来源于网络

1.       SqlConnection(DBConnection)  建立程序与数据库的链接 链接字符串有两种形式:

//使用Windows验证  SSPI(安全支持提供程序接口)

String theConnectionString =”Data Source=.express; Initial Catalog=DataBase; Intergrated Security=SSPI”;

//使用SQL Server身份验证

String theConnectionString=”Data Source=.express; Initial Catalog=DataBase; User ID=XX; Password=mypassword”;

关于连接池(connection pooling):里面放了很多的连接,只要连接字符串的值不发生改变,Ado.net则会重用现有的链接,而不建立新的链接。其默认值为true,这也是为什么每次操作结束之后都调用一个conn.Close()方法:将连接返回连接池。

2.       SqlCommand(DBCommand) 对数据库发出一些指令

写好CommandText之后可以选择执行:

*ExecuteNonQuary: 适用于不需要返回任何记录的情况,比如insert,update,delete

*ExecuteReader :通过执行ConnectText,返回一组DataReader对象

*ExecuteScalar :用于执行查询,返回查询结果所返回的数据集中的第一行第一列

*ExecuteXmlReader:

或者用Adapter来执行

它用的比较多的属性有:

*CommandText : *CommandType :*Connection : *Parameter :

期中的CommandType共有三种:CommandType.Text/CommandType.StoredProcedure/

CommandType.TableDirect

存储过程:theComand.CommandText=”存储过程名”

theComand.CommandType=CommandType.StoreProceduce

Parameter :向command对象添加参数

防止SQL注入:

Using(SqlCommand cmd=new SqlCommand())

{

cmd.Connection=conn;

cmd.CommandText=”delete customer where customerID=@id”;

cmd.CommandType=System.Data.CommandType.Text;

SqlParameter paramID=new SqlParameter(“@id”,textBox1.Text);

cmd.Parameter.Add(paramID);

}

3.       DataAdapter  链接数据库与DataSet之间的桥梁

SqlDataAdapter sda=new SqlDataAdapter(command): 在默认情况下,这个command会用于填充DataAdapter的SelectCommand属性,对于其他的属性,可以使用SqlCommandBuilder自动生成:

SqlDataAdapter sda=new SqlDataAdapter(theCommand);

SqlCommandBuilder theBuilder=new SqlCommandBuilder(sda);

Adapter.Fill(ds,”DataTable”) : 使用SelectCommand属性获取对象,并将它填充到ds中的DataTable表中

Adapter.FillSchema(ds1,SchemaType.Source,”DataTable”) 不放数据,而是把DataTable的框架拷贝给ds1

Adapter.Update();将数据库中的数据更新到DataSet中

4.       DataReader : 当只需要循环读取数据而不需要进行其他操作的时候可以使用这个。因为它在读取数据时限制了每次只能读取一笔数据,而且只能只读,所以使用起来不仅节省资源,而且效率很高。

DataReader对象通过Command的ExecuteReader方法获得,一旦获得之后可以使用它的Read方法来获取数据

SqlDataReader reader=new SqlDataReader();

String output=String.Empty;

If(reader.HasRows)

