ADO.NET的几个对象

  • Connection:管理数据库的连接
  • Command:对数据库执行命令
  • DataReader:数据流读取器,返回的数据都是快速的且只是“向前”的数据流。无法实例化,只能通过Command创建
  • DateSet:缓存数据,对数据进行操作
  • DataAdapter:数据适配器,数据库和DataSet的桥梁

ADO.NET命名空间

注:图取自网络

常见的是SQL数据源

引用命名空间:

using System.Data.SqlClient;

一、Connection类

连接数据库,Connection会被Command对象使用,这样就能够知道是在哪个数据源上面执行命令。

Connection有两个重要属性:ConnectionString和State,连接字符串和连接状态

       两个重要方法:Open()和Close(),用来打开和关闭数据库连接

using (SqlConnection conn = newSqlConnection("DataSource(local);Integrated Security=SSPI;Initial Catalog=Northwind"))
{
conn.Open();
}

conn.State.ToString():当前连接状态,返回值为Closed 或Open

二、Command对象

Command有两个重要属性:CommandType, 指明CommandText 是SQL语句,存储过程还是表操作,默认值为CommandType.Text; 

                                                    两个值:(1)CommandType.StoredProcedure,以存储过程方式执行

                           (2)CommandType.Text SQL语句执行

                           (3)CommandType.TableDirect,直接处理某个表

               CommandText,值为SQL语句或是存储过程名称,默认为SQL语句

创建命令对象的两种方式

using (SqlConnection conn = newSqlConnection("DataSource(local);Integrated Security=SSPI;Initial Catalog=Northwind"))
{
conn.Open();
SqlCommand SqlCommand= conn .CreateCommand(); //这种方式比较好
SqlCommand.CommandText="select * from Student";
//或是实例化一个对象
//SqlCommand sqlcmd=new SqlCommand();
//sqlcmd.CommandText ="select * from student";
//sqlcmd.Connection=conn;
}

三个重要方法:

  • ExecuteReader():返回DataReader对象,DataReader对象说明详见下文
