用C#对ADO.NET数据库完成简单操作的方法
程序员文章站
2023-10-30 15:31:40
数据库访问是程序中应用最普遍的部分。随着c#和ado.net的引入,这种操作变得更简单。这篇文章将示范四种最基础的数据库操作。 ● 读取数据。其中...
数据库访问是程序中应用最普遍的部分。随着c#和ado.net的引入,这种操作变得更简单。这篇文章将示范四种最基础的数据库操作。
● 读取数据。其中包括多种数据类型:整型,字符串,日期型。
● 写数据。如读数据一样,我们也需要写入多种类型的数据。这可以通过sql语句来完成。
● 更新或修改数据。我们将再次用到sql语句。
● 删除数据。用sql实现。
上述的操作都要基于microsoft access 2000数据库,但是,我们要对连接字符串进行简单的修改才能使用sql或其他ado数据。
开始操作
在使用ado类之前,我们将把ado.net的命名空间和一些常用数据类包括进来。把下面的代码加入到你想进行数据库操作的地方。它的具体位置应该是命名空间行之后,类声明之前。
using system.data; // state variables
using system.data.ado; // database
using system.globalization; // date
你或许还要向system.data命名空间添加参数,这取决于工程的类型需要。你所添加的代码的编译信息会提醒你这一点。添加system.data命名空间的操作:
● 右键点击solution explorer--参数选项;
● 选择添加参数;
● 选择.net框架栏;
● 双击system.data.dll条目;
● 选择ok;
● system.data应该出现在solution explorer的参数列表中了。
由于在多数操作中都会使用连接字符串,所以我建议你将它包含在使用的类中。
注意:程序中数据库文件的路径可能和下面不一样:
//attributes
public const string db_conn_string =
"driver={microsoft access driver (*.mdb)}; "+
"dbq=d:\\cs\\testdbreadwrite\\simpletest.mdb";
读取数据
现在的操作就比较有趣了。读是通过adodatareader类完成的(参看chris maunder的文章"the ado.net adodatareader class" 以了解更多)。读的操作步骤如下:
● 用ado连接打开数据库
adoconnection conn = new adoconnection(db_conn_string);
conn.open();
● 创建一个sql语句来确认要获取的数据。这条命令执行后返回一个adodatareader对象。注意execute方法中的out关键字。这是c#中传递参数的方式。
adodatareader dr;
adocommand cmd = new adocommand( "select * from person", conn );
cmd.execute( out dr);
● 循环遍历adodatareader中的每条记录,直到完成。注意:数据被作为字符串直接返回。字段名显示了要读取的字段。
while( dr.read() )
{
system.console.writeline( dr["firstname"] );
}
● 清除
但是,作为优秀的程序员我们应该将代码放在try/catch/finally 中,确保我们能够控制所有意外。
try
{
.... the database operations ...
}
catch( exception ex )
{
system.console.writeline( "reading:" );
system.console.writeline( " error:" + ex.message );
system.console.writeline( " sql :" + ssqlcmd );
system.console.writeline( " conn.:" + db_conn_string );
}
finally
{
// close the connection
if( conn.state == dbobjectstate.open )
conn.close();
}
读取不同的数据类型
["stuff"]通常可以返回某个类型的字符串。但是要获取一个整型或 datetime对象,就需要列出这些数据。以一个简单的例子或是adodatareade内建的很多例子中的一个就可以说明。例如:
int nordinalage = dr.getordinal( "age" );
int nage = dr.getint32( nordinalage );
datetime tupdated = (datetime)dr["updated"];
注意通过名字定位getordinal字段的用法。如果字段是空的(没有填入值),上面的代码会引发一个异常。这种情况下我们用isnull方法检验数据是否存在。
int nordinalage = dr.getordinal( "age" );
if( dr.isnull( nordinalage ) )
{
system.console.writeline( " age : not given!" );
}
else
{
int nage = dr.getint32( nordinalage );
system.console.writeline( " age : " + nage );
插入,修改,删除和其他sql命令
插入,修改,和删除用sql语句很容易实现。下面的代码通过一个sql命令插入一条记录:
// sql command
string ssqlcommand = "insert into person (age, firstname,
description, updated) " +
"values( 55, 'bob', 'is a penguin',
'2001/12/25 20:30:15' );";
// create the command object
adocommand cmdadder = new adocommand(
ssqlcommand,
db_conn_string);
cmdadder.activeconnection.open();
// execute the sql command
int nnoadded = cmdadder.executenonquery();
system.console.writeline( "\nrow(s) added = " + nnoadded + "\n" );
注意:try/catch并未出现在上述例子中,实际上是需要写的。
插入
上述代码通过一条sql语句插入一条记录。这条命令稍后执行。命令格式中需要注意的是:
● 数值直接赋值,不同单引号(');
● 字符串必须用单引号括起来 ('blah');
● 字符串中不能包含任何单引号或是双引号;
● 日期和时间都要以国际格式包括在单引号中。('yyyyy/mm/dd hh:mm:ss')
修改
update命令指示了要被修和已做修改的记录。executenonquery()返回的值显示变化的纪录的数目,这样如果在表格中有5个peter那它就会返回5。
string ssqlcommand = "update person set age = 27 where firstname = 'peter'";
删除
delete命令显示要被删除的纪录。这可能会是几条。executenonquery()返回的值显示变化的纪录的数目,这样如果表中有2个bobo就返回2。这两个bobo都会被删除。
string ssqlcommand = "delete from person where firstname = 'bobo'";
关于样例程序
样例是个简单的控制程序,它执行microsoft access数据库中提供的所有操作。在visual studio.net ide将testdbreadwrite.csproj 作为工程文件打开就可以编译它。在mainconsole.cs中改变db_conn_strin的值,让其指向simpletest.mdb,编译它。
● 读取数据。其中包括多种数据类型:整型,字符串,日期型。
● 写数据。如读数据一样,我们也需要写入多种类型的数据。这可以通过sql语句来完成。
● 更新或修改数据。我们将再次用到sql语句。
● 删除数据。用sql实现。
上述的操作都要基于microsoft access 2000数据库,但是,我们要对连接字符串进行简单的修改才能使用sql或其他ado数据。
开始操作
在使用ado类之前,我们将把ado.net的命名空间和一些常用数据类包括进来。把下面的代码加入到你想进行数据库操作的地方。它的具体位置应该是命名空间行之后,类声明之前。
using system.data; // state variables
using system.data.ado; // database
using system.globalization; // date
你或许还要向system.data命名空间添加参数,这取决于工程的类型需要。你所添加的代码的编译信息会提醒你这一点。添加system.data命名空间的操作:
● 右键点击solution explorer--参数选项;
● 选择添加参数;
● 选择.net框架栏;
● 双击system.data.dll条目;
● 选择ok;
● system.data应该出现在solution explorer的参数列表中了。
由于在多数操作中都会使用连接字符串,所以我建议你将它包含在使用的类中。
注意:程序中数据库文件的路径可能和下面不一样:
//attributes
public const string db_conn_string =
"driver={microsoft access driver (*.mdb)}; "+
"dbq=d:\\cs\\testdbreadwrite\\simpletest.mdb";
读取数据
现在的操作就比较有趣了。读是通过adodatareader类完成的(参看chris maunder的文章"the ado.net adodatareader class" 以了解更多)。读的操作步骤如下:
● 用ado连接打开数据库
adoconnection conn = new adoconnection(db_conn_string);
conn.open();
● 创建一个sql语句来确认要获取的数据。这条命令执行后返回一个adodatareader对象。注意execute方法中的out关键字。这是c#中传递参数的方式。
adodatareader dr;
adocommand cmd = new adocommand( "select * from person", conn );
cmd.execute( out dr);
● 循环遍历adodatareader中的每条记录,直到完成。注意:数据被作为字符串直接返回。字段名显示了要读取的字段。
while( dr.read() )
{
system.console.writeline( dr["firstname"] );
}
● 清除
但是,作为优秀的程序员我们应该将代码放在try/catch/finally 中,确保我们能够控制所有意外。
try
{
.... the database operations ...
}
catch( exception ex )
{
system.console.writeline( "reading:" );
system.console.writeline( " error:" + ex.message );
system.console.writeline( " sql :" + ssqlcmd );
system.console.writeline( " conn.:" + db_conn_string );
}
finally
{
// close the connection
if( conn.state == dbobjectstate.open )
conn.close();
}
读取不同的数据类型
["stuff"]通常可以返回某个类型的字符串。但是要获取一个整型或 datetime对象,就需要列出这些数据。以一个简单的例子或是adodatareade内建的很多例子中的一个就可以说明。例如:
int nordinalage = dr.getordinal( "age" );
int nage = dr.getint32( nordinalage );
datetime tupdated = (datetime)dr["updated"];
注意通过名字定位getordinal字段的用法。如果字段是空的(没有填入值),上面的代码会引发一个异常。这种情况下我们用isnull方法检验数据是否存在。
int nordinalage = dr.getordinal( "age" );
if( dr.isnull( nordinalage ) )
{
system.console.writeline( " age : not given!" );
}
else
{
int nage = dr.getint32( nordinalage );
system.console.writeline( " age : " + nage );
插入,修改,删除和其他sql命令
插入,修改,和删除用sql语句很容易实现。下面的代码通过一个sql命令插入一条记录:
// sql command
string ssqlcommand = "insert into person (age, firstname,
description, updated) " +
"values( 55, 'bob', 'is a penguin',
'2001/12/25 20:30:15' );";
// create the command object
adocommand cmdadder = new adocommand(
ssqlcommand,
db_conn_string);
cmdadder.activeconnection.open();
// execute the sql command
int nnoadded = cmdadder.executenonquery();
system.console.writeline( "\nrow(s) added = " + nnoadded + "\n" );
注意:try/catch并未出现在上述例子中,实际上是需要写的。
插入
上述代码通过一条sql语句插入一条记录。这条命令稍后执行。命令格式中需要注意的是:
● 数值直接赋值,不同单引号(');
● 字符串必须用单引号括起来 ('blah');
● 字符串中不能包含任何单引号或是双引号;
● 日期和时间都要以国际格式包括在单引号中。('yyyyy/mm/dd hh:mm:ss')
修改
update命令指示了要被修和已做修改的记录。executenonquery()返回的值显示变化的纪录的数目,这样如果在表格中有5个peter那它就会返回5。
string ssqlcommand = "update person set age = 27 where firstname = 'peter'";
删除
delete命令显示要被删除的纪录。这可能会是几条。executenonquery()返回的值显示变化的纪录的数目,这样如果表中有2个bobo就返回2。这两个bobo都会被删除。
string ssqlcommand = "delete from person where firstname = 'bobo'";
关于样例程序
样例是个简单的控制程序,它执行microsoft access数据库中提供的所有操作。在visual studio.net ide将testdbreadwrite.csproj 作为工程文件打开就可以编译它。在mainconsole.cs中改变db_conn_strin的值,让其指向simpletest.mdb,编译它。