ADO。net学习笔记
来源于网络
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学习笔记的更多相关文章
- ADO.NET 学习笔记 入门教程
本文转载自:http://www.youarebug.com/forum.php?mod=viewthread&tid=57&page=1&extra=#pid63 这是本人在 ...
- ADO.NET学习笔记(1)
ADO.Net是.Net框架中为数据库的访问而封装的一个库.通过这个库我们可以简单便捷的访问数据库,并对数据库进行一些增删改查的操作,目前ADO.Net支持四种主流的数据库,分别是SQL.OLE DB ...
- C#-ado.net学习笔记-会有更新
ado.net 通用类对象.在本地内存暂存数据 托管类对象.让本地通用类对象连接数据库,让本地通用类对象和数据库同步 连接数据库 new connection(connectstring) comma ...
- Sql Ado.net 学习笔记之连接字符串
https://www.cnblogs.com/heng95/p/5902019.html 连接字符串 SQL Client .net数据提供程序在连接到数据库时极其灵活,它提供了多种用以生成连接字符 ...
- ADO.NET Entity Framework学习笔记(3)ObjectContext
ADO.NET Entity Framework学习笔记(3)ObjectContext对象[转] 说明 ObjectContext提供了管理数据的功能 Context操作数据 AddObject ...
- ADO学习笔记之注入漏洞与参数化查询
ADO学习笔记之注入漏洞与参数化查询 作为新手,在学习ADO程序时,使用 sql 语言查询数据时,很容易写类似如下代码: using (SqlConnection con = new SqlConne ...
- Entity Framework学习笔记——错误汇总
之前的小项目做完了,到了总结经验和更新学习笔记的时间了.开始正题之前先啰嗦一下,对之前的学习目标进行一个调整:“根据代码生成表”与“生成数据库脚本和变更脚本”合并为“Code First模式日常使用篇 ...
- AJax 学习笔记二(onreadystatechange的作用)
AJax 学习笔记二(onreadystatechange的作用) 当发送一个请求后,客户端无法确定什么时候会完成这个请求,所以需要用事件机制来捕获请求的状态XMLHttpRequest对象提供了on ...
- CUBRID学习笔记 3 net连接数据库并使用cubrid教程示例
接上文 数据库安装好后,也可以测试语句了. 下面我们用c#写一个控制台程序,连接数据库,并读取数据. 一 下载驱动 net版的下 CUBRID ADO.NET Data Provider 9.3.0 ...
- Entity Framework学习笔记
原文地址:http://www.cnblogs.com/frankofgdc/p/3600090.html Entity Framework学习笔记——错误汇总 之前的小项目做完了,到了总结经验和 ...
随机推荐
- Linux raid信息 查看
Linux下查看软.硬raid信息的方法. 软件raid:只能通过Linux系统本身来查看 cat /proc/mdstat 可以看到raid级别,状态等信息. 硬件raid: 最佳的办法是通过已安装 ...
- 使用PLSQL Developer连接Oracle Database 11g Express Edition
要使用oracle数据库,需要准备三部分: 1.oracle服务端 2.oracle客户端 3.连接工具 你装的Oracle Database 11g Express Edition就是服务端,pls ...
- shell中 if else以及大于、小于、等于逻辑表达式介绍
比如比较字符串.判断文件是否存在及是否可读等,通常用"[]"来表示条件测试. 注意:这里的空格很重要.要确保方括号的空格.笔者就曾因为空格缺少或位置不对,而浪费好多宝贵的时间. i ...
- drupal7为admin/config页面添加自己开发的模块
1.实现显示模块 //admin/config配置页面添加journal块 $items['admin/config/journal'] = array(//注意格式为'admin/config/模块 ...
- opatch auto in windows db in 11.2.0.4
--prapare:copy 192.168.63.83 D:\oracle_patch\1612 to 192.168.2.169 D:\oracle_patch\1612cd D:\oracle_ ...
- 获取Excel部分数据并很据项目要求计算适宜性等级综合指数判断该地区的土壤适宜性
代码运行前请先导入jxl架包,以下代码仅供学习参考: 下图为项目中的Excel: ExcelTest02类代码如下: // 读取Excel的类 import java.io.BufferedWrite ...
- HDU 4685 Prince and Princess(二分匹配+强联通分量)
题意:婚配问题,但是题目并不要求输出最大匹配值,而是让我们输出,一个王子可以与哪些王妃婚配而不影响最大匹配值. 解决办法:先求一次最大匹配,如果有两个已经匹配的王妃,喜欢她们两个的有两个或者以上相同的 ...
- 获取spring bean的utils
<span style="font-size:10px;">package com.record.util; import org.springframework.be ...
- Python基础学习1---函数
Python函数篇 函数是重用的程序选, 他们允许给一块语句一个名称,然后可以在你的程序的任何地方是使用这个名称任意多次地运行这个语句块.这个就被称为 调用 函数.比如内建了很多高效的函数 如len ...
- CSS3简介
选择器 盒模型 背景和边框 文字特效 2d/3d转换 动画 多列布局 用户界面