前言:这节课老师请高级班的E老师过来代课,还是接着老师讲的内容继续深入,修改了上节课老师写的部分代码。

内容:

  1.数据库本质就是一个软件,这个软件帮助我们把数据有序地存储起来,当我们需要数据的时候帮我们快速地把数据找到。程序要和数据库进行交互,需要一些连接的纽带,需要数据库开一个门给我们,我们才能拿到东西,这一功能主要依靠ADO.NET来实现。

  2.数据库的操作主要分为“增删改查”,简记为:CRUD(Create,Read,Update,Delete)。

  3.连接字符串:web.config里面配置:

 <connectionStrings>
<add name="Student" connectionString="Database=Student;Server=.;Integrated Security=false;Uid=sa;Password=123;" providerName="System.Data.SqlClient"/>
</connectionStrings>

  其中的name和database后的名字最好相同。

  4.Connection对象:

 SqlConnection connection = new SqlConnection(connectionStringBuilder.ToString());//创建对象
2 connection.Open();//打开连接
3 connection.Close();//关闭连接
4 connection.Dispose();//释放资源

  当然,也可以使用using()来释放资源:using()内的对象必须是继承自IDisposable接口的。

 using (SqlDataReader reader = cmd.ExecuteReader())
{
if (reader.Read())
{
Response.Write("<script>alert('登录成功')</script>");
}
else
{
Response.Write("<script>alert('用户名或者密码错误')</script>");
}
}

  5.Command对象:

 ExecuteNonQuery: 执行增删改语句,返回值为该命令所影响的行数。
ExecuteReader: 执行查询,并返回一个 DataReader 对象。
ExecuteScalar: 执行查询, 返回查询数。
例:
SqlDataReader reader = cmd.ExecuteReader();//执行ExecuteReader while (read.Read())
{
Response.Write(read[].ToString());
}

  6.参数化:

 string strSql = "DELETE FROM RNews WHERE  NewsId=@NewsId;";
using (con = new SqlConnection(strCon))
{
con.Open();
cmd = new SqlCommand(strSql, con);
cmd.Parameters.Add(new SqlParameter("@NewsId", newsId));
cmd.ExecuteNonQuery();
}

  这种参数化的形式可以防注入,并且有利于数据库的查询计划,加快查询速度。

  7.DataAdapter:它为外部数据源与本地DataSet集合架起了一座坚实的桥梁,将从外部数据源检测到的数据合理正确地调配到本地的DataSet集合中。

  其属性和方法如下:

  • SelectComand属性:获取或设置用于在数据源选择记录的命令。
  • UpdateCommand属性:获取或这只用于更新数据源中的记录的命令。
  • DeleteCommand属性:获取或设置用于从数据源中删除记录的命令。
  • InsertCommand属性:获取或设置用于将新记录插入数据源中的命令。
  • Fill方法:填充数据集。
  • Update方法:更新数据源。
 DataSet ds = new DataSet();
con = new SqlConnection(connStr);
string sql = "select BookId,Title,Author,Press,price from Books";
using (cmd = new SqlCommand(sql, con))
{
SqlDataAdapter sda = new SqlDataAdapter(cmd);
sda.Fill(ds,"TabBooks");
GridView1.DataSource = ds.Tables["TabBooks"];
GridView1.DataBind();
}

  调用存储过程:

 DataSet ds = new DataSet();
SqlDataAdapter da = new SqlDataAdapter("GetAllUsers", "server=(local);database=DemoDB;Integrated Security=true;");
da.SelectCommand.CommandType = CommandType.StoredProcedure;
da.Fill(ds);
this.dataGridView1.DataSource = ds.Tables[];
  DataSet,DataTable,DataReader,DataAdapter区别:
  (1)DataSet是用来做连接sql的一种方法,意思是把数据库的副本存在应用程序里,相当于存在内存中的数据库,应用程序开始运行时,把数据库相关数据保存到DataSet。
  (2)DataTable表示内存中数据的一个表。常和DefaultView使用获取可能包括筛选视图或游标位置的表的自定义视图。
  (3)DataReader对象是用来读取数据库的最简单方式,它只能读取,不能写入,并且是从头至尾往下读的,无法只读某条数据,但它占用内存小,速度快。  
  (4)DataAdapter对象是用来读取数据库。可读取写入数据,某条数据超着强,但它占用内存比dataReader大,速度慢,一般和DataSet连用。
  (5)Dataset表示一个数据集,是数据在内存中的缓存。 可以包括多个表,DataSet 连接数据库时是非面向连接的。把表全部读到Sql中的缓冲池,并断开于数据库的连接,DataReader 连接数据库时是面向连接的。读表时,只能向前读取,读完数据后由用户决定是否断开连接。
  8.SQL注入:利用了写SQL语句时的不小心而使程序受到攻击。要防止注入,需要注意:检查用户输入的信息,是否含有分号啊,引号之类的;还有一种方式就是使用参数化查询方式:
 StringBuilder strSQL = new StringBuilder();
strSQL.Append("Update tb_SelCustomer Set ");
strSQL.Append(“Phone = @Phone”);
strSQL.Append("where Name = @Name");
using (SqlConnection conn = new SqlConnection(connStr.ConnectionString))
{
SqlCommand cmd = new SqlCommand(strSQL.ToString(), conn);
//构造Parameter对象
SqlParameter[] paras = new SqlParameter[]{new SqlParameter("@Phone",SqlDbType.VarChar, ), new SqlParameter("@Name", SqlDbType.VarChar, ) };
//给Parater对象赋值
paras[].Value = "";
paras[].Value = "测试客户1";
//遍历添加到Parameters集合中
foreach (var item in paras)
{
cmd.Parameters.Add(item);
}
try
{
conn.Open();
cmd.ExecuteNonQuery();
Console.WriteLine("Update Success...");
}
catch (Exception ex)
{
Console.WriteLine("{0}", ex.Message);
}
}

