当前位置: 移动技术网 > IT编程>开发语言>.net > ADO.NET基础知识汇总

ADO.NET基础知识汇总

2017年12月12日  | 移动技术网IT编程  | 我要评论

khy-016,你是我的命运插曲,css特效

虽然我们都知道ado.net是对数据库的操作,但是要真的说出ado.net的具体含义还不是很容易。
ado.net是activex data objects的缩写,它是一个com组件库,用于在microsoft技术中访问数据。之所以叫ado.net,应该是微软自己打的广告,希望在net编程环境中优先使用这种数据访问接口。上面这段话基本来自百度百科。简单来说,ado.net就是一种数据访问接口,可以让我们在程序中调用相应的类库对数据库(通常为sql server,也可以是access 等其他数据库)进行增删改查等操作。

ado.net的几大组成部分
ado.net由五大类库组成,分别是:

connection(用于建立与 数据库的连接)
command(用于执行sql语句)
datareader(用于读取数据)
dataadapter(用于填充把数据填充到dataset)
dataset(数据集,用于程序中)

通常,从程序中访问数据库的方法是:

创建一个到数据库的连接
打开数据库连接
创建ado记录集
从记录集中提取需要的数据
关闭记录集
关闭连接

下面就分别根据这一个过程结合ado.net的五大类库进行解释。

要想使用ado.net需要在程序中引用system.data.sqlclient。其中包含了对sql server进行操作的数据访问类:

sqlconnection:连接数据库
sqlcommand:数据库命名对象
sqlcommandbuilder:生成sql命令
sqldatareader:数据读取器
sqldataadapter:数据适配器,用于填充dataset
sqlparameter:为存储过程定义参数
sqltransaction:数据库事务

建立连接

首先,要想访问数据库,我们需要一个媒介把程序与数据库连接起来。这就是连接字符串,它的基本语法为:data source(数据源) + initial catalog(数据库名称) + user id(用户名) + password(密码)。

复制代码 代码如下:

string connectstring = "data source = myserveraddress;initial catalog = mydatabase;user id = myusername; password = mypassword;";

或者

复制代码 代码如下:

string connectstring = "server =myserveraddress;database = mydatabase; user id = myusername; password = mypassword;";

注意:对于sql server来说,它支持两种身份验证方法,一种是windows身份验证,另一种是sql server身份验证。如果要用windows身份验证,就需要在连接字符串中包括integrated security属性。该属性默认为false。需要设置为true后才能使用windows身份验证。
除了这几个必须的字段,连接字符串中还有许多可选的属性,在这里我就不一一列举,列出一些相关资料供感兴趣的朋友自行查阅,一个连接字符串可以包含哪些属性()。

接着,有了连接字符串就可以创建连接对象了。

sqlconnection connection = new sqlconnection(connecstring);
或者可以使用专门的连接字符串生成器:

复制代码 代码如下:

sqlconnectionstringbuilder connectionstringbuilder = new sqlconnectionstringbuilder()
{
datasource=”“,
initialcatalog=”“,
userid=”“,
password=””
};
sqlconnection connection = new sqlconnection(connectionstringbuilder.tostring());

然后使用连接对象可以打开或关闭连接。

connection.open();
connection.close();

执行命令

打开连接之后就可以操作数据库了,在这里需要用到sqlcommand命令对象。
它具有四个主要属性,这些属性会在初始化的时候赋默认值:
commandtext:空字符串(”“)
commandtimeout:30
commandtype:commandtype.text
connection:null

创建命令对象:

sqlcommand command = connection.createcommand(); 


sqlcommand command = new sqlcommand();

sqlcommand包含了几个重要的属性:
commandtext:用于获取或设置药对数据源之行的sql语句、表明或存储过程。
commandtype:设置你执行的sql语句类型,有三个枚举,分别是text(sql文本命令),storedprocedure(存储过程),tabledirect(表名)。
parameters:设置你的t-sql中需要用到的参数。

几个重要的方法:

executenonquery:返回被sql语句执行影响的行数(int),主要执行增删改操作。
executereader:执行sql或存储过程,返回的是sqldatareader类型,主要用来查询。
executescalar:返回执行结果集中的第一行第一列,如果没有数据,则返回null。
createparameter:创建sqlparameter实例。

举例说明:

using system;
using system.collections.generic;
using system.linq;
using system.text;
using system.data;//必须
using system.data.sqlclient;//必须
namespace command
{
 class program
 {
  static void main(string[] args)
  {
    sqlconnectionstringbuilder constr = new sqlconnectionstringbuilder();
    const.datasource=@".\sqlexpress";
    constr.integratedsecurity=true;
    constr.initialcatalog="db_test";
    stringbuilder strsql = new stringbuilder();
    for(int i=0;i<=100;i++)
    {
     strsql.append("insert into tb_test");
     strsql.append("values('");
     string name = "test"+i.tostring();
     strsql.append(name);
    }
    using(sqlconnection con = new sqlconnection(constr.connectionstring))
    {
     con.open();
     sqlcommand cmd = new sqlcommand(strsql.tostring(),con);
    int impactednumber = cmd.executenonquery();//返回受影响的行数
    object firstdata = cmd.executescalar();//返回执行结果中的第一行第一列,此方法可用于获取插入数据的id,(int linenumber =(int)cmd.executescalar();)
    }
  }
 }
}