using (SqlConnection conn = newSqlConnection("DataSource(local);Integrated Security=SSPI;Initial Catalog=Northwind"))
{
SqlCommand command = conn.CreateCommand();
  command.CommandText = "Select * form Student";
   //CommandBehavior.CloseConnetion 关闭dataReader时,同时也把与它相关联的Connection连接也一起关闭
  using (SqlDataReader dr = command.ExecuteReader(CommandBehavior.CloseConnection))
  {
    while (dr.Read())
    {
      //开始读取数据了,接下来你想怎么样就怎么样了
      string str = dr.GetSqlString().ToString();
    }
  }
}
using (SqlConnection conn = newSqlConnection("DataSource(local);Integrated Security=SSPI;Initial Catalog=Northwind"))
{
SqlConnection conn = new SqlConnection(str); //创建连接
SqlCommand cmd = conn.CreateCommand(); //创建命令
cmd.CommandText = "SELECT * FROM Person"; //设置操作语句
conn.Open(); //打开连接
//SqlDataReader读取数据
using (SqlDataReader reader = cmd.ExecuteReader())
{
  while (reader.Read())
{
Console.WriteLine(reader[0] + ":" + reader[1]); //输出当前行的第一列,第二列数据
}
} cmd.CommandText = "SELECT Count(*) FROM Person";
object obj = cmd.ExecuteScalar(); //仅查询第一行第一列
Console.WriteLine((int)obj);
conn.Close(); //关闭连接 }
  • ExecuteScalar():返回数据第一行第一列的值,如Count(*),如果没有数据,则返回NULL
  • ExecuteNonQuery():返回增、删、改的影响行数
using (SqlConnection conn = newSqlConnection("DataSource(local);Integrated Security=SSPI;Initial Catalog=Northwind"))
{
SqlCommand cmd = conn.CreateCommand(); //创建命令
cmd.CommandText = "Update Person Set PersonName = 'Ado.net修改' WHERE PersonId = @Id"; //设置操作语句
cmd.Parameters.Add("@Id", SqlDbType.Int); //添加参数,说明类型
cmd.Parameters["@Id"].Value = ; //设置参数值
conn.Open(); //打开连接
int i = cmd.ExecuteNonQuery(); //执行命令,ExecuteNonQuery由名称看出,只能用于非查询语句
conn.Close(); //关闭连接
Console.WriteLine(i); //输出影响行数   //直接使用参数集合添加你需要的参数,推荐这种写法
  //SqlParameter[] parameters = new SqlParameter[]
  //{
    //new SqlParameter("@name",SqlDbType.NVarChar,100){Value = "yang"},
    //new SqlParameter("@age",SqlDbType.Int,2){Value = 888},
    //new SqlParameter("@address",SqlDbType.NVarChar,20){Value = "Jiang Su"}, 
  //};
  //ommand.Parameters.AddRange(parameters);
}

三、DataReader类

常见方法:

(1)Read()返回Bool,是否还有下一行,并移到结果集的下一行

(2)GetOrdinal(string 列名),返回序列号,通过列名来获取当前列的索引号,这样如果下次你列名顺序发生变化也没有关系

(3)GetName(int 序列号):  获取列名,参数为指定列名的序列号,返回string

int nameId= dr.GetOrdinal("name");
string columnName = dr.GetName(nameId);
//知道列名获取值
using (SqlDataReader reader = cmd.ExecuteReader())
{
  while (reader.Read())
{
   Console.WriteLine(reader.GetString(sdr.GetOrdinal("
name")));
   } 
}

(4)NextResult(),当查询为批处理查询时,使用这个方法去读取下一个结果集,返回值为Bool,如果存在多个结果集,则为 true;否则为 false

using (SqlConnection conn = new SqlConnection(strConnString))
{
   conn.Open();
   using (SqlCommand cmd = new SqlCommand())
   {
     cmd.Connection = conn;
     // 利用分号「;」串连多句 SQL 语句,之后再一次丢进数据库去执行,达成「批次」读取或更新
     // 数据库的目的。此技巧亦适用于 INSERT、UPDATE、DELETE 的「批次」执行。
     cmd.CommandText = "SELECT 字段1,字段2 FROM 数据表1 ; SELECT * FROM 数据表2";
     using (SqlDataReader dr = cmd.ExecuteReader())
     {
       while(dr.Read())
       {
         this.DropDownList1.Items.Add(dr.GetSqlString().ToString() + dr.GetSqlInt32().ToString());
       }
    dr.NextResult();
     while(dr.Read())
    {
         this.DropDownList2.Items.Add(dr.GetString() + dr.GetInt32());
      }
    }
  }
}

四、SqlDataAdapter 数据适配器

有四个重载

无参
SqlDataAdapter(SqlCommand)        // 执行命令对象实例
SqlDataAdapter(String, SqlConnection) //只能指定查询语句 ②连接对象实例
SqlDataAdapter(String, ConnectionString)// 用 SelectCommand 和一个连接字符串初始化 SqlDataAdapter 类的一个新实例

一个重要方法:Fill(),数据填充至DataSet

using (SqlConnection conn = newSqlConnection("DataSource(local);Integrated Security=SSPI;Initial Catalog=Northwind"))
{
  DataSet dataSet = new DataSet();
conn.Open();
SqlCommand command = conn.CreateCommand();
command.CommandText = "select name,age,address from MyInformation";
SqlDataAdapter dataAdapter = new SqlDataAdapter(command);
dataAdapter.Fill(dataSet); //填充数据
}

对数据进行增加操作

using (SqlConnection conn = newSqlConnection("DataSource(local);Integrated Security=SSPI;Initial Catalog=Northwind"))
{
using (SqlConnection conn = new SqlConnection(ConnectionString()))
{
conn.Open();
//构建查询语句,也可以指定SqlCommand,其中变换的方法有很多
SqlDataAdapter da = new SqlDataAdapter("select LastName,FirstName from dbo.Employees", conn);
DataSet ds = new DataSet();
da.Fill(ds);
//这句话很重要,它会把你在DataSet增加的数据转化为SQL语句用来更新数据库
SqlCommandBuilder cmdBuilder = new SqlCommandBuilder(da);
//添加行,实例化一个行对象,注意是用NewRow来创建行
DataRow row = ds.Tables[].NewRow();
row[] = "Yang";
row[] = "鬼头";
ds.Tables[].Rows.Add(row); //添加到表中
da.Update(ds); //把DataSet中表和数据库进行对比,更新
}
}

更新操作

using (SqlConnection conn = newSqlConnection("DataSource(local);Integrated Security=SSPI;Initial Catalog=Northwind"))
{
using (SqlConnection conn = new SqlConnection(""))
{
SqlDataAdapter da = new SqlDataAdapter("SQL语句或你自己定义的命令对象", conn);
DataSet ds = new DataSet();
da.Fill(ds);
//很重要的一句话
SqlCommandBuilder cmdBuilder = new SqlCommandBuilder(da);
ds.Tables[].Rows[][] = ""; //修改数据
da.Update(ds);
//调用Update方法其中隐式的调用了AcceptChanges方法,更新数据集中的数据
//如果你继续使用这个数据集而没有调用这个方法,在后面的使用会出现异常
ds.AcceptChanges(); //这句话可以不写的
}
}

最后

对于一些增删改,都应加上事务,防止出错能回滚数据

using (SqlConnection conn = newSqlConnection("DataSource(local);Integrated Security=SSPI;Initial Catalog=Northwind"))
{ //事务
SqlTransaction myTran = con.BeginTransaction();
tyr
{
//正常代码执行
..............
//提交事务
myTran.Commit();
}
catch(Exception e)
{
//出错,事务回滚
myTran.Rollback();
}
}

ADO.NET的学习的更多相关文章

  1. ado.net EF学习系列----深入理解查询延迟加载技术(转载)

    ado.net EF是微软的一个ORM框架,使用过EF的同学都知道EF有一个延迟加载的技术. 如果你是一个老鸟,你可能了解一些,如果下面的学习过程中哪些方面讲解的不对,欢迎批评指教.如果一个菜鸟,那我 ...

  2. ADO.net基础学习总结(二)

    将连接字符串放入配置文件中 1.添加一个“应用程序配置文件:app.config” <?xml version="1.0" encoding="utf-8" ...

  3. ADO.net基础学习总结

    ADO.net是一门.net连接.操作数据库的技术   释放资源:凡是实现了idisposable借口的类都需要用using来释放资源 using() { } 连接数据库 //创建数据库连接: usi ...

  4. ADO.NET初学习

    ①System.Data  → DataTable,DataSet,DataRow,DataColumn,DataRelation,Constraint,DataColumnMapping,DataT ...

  5. ADO。net学习笔记

    来源于网络 1.       SqlConnection(DBConnection)  建立程序与数据库的链接 链接字符串有两种形式: //使用Windows验证  SSPI(安全支持提供程序接口) ...

  6. ADO.NET 基础学习笔记1

    1. ODBC.OLEDB.ADO.ADO.NET之间的关系 ODBC: 开放数据库互连(ODBC)是MICROSOFT提出的数据库访问接口标准.ODBC(Open DatabaseConnectiv ...

  7. ADO.NET知识学习总结

      1. 概述 使用的命名空间: System.Data.SqlClient 连接字符串    服务器/数据库实例+数据库名称+安全信息+用户名+密码  可参考http://www.connectio ...

  8. ADO.NET详细学习笔记《一》

    目录 ADO.NET和ADO的区别 ADO.NET的五大核心对象 Connection对象 Command对象 DataAdapter对象,DataSet对象 DataReader对象 [1]ADO. ...

  9. ADO.NET基础学习 二(Command对象)

    ②command对象用来操作数据库.(三个重要的方法:ExecuteNonQuery(),ExecuteReader(),ExecuteScalar()) ⑴以update(改数据)为例,用到Exec ...

随机推荐

  1. [译] 所有你需要知道的关于完全理解 Node.js 事件循环及其度量

    原文地址:All you need to know to really understand the Node.js Event Loop and its Metrics 原文作者:Daniel Kh ...

  2. 图解虚数 - A Visual, Intuitive Gudie to Imaginary Numbers

    这是一篇发表在 betterexplained 上的文章.它通过类比.图解的方式简明地介绍了虚数的意义. 作者:Kalid 原文:A Visual, Intuitive Gudie to Imagin ...

  3. oracle数据库中的四种循环

    [sql]  DECLARE  x number;  BEGIN  x:=9;  <<repeat_loop>>  --循环点  x:=x-1;  DBMS_OUTPUT.PU ...

  4. PAT (Basic Level) Practise (中文) 1017. A除以B (20)

    1017. A除以B (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 本题要求计算A/B,其中A是不超过 ...

  5. hexdump命令的使用

    hexdump命令是Linux下的打印16进制的利器,它可以按我们指定的格式输出16进制,特别有用,配合eeprom来用简直是绝配. 今天我们来介绍一个hexdump命令的使用: 首先我们准备一个测试 ...

  6. netstat命令---输出网络相关的信息

    简介 Netstat 命令用于显示各种网络相关信息,如网络连接,路由表,接口状态 (Interface Statistics),masquerade 连接,多播成员 (Multicast Member ...

  7. dfs+剪枝:poj2362

    贴题目 Square Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 24604   Accepted: 8449 Descr ...

  8. java程序给short变量赋0xff报异常

    在java程序中以二进制或十六进制表示的数比如0x01默认类型为int.所以付给short类型时要强制类型转换. short q = (short) 0b1111111111111111; Syste ...

  9. HTML基础进阶

    [toc] HTML表单 form标签 <form> 标签代表一个表单,表单用于向服务器传输数据. 标签能够包含 <input> ,可以是文本字段,复选框,单选框或提交按钮等. ...

  10. JVM内存概览与GC初步

    一.JVM内存空间概览 Java虚拟机使用的内存块包含 栈空间Stack (虚拟机栈.本地方法栈).堆空间 Heap Memory .永久区 Perm Gen(related to method ar ...