博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ADO.Net基础复习(一)
阅读量:6615 次
发布时间:2019-06-24

本文共 7185 字,大约阅读时间需要 23 分钟。

先前的一个SQL基础复习,有点粗枝大叶,不够具体、详细! 复习整理的,有很多属性和方法也没提到,只是说了一下常用的、基础的属性和方法!

一切都归因于老师的教导有方!

 

注意命名空间的引入:

using System.Data;

using System.Data. OleDb;       //用于OLEDB提供器支持的数据库

using System.Data. Odbc;        //用于ODBC数据提供器支持的数据库的数据

using System.Data.SqlClient;   //用于sql server数据库

 

五大对象:

Connection对象:建立与数据源的连接

Command对象:检索,插入,删除,修改数据

DataReader对象:只读,只向前的方式检索数据

DataAdapter对象:数据库和数据集交互的桥梁

DataSet对象:看成是驻留在内存中的一个小型数据库

 

四种典型的连接类

OdbcConnection

OleDbConnection

SqlConnection

 

下面是以对SQL Server数据库的操作

一、Connection对象:连接数据源   

1.创建Connection对象:   

string strCon="Data Source="user8\\SQLEXPRESS";Initial Catalog=studentdb";   

SqlConnection myConnection=new SqlConnection(strCon);      

2.属性:   

(1).ConnectionString:指定连接数据库所需的值字符串格式的描述   

 Data Source=服务名; Initial Catalog=数据库名; User ID=用户名;        Password=密码;  //Integrated Security=True;  

如: //SQL Server验证(注意转义字符:\),混合验证        

ConnectionString="Data Source=user8\\SQLEXPRESS;Initial Catalog=studentdb; User ID=sa;Passward=pws;"   

  //windows验证

ConnectionString="Data Source="user8\\SQLEXPRESS";Initial Catalog=studentdb;     Integrated Security=true;" 

(2).State:只读属性,表示连接状态

(3).Pooling:当为 true 时,请求新的连接时从池中取出,默认是true   

(4).Connect Timeout( Connection Timeout):等待服务器响应的时间(单位:秒). 默认值:15。   

(5).Provider:指打开数据库的驱动程序       

3.方法:   

(1).Open()  //根据连接串,打开连接   

(2).Close() //关闭连接,释放资源

4.事件:   

(1).StateChange:此事件发生在连接的状态发生更改时   

(2).InforMessage:此事件发生在从数据源返回信息性消息或警告时

 

二、Command对象:执行相关命令    

1.创建Command对象:    

string strSql="";//SQL命令    

(1).SqlCommand com=new SqlCommand(strSql,connection);    

(2).SqlCommand com=connection.CreateCommand(strSql);    

2.属性    

(1).Connection:连接对象    

(2).CommandText:要执行的SQL命令(SQL语句或存储过程)    

(3).CommandType:默认值是Text,执行sql语句;并可设置为StoredProcedure,执行存储过程;TableDirect,指示所包含的是要访问的一个表的名称,从此表中将取出所有的列和行    

(4).Parameters:Parameters集合    

(5).Transaction:执行命令所在的事务       

3.方法    

(1).ExecuteNonQuery():返回执行命令受影响的行数,用于增删改操作

(2).ExecuteScalar():返回执行sql语句的第一行第一列的值,用于查询单列值      

(3).ExecuteReader ():返回一个DataReader对象[只向前、只读的结果集],用于查询多个数据    

4.对于Parameters集合:    

(1).属性:    

<1>.Count属性:获取集合中参数的数目;    

<2>.ParameterName:设置为SQL命令或存储过程中的参数名,如 ”    

<3>.SqlDbType:将该属性设置为参数的数据类型。    

设置SqlParameter对象的数据类型的方法有以下两种。    

在DbType枚举中选择一个值赋给DbType属性   

在SqlDbType枚举中选择一个值赋给SqlDbType属性    

<4>.Size:设置该属性以指示参数大小,例如字符串参数中字符的个数。     无需为已知且具有固定大小的数据类型(例如DbType.Int32)指定大小   

<5>.Direction:设置该属性以指示该参数是只输入参数、只输出参数、双向参数 还是存储过程的返回值。

该属性可设置为ParameterDirection枚举值之一:     ParameterDirection.Input、ParameterDirection.InputOutput、    ParameterDirection.Output或ParameterDirection.ReturnValue。默认方向为    ParameterDirection.Input    

<6>.Value:对于只输入参数或双向参数而言,在运行该命令之前需要设置Value属性。

对于只输出参数、双向参数和存储过程的返回值而言,在运行该命令之后可以检索Value属性    

