如何使用c#操作access数据库: 手头没有microsoft access,如何建立数据库,一切依然简单. 首先引用c:program filescommon filessystemadomsadox.dll,该dll包含adox命名空间; 接着引用c:program filescommon filessystemadomsjro.dll,该dll包含jro命名空间 sxs
如何使用c#操作access数据库:
手头没有microsoft access,如何建立数据库,一切依然简单.
首先引用c:program filescommon filessystemadomsadox.dll,该dll包含adox命名空间;
接着引用c:program filescommon filessystemadomsjro.dll,该dll包含jro命名空间
sxs好问提示:如,导入dll不成功,手动把com组件导入为 .net组件,在用vs.net工具导入
using system;
using system.io;
using adox; //该命名空间包含创建access的类(方法)--解决方案 ==> 引用 ==> 添加引用 ==> 游览找到.dll
using jro; //该命名空间包含压缩access的类(方法)
public class access
...{
/**////根据指定的文件名称创建access数据库
///mdbpath:要创件的access绝对路径
public void create( string mdbpath )
...{
if( file.exists(mdbpath) ) //检查数据库是否已存在
...{
throw new exception(目标数据库已存在,无法创建);
}
// 可以加上密码,这样创建后的数据库必须输入密码后才能打开
mdbpath = provider=microsoft.jet.oledb.4.0;data source= + mdbpath;
// 创建一个catalogclass对象的实例,
adox.catalogclass cat = new adox.catalogclass();
// 使用catalogclass对象的create方法创建access数据库
cat.create(mdbpath);
}
/**////压缩修复access数据库,mdbpath为数据库绝对路径
public void compact( string mdbpath )
...{
if( !file.exists(mdbpath) ) //检查数据库是否已存在
...{
throw new exception(目标数据库不存在,无法压缩);
}
//声明临时数据库的名称
string temp = datetime.now.year.tostring();
temp += datetime.now.month.tostring();
temp += datetime.now.day.tostring();
temp += datetime.now.hour.tostring();
temp += datetime.now.minute.tostring();
temp += datetime.now.second.tostring() + .bak;
temp = mdbpath.substring(0, mdbpath.lastindexof()+1) + temp;
//定义临时数据库的连接字符串
temp2 = provider=microsoft.jet.oledb.4.0;data source= + temp;
//定义目标数据库的连接字符串
mdbpath2 = provider=microsoft.jet.oledb.4.0;data source= + mdbpath;
//创建一个jetengineclass对象的实例
jro.jetengineclass jt = new jro.jetengineclass();
//使用jetengineclass对象的compactdatabase方法压缩修复数据库
jt.compactdatabase( mdbpath2, temp2 );
//拷贝临时数据库到目标数据库(覆盖)
file.copy( temp, mdbpath, true );
//最后删除临时数据库
file.delete( temp );
} /**//// 备份数据库,mdb1,源数据库绝对路径; mdb2: 目标数据库绝对路径
public void backup( string mdb1, string mdb2 )
...{
if( !file.exists(mdb1) )
...{
throw new exception(源数据库不存在);
}
try
...{
file.copy( mdb1, mdb2, true );
}
catch( ioexception ixp )
...{
throw new exception(ixp.tostring());
}
}
/**////恢复数据库,mdb1为备份数据库绝对路径,mdb2为当前数据库绝对路径
public void recover( string mdb1, string mdb2 )
...{
if( !file.exists(mdb1) )
...{
throw new exception(备份数据库不存在);
}
try
...{
file.copy( mdb1, mdb2, true );
}
catch( ioexception ixp )
...{
throw new exception(ixp.tostring());
}
}
}
******************************************************************************************************
在beta2中,。net提供了以下的namespace:
system.data namespace
system.data.oledb (和beta1中已经不同了,所以如果拿beta1中的程序到beta2中来运行肯定不可以的)
如果想讲清楚这些东西,我不认为是我可以作到的,所以我想通过一些具体的程序来把我们对数据库的最基本的操作(select、update、delete、insert等)演示一下,其他的还是需要朋友们在学习过程中来慢慢体会了!
要想操作一个数据库,,不论是那种操作,首先要做的肯定是打开数据库,下面我们以access数据库来做例子说明如何打开一个数据库连接!在这里我们需要用到的是:system.data.oledb.oledbconnection类!(如果操作sql数据库,我们最好使用 system.data.sqlclient.sqlconnection类)
我先写出我自己使用的程序:
using system.data
using system.data.oledb
public oledbconnection getconn()
{
string connstr=provider=microsoft.jet.oledb.4.0 ;data source=f:webnotesbookclassleavenotes.mdb;
oledbconnection tempconn= new oledbconnection(connstr);
return(tempconn);
}
相信只要使用过ado的朋友应该都可以看懂的!我们先定义一个string类型的变量,其中存放了我们连接数据库的连接字符串,然后在定义一个 system.data.oledb.oledbconnection类型的对象并实例化,最后返回这个对象!需要说明一下的是,我并没有把语句: tempconn.open();放到这个函数中,原因我我稍后在说明,这里只是先提醒一下!
通过上面的函数,我们就已经得到了类似于ado中的连接对象connection了!下面的就是具体操作数据库了!
在具体讲操作前,我认为有必要先认识一下下面的两个类:
system.data.oledb.oledbdataadapter
system.data.oledb.oledbdatareader
system.data.oledb.oledbdataadapter:可以直接和dataset联系,并操作数据源的,它的功能相对强大一些,因此也比较耗系统资源!