ADO.NET五大对象增删改查使用
string ConnStr = "Data Source=.;Initial Catalog=ADO_DEMO;Integrated Security=True"; #region SqlConnection使用
//第一步:新建SqlConnection对象
SqlConnection SqlConn = new SqlConnection(); //设置SqlConnection对象的连接字符串;
SqlConn.ConnectionString = ConnStr; //如果用DataSet或者DataTable,可以不用打开数据库,否则必须打开数据库
SqlConn.Open();
#endregion #region SqlCommand对象的增、删、改操作
//新建SqlCommand对象
SqlCommand cmd = new SqlCommand(); //设置SqlCommand对象的Connection属性,即:SqlConn(SqlConnection类型的对象)
cmd.Connection = SqlConn; //如果是执行INSERT/UPDATE/DELETE的SQL语句,可以直接设置CommandText属性
//如果是执行存储过程,则必须设置CommandType属性为CommandType.StoredProcedure
cmd.CommandText = "INSERT INTO Ex_Class VALUES('1707A',19)"; //设置完Connection属性及CommandText属性后可以直接执行SQL语句
//cmd.ExecuteNonQuery(); //执行完成后要关闭数据库,并且释放资源
SqlConn.Close();
SqlConn.Dispose();
#endregion #region 利用SqlCommand对象和SqlDataReader对象获取数据(记录集)
//判断如果连接没有打开,是关闭状态,就打开数据库
if(SqlConn.State == ConnectionState.Closed)
{
SqlConn.ConnectionString = ConnStr;
SqlConn.Open();
} //新建SqlCommand对象
SqlCommand cmd_select = new SqlCommand(); //设置SqlCommand对象的Connection属性,即:SqlConn(SqlConnection类型的对象)
cmd_select.Connection = SqlConn; //如果是执行INSERT/UPDATE/DELETE的SQL语句,可以直接设置CommandText属性
//如果是执行存储过程,则必须设置CommandType属性为CommandType.StoredProcedure
cmd_select.CommandText = "SELECT * FROM Ex_Class"; //调用ExecuteReader方法并用SqlDataReader对象接收返回的记录;
SqlDataReader sdr = cmd_select.ExecuteReader(); //如果SqlDataReader返回的只有一条记录,可以用下面的方法来获取;
if(sdr.Read())
{
string ClassName = sdr["ClassName"].ToString();
int ClassCount = Convert.ToInt32(sdr["ClassCount"]); Response.Write(string.Format("SqlDataReader返回一条记录:ClassName:{0} ClassCount:{1}<br><br>", ClassName, ClassCount));
} //如果SqlDataReader返回的是多条记录,可以用下面的方法来获取记录,并存储集合
List<Model> DataList = new List<Model>();
while(sdr.Read())
{
Model m = new Model();
m.ClassName = sdr["ClassName"].ToString();
m.ClassCount = Convert.ToInt32(sdr["ClassCount"]);
DataList.Add(m);
} //然后可以使用集合中的数据,比如:
foreach(var p in DataList)
{
Response.Write(string.Format("SqlDataReader返回多条记录:ClassName:{0} ClassCount:{1}<br><br>", p.ClassName, p.ClassCount));
} //注意SqlDataReader使用完后要关闭和释放资料
sdr.Close();
sdr.Dispose();
SqlConn.Close();
SqlConn.Dispose();
#endregion #region 利用DataTable对象获取数据(记录集)
/*注意:如果DataTable获取记录,不用打开数据库,即Open()*/ SqlConn.ConnectionString = ConnStr; //新建SqlCommand对象
SqlCommand cmd_datatable = new SqlCommand(); //设置SqlCommand对象的Connection属性,即:SqlConn(SqlConnection类型的对象)
cmd_datatable.Connection = SqlConn; //如果是执行INSERT/UPDATE/DELETE的SQL语句,可以直接设置CommandText属性
//如果是执行存储过程,则必须设置CommandType属性为CommandType.StoredProcedure
cmd_datatable.CommandText = "SELECT * FROM Ex_Class"; //新建一个SqlDataAdapter对象,用来向DataTable填充数据
SqlDataAdapter sda = new SqlDataAdapter(); //设置SqlDataAdapter对象对应的SqlCommand对象
sda.SelectCommand = cmd_datatable; //新建一个DataTable对象,用来接收SqlDataAdapter对象传递过来的数据
DataTable dt = new DataTable(); //调用SqlDataAdapter对象的Fill方法,将数据填充到DataTable
sda.Fill(dt); //接下来可以使用DataTable中的数据,比如获取第一行的值:
string MyClassName = Convert.ToString(dt.Rows[]["ClassName"]);
int MyClassCount = Convert.ToInt32(dt.Rows[]["ClassCount"]); Response.Write(string.Format("DataTable返回一条记录:ClassName:{0} ClassCount:{1}<br><br>", MyClassName, MyClassCount)); //也可以使用foreach遍历DataTable中的数据
List<Model> DList = new List<Model>();
foreach(DataRow dr in dt.Rows)
{
Model Obj = new Model();
Obj.ClassName = Convert.ToString(dr["ClassName"]);
Obj.ClassCount = Convert.ToInt32(dr["ClassCount"]);
DList.Add(Obj); //或者直接输出值
Response.Write(string.Format("DataTable返回多条记录:ClassName:{0} ClassCount:{1}<br><br>", dr["ClassName"], dr["ClassCount"]));
} //如果用DataTable返回一个List类型,除了上面手工转换,还可以使用下面的方法
//注意:需要引入using Newtonsoft.Json命名空间 //第一步:将DataTable中的数据库序列化为一个字符串
var json = JsonConvert.SerializeObject(dt);
List<Model> NewList = new List<Model>(); //第二步:将序列化的字符串反序列化为一个List对象
NewList = JsonConvert.DeserializeObject<List<Model>>(json);
#endregion #region 利用SqlCommand调用存储过程
if (SqlConn.State == ConnectionState.Closed)
{
SqlConn.ConnectionString = ConnStr;
SqlConn.Open();
} //新建SqlCommand对象
SqlCommand cmd_proc = new SqlCommand(); //设置SqlCommand对象的Connection属性,即:SqlConn(SqlConnection类型的对象)
cmd_proc.Connection = SqlConn; //如果SqlCommand对象执行的是存储过程,则必需设置SqlCommand对象的CommandType为CommandType.StoredProcedure
cmd_proc.CommandType = CommandType.StoredProcedure; //设置SqlCommand对象调用的存储过程名称
cmd_proc.CommandText = "PROC_Ex_Class"; //设置存储过程需要的参数
//如果是输入参数需要直接赋值,如果是输出参数或者返回值,则只需要设置参数的Direction属性
SqlParameter sql_parm1 = new SqlParameter("@ClassName", SqlDbType.NVarChar, ); //设置输入参数的值
sql_parm1.Value = "1909B"; //将参数添加进SqlCommand对象的Parameters集合
cmd_proc.Parameters.Add(sql_parm1); //第2个参数
SqlParameter sql_parm2 = new SqlParameter("@ClassCount", SqlDbType.NVarChar, ); //设置输入参数的值
sql_parm2.Value = ; //将参数添加进SqlCommand对象的Parameters集合
cmd_proc.Parameters.Add(sql_parm2); //第3个参数:设置输出参数的Direction属性,无需设置值
SqlParameter sql_parm3 = new SqlParameter("@Info", SqlDbType.NVarChar, );
sql_parm3.Direction = ParameterDirection.Output;
cmd_proc.Parameters.Add(sql_parm3); //第4个参数:设置存储过程返回值的Direction属性,无需设置值
SqlParameter sql_parm4 = new SqlParameter("@ReturnVal", SqlDbType.NVarChar, );
sql_parm4.Direction = ParameterDirection.ReturnValue;
cmd_proc.Parameters.Add(sql_parm4); //调用SqlCommand对象的ExecuteNonQuery方法,执行存储过程
cmd_proc.ExecuteNonQuery(); //存储过程执行完成后,输出参数和返回值参数自动会被赋值 //这是存储过程的输出参数
string info = Convert.ToString(sql_parm3.Value); //这是存储过程的返回值
int returnval = Convert.ToInt32(sql_parm4.Value); //我们可以把两个结果输出
Response.Write(string.Format("存储过程执行结果:输出参数:{0},返回值:{1}", info, returnval));
#endregion
ADO.NET五大对象增删改查使用的更多相关文章
- Ado.net[登录,增删改查,Get传值,全选,不选,批量删除,批量更新]
[虽然说,开发的时候,我们可以使用各种框架,ado.net作为底层的东西,作为一个合格的程序员,在出问题的时候我们还是要知道如何调试] 一.增删改查 cmd.ExecuteReader();执行查询, ...
- ADO.NET基础(增删改查)
ADO.NET是一种数据访问技术,就是将C#和MSSQL连接起来的一个纽带.可以通过ADO.NET将内存中的临时数据写入到数据库中,也可以将数据库中的数据提取到内存中供程序调用. ADO.NET是所有 ...
- jQuery 第四章 实例方法 DOM操作_基于jQuery对象增删改查相关方法
.next() .prev() .nextAll() .prevAll() .prevUntil() .nextUntli() .siblings() .children() .parent() .p ...
- C# ADO.NET 封装的增删改查
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- ADO.NET ORM数据库增删改查封装(工具一)
约束 public abstract class BaseModel { public int Id { get; set; } } 连接字符串 public static readonly stri ...
- ado.net C#如何实现数据库增删改查
ado.net数据库访问技术将数据库中的数据,提取到内存中,展示给用户看还可以将内存中的数据写入数据库中去 并不是唯一的数据库访问技术,但是它是最底层的数据库访问技术也就是说是最麻烦但是是最不可缺少的 ...
- ado.net的简单数据库操作(三)——简单增删改查的实际应用
果然,在犯困的时候就该写写博客,写博客就不困了,哈哈! 上篇我记录了自己的SqlHelper的开发过程,今天记录一下如何使用这个sqlhelper书写一个具有简单增删改查的小实例啦. 实例描述:在数据 ...
- Ado.net之对数据库的增删改查
一.了解Command对象 1.Command对象:封装了所有对外部数据源的操作,包括增删改查和执行存储过程,并在执行完成后返回合适的结果,同Connection一样,对于不同的数据源,Ado.net ...
- 在MFC里面使用ADO访问微软的ACCESS数据库 实现增删改查
声明:百度以外的公司可以自由转载该文. 正如我上一篇博文提到,ADO这货和MFC没有任何关系,ADO 是一个独立的组件.所以为了使用ADO 我们就要把ADO引入到MFC中. ADO是硬盘上的表现形式是 ...
随机推荐
- 如何在Hybris commerce里创建一个media对象
进入backoffice的Media中心, 首先新建一个文件夹,用于存放即将创建的media对象: 取名为jerryimage: 然后创建一个新的media对象,取名jerryproductimage ...
- Kubernetes 1.15部署日记-使用kubeadm--<7-8>
7. 在k8s集群中run一个应用 nginx已经跑起来了到此kubernetes集群部署结束了. 8. 总结 此次部署kubernetes的起因是AI团队中的kubernetes项目跑在其他IP段网 ...
- 初识面向对象(钻石继承,super,多态,封装,method,property,classmethod,staticmethod)
组合 什么有什么的关系 一个类的对象作为另一个类的对象继承 子类可以使用父类中的名字(静态属性 方法)抽象类和接口类 只能不继承,不能被实例化 子类必须实现父类中的同名方法———规范代码 metacl ...
- [http] http body中chunked数据的编码格式
一 我们知道,http response的body可以使用chunked编码.这个时候不需要显示的 指定content-length来标记结尾. 如: 我们可以见到编码的chunked字样,并且没有看 ...
- python爬虫爬取get请求的页面数据代码样例
废话不多说,上代码 #!/usr/bin/env python # -*- coding:utf-8 -*- # 导包 import urllib.request import urllib.pars ...
- 一个在开源中国博客上讲解的AC自动机
原文出处:http://my.oschina.net/amince/blog/196426 原 荐 AC(Aho—Corasiek) 多模式匹配算法 摘要 如何在一篇文章中,搜索多个关键字,如何快速查 ...
- 为什么将项目托管到Apache,浏览器输入http://127.0.0.1会跳转到http://127.0.0.1//dashboard/?
找到xampp安装的根目录下htdocs文件夹下的index.php文件 <?php if (!empty($_SERVER['HTTPS']) && ('on' == $_SE ...
- [Wc2011] Xor 和 [HNOI2011]XOR和路径
Xor F.A.Qs Home Discuss ProblemSet Status Ranklist Contest 入门OJ ModifyUser autoint Logout 捐赠本站 Prob ...
- Fiddler——如何抓取PHP的curl请求
前言 本文主要介绍如何使用fiddler工具,来进行抓取PHP的curl请求,如果你会使用fiddler,那就是一行代码的事, 不会也没事,本文会教你如何简单的使用. 步骤 代码 设置桥接网络为127 ...
- centos7下用命令安装node&pm2
一.下载node安装包 1.wget https://npm.taobao.org/mirrors/node/latest-v12.x/node-v12.4.0-linux-x64.tar.gz 二. ...