(2).方法:    

<1>.Add():将参数添加到集合中;    

<2>.Clear():从集合中移除所有参数;    

<3>.Insert():将参数插入集合中的指定索引位置;    

<4>.Remove():从集合中移除所指定的参数;    

(3).创建参数对象:    

strSQL="select  *  from CustomersTb where ";       

<1>.第一种方式:     cmd.Parameters.add(new SqlParameter("@customerid","ALFKI"));    

<2>. 第二种方式 :    

SqlParameter myPara=new SqlParameter();    

myPara .ParameterName="@customerid";    

myPara.value="ALFKI";   

cmd.Parameters.Add(myPara);    

5.对于ExecuteReader ()方法返回一个DataReader对象    

(1).DataReader的创建:sqlDataReader rdr=cmd.ExecuteReader();    

(2).属性:    

<1>.FieldCount:字段数    

<2>.HasRows:是否有数据未读    

<3>.IsClosed:判断DataReader对象是否关闭    

(3).方法:    

<1>.GetValue():获取指定字段的值    

<2>.GetOrdinal():获取字段的序号    

<3>.Read():判断并读取下一条记录    

<4>.Close():关闭对象    

还有方法:GetInt32()\GetName()\NextResult()\IsDBNull()

 

三、Adapter数据适配器对象:数据库和数据集的桥梁(断开环境)    

DataAdapter是和数据集(DataSet)一起使用的对象,数据库与数据集之间起桥梁作用;专门为处理脱机数据而设计的。        

1.创建DataAdapter对象:    

string   Source=.;Initial Catalog=northwind;User ID=MyUserid;Password=myPassword;"    

string strSql="select * from studentsTb";      

(1).用查询串和连接字符串    

SqlDataAdapter da=new SqlDataAdapter (strSql,strConn);    

该方式会为每个SqlDataAdapter 创建一个新的SqlConnection对象,应适当选择。

用查询串和连接对象 SqlConnection cn=new sqlConnection(strConn);                  

(2).SqlDataAdapter da=new SqlDataAdapter (strSql,cn);     

比较常用的方式    

(3).使用SqlCommand对象    

SqlCommand cmd=new SqlCommand(strSql,CN);             

SqlDataAdapter da=new SqlDataAdapter (cmd);    

已存在一个SqlCommand对象时使用.           

2.属性:    

(1).SelectCommand:在数据源中检索数据的数据命令    

(2).InsertCommand:在数据源中插入数据的数据命令    

(3).UpdateCommand:在数据源中更新数据的数据命令    

(4).DeleteCommand:在数据源中删除数据的数据命令    

(5).TableMappings:DataTableMapping对象的集合,决定DataSet中的行与数据源之间的关系    

(6).UpdateBatchSize:决定批进程支持,指出在批处理中可执行的命令的数量

3.方法:    

(1).Fill()    

<1>. Fill(DataSet) :DataSet结果集    

<2>. Fill(DataTable): DataTable对象    

<3>. Fill(Int32,Int32,params DataTable[]):开始记录索引 ,要填充的数据表的行数, DataTable对象   

<4>.Fill(DataSet, Int32,Int32,String) :DataSet结果集,对象 开始记录的索引 ,要填充的数据集的行数 ,表名    

(2).Update()

4.对于TableMappings属性的应用    

(1).先创建SqlDataAdapter对象    

SqlDataAdapter adapter = CreateDataAdapter(conn, age);   

DataSet ds = new DataSet();     

(2).Mappings的用法   

DataTableMapping mapping = adapter.TableMappings.Add("Table", "学生表");   

mapping.ColumnMappings.Add("SNO", "学生编号");  

mapping.ColumnMappings.Add("SName", "学生姓名");  

mapping.ColumnMappings.Add("SDept", "所在院系");  

mapping.ColumnMappings.Add("SClass", "所在班级");

mapping.ColumnMappings.Add("SSex", "性别");   

mapping.ColumnMappings.Add("SAge", "年龄");       

(3).数据填充    

adapter.Fill(ds);      

(4).dataGridView绑定显示   

dataGridView1.DataSource = ds.Tables["学生表"];//使用设置好的映射表名字  

dataGridView1.Refresh();      

5.Update()方法的应用    

(1).数据填充    

string strSql="SELECT * FROM STUDENT";     

adapter.SelectCommand = new SqlCommand(strSql, conn);                   

SqlCommandBuilder builder = new SqlCommandBuilder(adapter);

adapter.Fill(ds);

dataGridView1.DataSource = ds.Tables[0];      