sql参数
若想在程序中传递参数给数据库,可以使用sqlparameter。该类有几个重要的属性:

parametername:设置参数名
value:给参数设置值
size:设置参数字节最大长度
sqldbtype:参数在sql中的类别

和几个重要的方法:

addwithvlue

add
addrange

举例说明:

 sqlconnection connection =new sqlconnection(""))
 {
  sqlcommand cmd = connection.createcommand();
  cmd.commandtext="";
cmd.parameters.add("@name",sqldbtype.nvarchar).value = "deng";//方法一
cmd.parameters.addwithvalue(@"name","deng");//方法二
sqlparameter[] parameters = new sqlparameter[]
 {
 new sqlparameter("@name",sqldbtype.nvarchar,100){value="deng"},
 };
 cmd.parameters.addrange(parameters);//可以放一个参数数组,包含多条参数,在此只举一个例子
}

可以通过cmd.parameters[i].value设置和读取数值。

数据读取

利用查询语句得到的数据信息需要通过数据读取器进行操作。
举例:

sqlconnetion con = new sqlconnection("")
{
 con.open();
 sqlcommand cmd = con.createcommand();
 cmd.commandtext="";
 sqldatareader dr = cmd.executereader(commandbehavior.closeconnection)
 {
  while(dr.read())
  {
   string str = dr.getsqlstring(0).tostring();
  }
 }
}

介绍几个常用的方法:

getordinal:可以获取指定列名的序列号,int name = dr.getordinal(“name”);
getname:与上面的方法对应,可以通过列号返回列名字。
isdbnull:判断当前读取的数据是否为null。
nextresult:当查询为批处理查询时,使用这个方法去获取下一个结果集,返回值为bool,如果存在多个结果集,则为true;否则为false。
read:读取数据。

常用属性有:

hasrow:判断是否有数据。
fieldcount:获取读取的列数。
isclosed:判断读取的数据流是否关闭。
sqldatareader是连接相关的,也就是说与数据库的连接一断开就无法读取数据库中的数据,说明查询结果并不是放在程序中,而是放在数据库的服务中。

事务

需要用到sqltransaction类,需要在指定位置命名存储点,该存储点之后的操作都将会回滚。
例子:

sqlconnection con = new sqlconnection(strcon);
con.open();
sqltransaction transaction = con.begintransaction();
sqlcommand cmd = con.createcommand();
cmd.commandtext = ""
cmd.transaction = transaction;
transaction.save("transaction point");
transaction.rollback("transaction point");

数据适配器

sqldataadapter类有四个重载构造函数:

无参
sqldataadapter(sqlcommand)
sqldataadapter(string,sqlconnection)
sqldataadapter(string, connectionstring)
填充数据例子:

dataset dataset = new dataset();
sqlconnection con = new sqlconnection("");
con.open();
sqlcommand cmd = con.createcommand();
cmd.commandtext="select xxx from tb_xxx";
sqldataadapter dataadapter = new sqldataadapter(cmd);
dataadapter.fill(dataset);

填充后的数据可以使用sqlcommandbuilder进行增删改查。

例子:

sqlconnection con = new sqlconnection(connectionstring();
con.open();
sqldataadapter da = new sqldataadapter("select xxx from tb_xx");
dataset ds =new dataset();
da.fill(ds);
sqlcommandbuilder cmdbuilder = new sqlcommandbuilder(da);
datarow row = ds.tables[0].newrow();
row[0]="a";
row[1]="b";
ds.tables[0].rows.add(row);
da.update(ds);

sqlcommandbuilder 可以把dataset增加的数据转化为sql语句用来更新数据库。然后调用update方法。

总结

因为现在使用的框架或着库都已经封装了ado.net,可能在日常工作中很少会再从头开始编写ado.net来连接数据库,但是在.net面试中还是非常常见的,希望可以借此加深一下印象。另外,本人目前持有的是银蕨签证,可以在新西兰求职9个月,期间如果找到相关专业工作,可直接转2年的工作签证,非常方便移民,该签证每年全球发放300个,虽然还没有working holiday签证为大家所熟知,但是每年的争抢还是很激烈的。需要了解相关事宜的可以给我留言。本人的第一篇博客,属于整理资料,并非完全原创,如有哪方面不正确,还希望大神可以多多指正。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网