{

while(reader.Read()

{Console.WriteLine(reader[“name”]/reader[1]).toString();}

}

Reader.Close();

5.       DataSet :可以将它视为一个cache,将数据库中查询到的数据保留起来

构造的时候顺序(列->表->cache):

Private static DataSet BuildDataSet()

{

DataSet ds=new DataSet();

DataTable dt=new DataTable(“Product”);

DataColumn dcProID=new DataColumn(“ProductID”,typeof(int));

DataColumn dcProName=new DataColumn(“ProductName”,typeof(string));

dcProName.MaxLength=100;

DataColumn dcReleaseDate=new DataColumn(“ReleaseDate”,typeof(DataTime));

//添加列

Dt.Column.Add(dcProID);

Dt.Column.Add(dcProName);

Dt.Column.Add(dcReleaseDate);

//添加约束:

Dt.PrimaryKey=new DataColumn[]{dcProID };

Dt.Constraints.Add(new UniqueConstraint(dcProName));

//添加元祖:

Dt.Raws.Add(new object[]{1,””,DataTime.Now});

Ds.Table.Add(dt);

Return ds;

}

若有多张表的话,还可以创建DataRelation  参考:http://blog.sina.com.cn/s/blog_55a69f170100l16k.html

删除DataTable中的一行:

Public void DeleteCustomer(int id)

{

DataSet ds=new DataSet();

DataRow[] results=ds.Table[“表名”].Select(“ID=”+id.ToString());

If(results.length>0)

{result[0].Delete();} //Delete:给行标记上删除记号,等最后操作的时候删除,区分与Remove()的区别

Ds.AcceptChanges();

}

ADO。net学习笔记的更多相关文章

  1. ADO.NET 学习笔记 入门教程

    本文转载自:http://www.youarebug.com/forum.php?mod=viewthread&tid=57&page=1&extra=#pid63 这是本人在 ...

  2. ADO.NET学习笔记(1)

    ADO.Net是.Net框架中为数据库的访问而封装的一个库.通过这个库我们可以简单便捷的访问数据库,并对数据库进行一些增删改查的操作,目前ADO.Net支持四种主流的数据库,分别是SQL.OLE DB ...

  3. C#-ado.net学习笔记-会有更新

    ado.net 通用类对象.在本地内存暂存数据 托管类对象.让本地通用类对象连接数据库,让本地通用类对象和数据库同步 连接数据库 new connection(connectstring) comma ...

  4. Sql Ado.net 学习笔记之连接字符串

    https://www.cnblogs.com/heng95/p/5902019.html 连接字符串 SQL Client .net数据提供程序在连接到数据库时极其灵活,它提供了多种用以生成连接字符 ...

  5. ADO.NET Entity Framework学习笔记(3)ObjectContext

    ADO.NET Entity Framework学习笔记(3)ObjectContext对象[转]   说明 ObjectContext提供了管理数据的功能 Context操作数据 AddObject ...

  6. ADO学习笔记之注入漏洞与参数化查询

    ADO学习笔记之注入漏洞与参数化查询 作为新手,在学习ADO程序时,使用 sql 语言查询数据时,很容易写类似如下代码: using (SqlConnection con = new SqlConne ...

  7. Entity Framework学习笔记——错误汇总

    之前的小项目做完了,到了总结经验和更新学习笔记的时间了.开始正题之前先啰嗦一下,对之前的学习目标进行一个调整:“根据代码生成表”与“生成数据库脚本和变更脚本”合并为“Code First模式日常使用篇 ...

  8. AJax 学习笔记二(onreadystatechange的作用)

    AJax 学习笔记二(onreadystatechange的作用) 当发送一个请求后,客户端无法确定什么时候会完成这个请求,所以需要用事件机制来捕获请求的状态XMLHttpRequest对象提供了on ...

  9. CUBRID学习笔记 3 net连接数据库并使用cubrid教程示例

    接上文 数据库安装好后,也可以测试语句了. 下面我们用c#写一个控制台程序,连接数据库,并读取数据. 一 下载驱动  net版的下 CUBRID ADO.NET Data Provider 9.3.0 ...

  10. Entity Framework学习笔记

    原文地址:http://www.cnblogs.com/frankofgdc/p/3600090.html Entity Framework学习笔记——错误汇总   之前的小项目做完了,到了总结经验和 ...

随机推荐

  1. 哈佛大学构建动态网站--第七讲ajax

    Ajax ajax举例: DOM的结构 通过js来修改html页面. Ajax的含义: return false的用途 跨浏览器的ajax 为什么不直接从yahoo获得数据呢? XMLHttpRequ ...

  2. 【重大bug】viewpager使用的时候加载数据应该在setOnPageChangeListener里加载

    [重大bug]viewpager使用的时候加载数据应该在setOnPageChangeListener里的onPageSelected里加载,我说怎么首页有数据,第二页就是空白,就是加载了但是数据不显 ...

  3. 关于iOS socket都在这里了

    socket(套接字)是通信的基石,是支持TCP/IP协议的网络通信的基本操作单元,包含进行网络通信必须的五种信息:连接使用的协议,本地主机的IP地址,本地进程的协议端口,远地主机的IP地址,远地进程 ...

  4. get 和 post请求的区别

    (1)GET请求用于获取信息,从Client的角度看,不会改变资源状态,并且多次对同一URL的多个请求应该返回相同的结果.        GET请求的参数会显示在URL中,即放置在HTTP协议头中(所 ...

  5. OpenLayer 3 鼠标位置坐标显示控件

    <body> <div id="map"> <div id="mouse-position"></div> &l ...

  6. FZU 2113 BCD Code 数位dp

    数位dp,但是很奇怪的是我在虚拟oj上用GUC C++提交会wa,用Visual c++提交正确,但是加上注释后提交又莫名CE--好任性啊 0 ,0 题目思路:看代码吧 注释很详细 #include& ...

  7. div.2/D. As Fast As Possible<数学题,二分>

    题目连接 题意: n个学生出去玩,要前进一段距离,租了一辆可以载k个人的车,问到达到目的地的最短时间. cin: n,l,v1,v2,k. £:所有人一起到达终点的时候时间最短. £:所有人走路和坐车 ...

  8. 【转】Java 内部类种类及使用解析

    Java 内部类种类及使用解析 内部类Inner Class 将相关的类组织在一起,从而降低了命名空间的混乱. 一个内部类可以定义在另一个类里,可以定义在函数里,甚至可以作为一个表达式的一部分. Ja ...

  9. gameUnity 网络游戏框架

    常常在想,有没有好的方式,让开发变得简单,让团队合作更加容易. 于是,某一天 动手写一个 架构, 目前版本 暂定 0.1 版本.(unity5.0.0f4 版本以上) 我打算 开源出来 0.1有什么功 ...

  10. 2015年4月29日 dayofweek

    #include <stdio.h>#include <stdlib.h>int DayofYear(int year, int month, int day);#define ...