dataGridView1.Refresh();    

更新时的代码:

adapter.Update(ds);              

MessageBox.Show("更新成功");       

6.DataAdapter的事件    

(1).Disposed:当调用Dispose释放组件的时候调用。    

(2). FillError:在填充操作过程中出现错误时返回。    

(3). RowUpdating:在对数据源执行命令前的Update过程中发生,试图进行更新,因此激发该事件。    

(4). RowUpdated:在对数据源执行命令后的Update过程中发生,试图进行更新,因此激发该事件。

   

四、DataSet:数据集

1.DataSet 层次结构中的类:DataTable\DataColumn\DataRow\DataTableCollection\DataCloumnCollection\DataRowCollection\

2.对于DataTable对象允许访问数据集中被访问的Rows集合,有如下方法: Add()\InsertAt()\Find()\Select()\Remove()

对于DataTable对象允许访问数据集中被访问的Columns集合,有如下方法: Add()\InsertAt()\Find()\Select()\Remove()

3.创建DataTable   

//创建一个DataTable的一个实例。

DataTable dt = new DataTable("学生表");

//声明列对象            

DataColumn column;               

column = new DataColumn();               

//设置列的数据类型               

column.DataType = System.Type.GetType("System.Int32");               

column.ColumnName = "学生编号";               

column.ReadOnly = true;               

column.Unique = true;               

//向DataTable添加该列               

dt.Columns.Add(column);

//建立一个新行   

row = dt.NewRow();              

//为新建立的行添加数据               

row["学生编号"] = Convert.ToInt32(txtID.Text.ToString());               

row["学生姓名"] = txtName.Text;

//为该表添加指定的行              

dt.Rows.Add(row);

 

//绑定数据为DataGridView              

dataGridView1.DataSource = dt;              

dataGridView1.Refresh();

4.DataTable的Select方法 三个参数:

(1). String:筛选条件

(2).String:排序表达式

(3).RowStateValue:一个值,指示要以什么版本或状态进行筛选。这是一个枚举值。如 :DataViewRowState.CurrentRows。

示例代码:  

DataTable dataTable = new DataTable("学生表临时");       

dataTable = dt.Clone();

string expression = "学生编号 = " + Convert.ToInt32(txtID.Text.ToString());              

//按照条件筛选数据              

DataRow[] foundRows = dt.Select(expression);

//遍历查询出来的结果并将其绑定到DataGridView2上。            

foreach(DataRow dr in foundRows)            

{                  

  DataRow dataRow = dataTable.NewRow();                  

  dataRow[0] = dr[0];                  

 dataRow[1] = dr[1];

 dataTable.Rows.Add(dataRow);          

}

 //绑定数据为DataGridView              

dataGridView2.DataSource = dataTable;              

dataGridView2.Refresh();

5.DataTable对象的SELECT方法的功能非常强大,但它效率低,windows web窗体都不支持绑定到select方法的返回值,dataView类能弥补select的局限性. DataView属性:

(1).RowFilter:此属性用来指定用来过滤记录的字符串格式的表达式/条件。满足条件的记录将只被包括在视图中。

(2).RowStateFilter:此属性指定此 DataView 返回的数据的版本。

(3).Sort:此属性用来指定将按其排序记录的表达式。表达式包括列名称和排序限定符,其为 ASC 或 DESC,以升序或降序来显示记录。   

本文转自SanMaoSpace博客园博客,原文链接:http://www.cnblogs.com/SanMaoSpace/archive/2011/11/15/2250375.html,如需转载请自行联系原作者

你可能感兴趣的文章
Android4.0 WiFi 源码解读
查看>>
反序列化坑
查看>>
dubbo源码解读系列之一dubbo项目组成
查看>>
linux中seq命令用法
查看>>
arnold resouces
查看>>
凭兴趣求职80%会失败,为什么
查看>>
URI的常用使用场景
查看>>
详解网络流量监控
查看>>
Ubuntu 修改 IP/DNS
查看>>
Java API 学习 (java 、javax 、org )的理解 (1)
查看>>
mysql error:Lock wait timeout exceeded
查看>>
将乱码后的中文作为key放入redis后,取值时找不到key该怎么弄
查看>>
祝各位2019
查看>>
ubuntu16.0.4安装ganglia
查看>>
js模拟点击事件实现代码
查看>>
【★】独创多播超级教程!
查看>>
Scala之美 - Future & map & flatMap
查看>>
Java获取随机数生成随机字符串用于验证码等之类的工具
查看>>
简单的下单程序
查看>>
Golang面试题解析(三)
查看>>