SqlCommand对应着SqlClient模式;OleDbCommand对应着OleDb模式,OdbcCommand对应着Odbc模式。
假设我们想使用SqlClient模式查询SqlServer中testDB数据库中student表中的xh(学号)、xm(姓名)和xb(性别)三列的值,则可以建立如下的命令对象(sConn参见建立的连接sConn:
SqlCommand sCmd=new SqlCommand("SELECTxh,xm,xbFROMstudent",sConn);
亦可使用如下的形式:
SqlCommand sCmd=new SqlCommand();
sCmd.CommandText="SELECTxh,xm,xbFROMstudent";
sCmd.Connection=sConn;
命令对象常用的有三个方法:ExecuteReader(),ExecuteNonQuery()和ExecuteScalar()。ExecuteReader方法用于返回查询结果的全部数据。ExecuteNonQuery方法用于返回所影响的行数,一般用于Insert、Update和Delete操作。ExecuteScalar方法返回结果中的第一行第一列的值。
5、数据读取器DataReader
DataReader用于从返回来的数据区中读取数据。其根据使用的数据连接模式不同也有不同的形式:SqlDataReader对应着SqlClient模式,OleDbDataReader对应着OleDb模式,OdbcDataReader对应着Odbc模式。
数据读取器应与命令对象配合使用,下面接着4中的例子来写:
SqlDataReader sdr=null;
sdr=sCmd.ExecuteReader();//执行命令对象,并用sdr指向结果集的第一条记录。
while(sdr.Read())//每读取一条记录后,指向其下一条记录
{
Console.WriteLine("学号:{0},姓名:{1},性别:{2}",sdr["xh"],sdr["xm"],sdr["xb"]);//或使用下面的格式
//Console.WriteLine("学号:{0},姓名:{1},性别:{2}",sdr[0],sdr[1],sdr[2]);
}
sdr.Close();//关闭读取器
6、数据集DataSet和数据适配器DataAdapter
一般数据集和数据适配器是密不可分的,下面先介绍数据适配器。
数据适配器可以容纳一组数据命令和一个数据库连接对象,这与Command对象不同,Command只有一个数据命令和一个数据库连接。数据适配器根据不同的连接模式也有不同的形式:SqlDataAdapter、OleDbDataAdapter和OdbcDataAdapter。下面给出SqlClient模式下数据适配器的定义方式:
SqlDataAdaptersda=newSqlDataAdapter("SELECTxh,xm,xbFROMstudent",sConn);
第一个参数是用到的SQL语句,第二个参数是数据连接。也可以使用一个命令对象传递上面的信息。即:
SqlDataAdaptersda=newSqlDataAdapter(sCmd);
下面再介绍一下DataSet,DataSet是在内存中缓存的数据集,包括数据本身,还包括定义在数据上的约束和关系等信息。数据集中可以包含0个这样的数据对象。不管使用什么样的数据库连接模式,其只有唯一的形式。其定义方法如下:
DataSet ds=newDataSet();
定义完数据集后,就可以调用数据适配器的Fill方法来填充数据集:
sda.Fill(ds);
也可以在填充的同时,指定表名:
sda.Fill(ds,"Student");
可以使用下面的方法读取数据集中的数据信息:
introwNum=ds.Tables["Student"].Rows.Count;//获得数据集表student表中的行数
intcolumnNum=ds.Tables["Student"].Columns.Count;//获得数据集表student中的列数
for(inti=0;i<rowNum;i++)
{
for(intj=0;j<columnNum;j++)
{
Console.Write(ds.Tables["student"].Columns[j].ColumnName+":"+ds.Tables["student"].Rows[i][j].ToString();
}
Console.WriteLine();
}
下面给出一个数据库操作的例子。假设在SqlServer中有一个数据库test,其存放着一个数据表名为student,其结构为student(xh,xm,xb,mz),下面使用SqlClient模式连接数据库:
usingSystem;
//引入命名空间
usingSystem.Data;
usingSystem.Data.SqlClient;
classDbOper
{
staticvoidMain()
{
//定义连接字符串
string connString;
connString="server=.;uid=sa;pwd=;database=test;";
//定义连接对象sConn
SqlConnections Conn=new SqlConnection(connString);
try
{
//打开连接
sConn.Open();
}
catch(Exceptionex)
{
//给出错误信息
Console.WriteLine("连接错误:"+ex.Message);
}
//定义SQL查询语句
stringsql;
sql="select*fromstudent";
//定义命令对象sCmd
SqlCommandsCmd=newSqlCommand(sql,sConn);
//定义数据读取器sdr
SqlDataReadersdr=null;
//执行命令对象sCmd并赋值给sdr
sdr=sCmd.ExecuteReader();
//循环输出sdr中的内容
Console.WriteLine("学号姓名性别民族");
while(sdr.Read())
{
Console.WriteLine(sdr[0]+""+sdr["xm"]+sdr["xb"]+""+sdr["mz"]);
}
//关闭数据读取器
sdr.Close();
//关闭数据库连接
sConn.Close();
}
}