来源于网络

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. 初识mongo

    进入mongo /usr/local/mongodb/bin/mongo --host 查看所有db show dbs 查看当前进入的db db 查看当前db的所有collection show co ...

  2. 自定义AccessDeniedHandler

    在Spring默认的AccessDeniedHandler中只有对页面请求的处理,而没有对Ajax的处理.而在项目开发是Ajax又是我们要常用的技术,所以我们可以通过自定义AccessDeniedHa ...

  3. htop安装步骤【原创】

    htop安装步骤 下载:http://hisham.hm/htop/releases/ [root@hchtest2 ~]# tar zxvf htop-2.0.2.tar.gz [root@hcht ...

  4. jquery滚动条加载数据

    //滚动条  $(window).scroll(function () {   var scrollTop = $(this).scrollTop();   var scrollHeight = $( ...

  5. 控制器view的加载顺序initWithNibName >>> viewDidLoad >>> viewWillAppear >>> viewDidAppear

    -(void)viewWillAppear:(BOOL)animated { self.navigationController.navigationBarHidden=NO;// 邓超界:放在wil ...

  6. linux expr命令参数及用法详解

    expr用法 expr命令一般用于整数值,但也可用于字符串.一般格式为: #expr argument operator argument expr也是一个手工命令行计数器. #$expr 10 + ...

  7. Java 中的四种引用及垃圾回收策略

    Java 中有四种引用:强引用.软引用.弱引用.虚引用: 其主要区别在于垃圾回收时是否进行回收: 1.强引用 使用最普遍的引用.如果一个对象具有强引用,那就 类似于必不可少的生活用品,垃圾回收器绝不会 ...

  8. SDWebImage的总结

    SDWebImage 1> 图片文件缓存的时间有多长:1周 _maxCacheAge = kDefaultCacheMaxCacheAge 2> SDWebImage 的内存缓存是用什么实 ...

  9. wpf中ListBox的选中项与ComboBox间的绑定

    产品类: public class Product:NotificationObject { private int productID; public int ProductID { get { r ...

  10. calc()使用笔记

    calc()可以给元素做运算, calc(expression) eg: .a { width: -webkit-calc(100% - 2px); width: -moz-calc(100% - 2 ...