后记:内容有点多,得仔细消化一下。

ASP.NET动态网站制作(23)-- ADO.NET(2)的更多相关文章

  1. ASP.NET动态网站制作(3)--css(2)

    前言:css分为四次课讲完,第一节课内容见ASP.NET动态网站制作(2)--css(1),接下来的内容会涉及到定位.浮动.盒子模型(第二次课).css的具体应用(第三次课).css3(第四次课).今 ...

  2. ASP.NET动态网站制作(24)-- ADO.NET(3)

    前言:ADO.NET的第三节课.今天主要讲SQL Helper. 内容: 1.DataReader和DataSet的区别: (1)DataReader是一行一行地读,且只能向前读:DataSet是一次 ...

  3. ASP.NET动态网站制作(22)-- ADO.NET(1)

    前言:这节课开始真正地学习WEB开发,ADO.NET就是一组允许.NET开发人员使用标准的.机构化的,甚至无连接的方式与数据交互的技术.所属的类库为:System.Data.dll. 内容: 1.AD ...

  4. ASP.NET动态网站制作(25)-- ADO.NET(4)

    前言:这节课老师主要讲网页当中内容的分页效果,自己写一个分页控件. 内容: 1.首先写出HTML代码: <div id="pager"> <%=GetPagerH ...

  5. ASP.NET动态网站制作(26)-- Ajax

    前言:这节课讲解关于Ajax的相关内容. 内容: 1.当点击页面中的一个按钮提交数据或请求数据的时候,整个页面的信息都会提交(不管信息是否是提交或者请求的数据,页面中所有的数据都提交),这样耗用的时间 ...

  6. ASP.NET动态网站制作(20)-- C#(3)

    前言:C#的第三节课,继续上次课的内容,依旧围绕基础的只是讲解. 内容: 1.StringBuilder类:由于string类一旦创建,则不能更改.如果做字符串拼凑的话,将会非常耗费空间,如: str ...

  7. ASP.NET动态网站制作(1)--html

    前言:正式上课的第一课,讲的是前端部分的最基础内容:html. 前端:html,css,js 数据库:sql server 动态部分:.net,c#... IIS(Internet Informati ...

  8. ASP.NET动态网站制作(0)

    前言:一直想系统地学习一下网站建设的相关内容,看过相关的书籍,也跟着视频学过,但总觉得效率不高,学过的东西印象不深刻,或许还是自己动手实践的少.无意中免费听了一堂讲ASP.NET网站建设的课,觉得性价 ...

  9. ASP.NET动态网站制作(28)-- 三层框架(2)

    前言:三层框架的第二节课,继续上次课的内容. 内容: 1.三层框架的使用目的:可以将视图层和业务逻辑层及实体层分开,可以提高代码的扩展性,安全性,可以实现程序的低耦合性. 2.GetModel方法及G ...

随机推荐

  1. 初识交替最小二乘ALS

    ALS是alternating least squares的缩写 , 意为交替最小二乘法:而ALS-WR是alternating-least-squares with weighted-λ -regu ...

  2. 一篇文章让你彻底弄懂WinForm GDI 编程基本原理

    一 GDI编程原理 GDI(Graphics Device Interface,图形设备接口),主要负责Windows系统与绘图程序之间的信息交换,处理所有Windows程序的图形输出. GDI的常用 ...

  3. Delphi CRC算法, 不错

    http://www.cnblogs.com/tangqs/archive/2011/12/08/2280255.html

  4. tiny4412 串口驱动分析七 --- log打印的几个阶段之内核启动阶段(earlyprintk)

    作者:彭东林 邮箱:pengdonglin137@163.com 开发板:tiny4412ADK+S700 4GB Flash 主机:Wind7 64位 虚拟机:Vmware+Ubuntu12_04 ...

  5. 为何Redis要比Memcached好用

    Redis是新兴的通用存储系统,而Memcached仍有其适用领域 Memcached还是Redis? 在现代高性能Web应用中这一直是个争论不休的话题. 在基于关系型数据库的Web应用需要提高性能时 ...

  6. Python 最火 IDE 最受欢迎(转载)

    来自:开源中国社区 链接:https://www.oschina.net/news/86973/packt-skill-up-2017 电子书网站 Packt 刚刚发布了第三届 “Skill UP” ...

  7. 初识Nginx及编译安装Nginx

    初识Nginx及编译安装Nginx 环境说明: 系统版本    CentOS 6.9 x86_64 软件版本    nginx-1.12.2 1.什么是Nginx? 如果你听说或使用过Apache软件 ...

  8. php合并两个二维数组

    <?php $array1=array(1, 2);//数组1 $array2=array(2, 3);//数组2 $array3=array_merge($array1, $array2);/ ...

  9. Linux学习笔记 (二)常用linux命令

    一.命令行语法: 命令字 [选项] [参数] 注意:Linux中对命令是区分大小写的. 二.获取命令帮助: 1.help命令:help xxx,shell内部指令,用来获取linux内部命令.例如:h ...

  10. nonlocal(非局部变量)---python 3.x 新增关健词

    Python里只有2种作用域:全局作用域和局部作用域.全局作用域是指当前代码所在模块的作用域,局部作用域是指当前函数或方法所在的作用域.其实准确来说,Python 3.x引入了nonlocal关键字, ...