华域联盟 .Net ADO.NET无连接模式的详细介绍

ADO.NET无连接模式的详细介绍

无连接模式:可以在没有打开连接时在内存中操作数据,DataAdapter通过管理连接为无连接模式提供服务,当要从数据库中查询数据时,DataAdapter打开一个连接,填充指定的DataSet,等数据读取完马上自动关闭连接,然后可以对数据做修改,再次使用DataAdapter打开连接,持久化修改(无论是更新,删除或是更新),最后自动关闭连接,使用无连接模式的情况是有一些独立数据,它们不会发生改变或者很少改变,因为在将填充DataSet和更新数据这段时间内数据库中的实际数据也许会发生改变,如果需要将数据立即持久化到数据库请使用连接模式

读取数据到DataSet:无连接意味着一个连接建立了一个与数据库的会话,请求的数据读入到DataSet中,然后通过断开数据库的连接关闭会话,这时会话因为与数据库的断开而关闭,DataSet成为一个无连接的数据库

复制代码 代码如下:

/// <summary>

      /// 查询学生信息

      /// </summary>

      /// <returns>返回填充了学生表的DataSet</returns>

      public DataSet GetUserInfor()

      {

          string str = "Data Source=.;Initial Catalog=Student;Integrated Security=True";

          var conn = new SqlConnection(str);

          DataSet ds = new DataSet();

          var sda = new SqlDataAdapter("SELECT * FROM Student",conn);

          sda.Fill(ds, "student");//调用fill方法时,SqlDataAdapter会自动打开连接,读取数据然后关闭连接

          foreach (DataRow dr in ds.Tables["student"].Rows)

          {

              Console.WriteLine(dr["name"]);

          }

          return ds;

      }

将DataSet的修改保存到数据库
插入数据

复制代码 代码如下:

/// <summary>

      /// 插入学生信息,并返回插入后的DataSet

      /// </summary>

      /// <param name="stu">学生实体类</param>

      public DataSet InsertStudnt(Student stu)

      {

          DataSet ds = GetUserInfor();

          string str = "Data Source=.;Initial Catalog=Student;Integrated Security=True";

          string sql = "INSERT INTO student VALUES (@name,@age)";

          var conn = new SqlConnection(str);

          var cmd = new SqlCommand(sql,conn);

          var sda = new SqlDataAdapter();

          SqlParameter sqlParam1 = new SqlParameter()

          {

              ParameterName = "@name",

              SourceColumn = "name"

          };

          SqlParameter sqlParam2 = new SqlParameter()

          {

              ParameterName = "@age",

              SourceColumn = "age"

          };

          SqlParameter[] sqlParamArray = new SqlParameter[] {sqlParam1,sqlParam2 };

          cmd.Parameters.AddRange(sqlParamArray);

          sda.InsertCommand = cmd;

          DataRow dr = ds.Tables["student"].NewRow();

          dr["name"] = stu.name;

          dr["age"] = stu.age;

          ds.Tables["student"].Rows.Add(dr);

          sda.Update(ds,"student");

          return ds;

      }

更新数据

复制代码 代码如下:

/// <summary>

      /// 根据ID更新姓名和年龄

      /// </summary>

      /// <param name="name">姓名</param>

      /// <param name="age">年龄</param>

      /// <param name="id">学生ID</param>

      /// <returns>返回更新后的DataSet</returns>

      public DataSet UpdateStudent(Student stu,int id)

      {

          DataSet ds = GetUserInfor();

          string str = "Data Source=.;Initial Catalog=Student;Integrated Security=True";

          string sql = "UPDATE student SET name=@name,age=@age WHERE id=@id";

          var conn = new SqlConnection(str);

          var cmd = new SqlCommand(sql, conn);

          var sda = new SqlDataAdapter();

          SqlParameter param1 = new SqlParameter()

          {

              ParameterName="@name",SourceColumn="name"

          };

          SqlParameter param2 = new SqlParameter()

          {

              ParameterName = "@age",

              SourceColumn = "age",

              SqlDbType=SqlDbType.Int

          };

          SqlParameter param3 = new SqlParameter()

          {

              ParameterName = "@id",

              SourceColumn = "id"

          };

          SqlParameter[] param = new SqlParameter[] {param1,param2,param3 };

          cmd.Parameters.AddRange(param);

          sda.UpdateCommand = cmd;

          DataTable dt = ds.Tables["student"];

          foreach (DataRow dr in dt.Rows)

          {

              int oldID=Convert.ToInt32(dr["id"]);

              if (oldID == id)

              {

                  dr["name"] = stu.name;

                  dr["age"] = stu.age;

              }

          }

          sda.Update(ds,"student");

          return ds;

      }

删除数据

复制代码 代码如下:

/// <summary>

      /// 根据ID删除一个学生

      /// </summary>

      /// <param name="id">返回更新后的DataSet</param>

      public DataSet DeleteStudent(int id)

      {

          DataSet ds = GetUserInfor();

          string str = "Data Source=.;Initial Catalog=Student;Integrated Security=True";

          string sql = "DELETE FROM student WHERE id=@id";

          var conn = new SqlConnection(str);

          var cmd = new SqlCommand(sql, conn);

          var sda = new SqlDataAdapter();

          SqlParameter param = new SqlParameter()

          {

              ParameterName="@id",SourceColumn="id",SqlDbType=SqlDbType.Int

          };

          cmd.Parameters.Add(param);

          sda.DeleteCommand = cmd;

          DataTable dt=ds.Tables["student"];

          foreach (DataRow dr in dt.Rows)

          {

              int oldId = Convert.ToInt32(dr["id"]);

              if (oldId == id)

                  dr.Delete();

          }

          sda.Update(ds,"student");

          return ds;

      }

本文由 华域联盟 原创撰写:华域联盟 » ADO.NET无连接模式的详细介绍

转载请保留出处和原文链接:https://www.cnhackhy.com/52010.htm

本文来自网络,不代表华域联盟立场,转载请注明出处。

作者: sterben

发表回复

联系我们

联系我们

2551209778

在线咨询: QQ交谈

邮箱: [email protected]

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部