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

本文共 7151 字,大约阅读时间需要 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,以升序或降序来显示记录。   

 

转载于:https://www.cnblogs.com/SanMaoSpace/archive/2011/11/15/2250375.html

你可能感兴趣的文章
【BZOJ1030】[JSOI2007]文本生成器
查看>>
LG GPRO2 SudaMod 3.1 自编译版 20180524 更新
查看>>
Android系统移植与调试之------->增加一个双击物理按键打开和关闭闪光灯并将闪光灯状态同步到下拉菜单中...
查看>>
【测试工程师面试】记录自己的一次面试
查看>>
关于lettuce的一个基本操作的总结
查看>>
[转载]步进电机原理介绍与基于STM32的SPWM驱动步进电机,使用软件实现电机细分...
查看>>
css hack
查看>>
Python 递归
查看>>
第3章 敏捷项目管理概述
查看>>
C语言中函数strcpy ,strncpy ,strlcpy的用法
查看>>
让函数只执行一次的简化写法(非单列模式)
查看>>
Android深入浅出系列之Bluetooth—蓝牙操作(一)
查看>>
MapReduce入门
查看>>
软件测试作业03
查看>>
vs 代码格式化
查看>>
对话框Dialog总结
查看>>
权限管理系统
查看>>
病毒的基本知识
查看>>
【Codeforces Round #431 (Div. 1) D.Shake It!】
查看>>
Morris算法-----二叉树遍历
查看>>