回顾Ado.Net
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data.SqlClient;
using System.Configuration;
using System.Data;
/// <summary>
///SqlHelper 的摘要说明
/// </summary>
public class SqlHelper
{
static string connStr = ConfigurationManager.ConnectionStrings["JSDB"].ConnectionString;
public SqlHelper()
{
}
public static int ExecuteNonquery(string cmdText,params SqlParameter[] ps)
{
using (SqlConnection conn = new SqlConnection(connStr))
{
using (SqlCommand cmd = new SqlCommand())
{
conn.Open();
cmd.Connection = conn;
cmd.CommandText = cmdText;
cmd.Parameters.AddRange(ps);
return cmd.ExecuteNonQuery();
}
}
}
public static object ExecuteScalar(string cmdText, params SqlParameter[] ps)
{
using (SqlConnection conn = new SqlConnection(connStr))
{
using (SqlCommand cmd = new SqlCommand())
{
conn.Open();
cmd.Connection = conn;
cmd.CommandText = cmdText;
cmd.Parameters.AddRange(ps);
return cmd.ExecuteScalar();
}
}
}
public static DataSet GetDsByAdapter(string cmdText, params SqlParameter[] ps)
{
DataSet ds = new DataSet();
using (SqlConnection conn = new SqlConnection(connStr))
{
using (SqlCommand cmd = new SqlCommand())
{
conn.Open();
cmd.Connection = conn;
cmd.CommandText = cmdText;
cmd.Parameters.AddRange(ps);
using (SqlDataAdapter apt = new SqlDataAdapter(cmd))
{
apt.Fill(ds);
}
}
}
return ds;
}
public static SqlDataReader GetReader(string cmdText, params SqlParameter[] ps)
{
//using (SqlConnection conn = new SqlConnection(connStr))
//{
// using (SqlCommand cmd = new SqlCommand())
// { conn.Open();
// cmd.Connection = conn;
// cmd.CommandText = cmdText;
// cmd.Parameters.AddRange(ps);
// return cmd.ExecuteReader(CommandBehavior.CloseConnection);
// }
//}
SqlConnection conn = new SqlConnection(connStr);
SqlCommand cmd = new SqlCommand();
conn.Open(); cmd.Connection = conn; cmd.CommandText = cmdText; cmd.Parameters.AddRange(ps);
return cmd.ExecuteReader(CommandBehavior.CloseConnection);
}
}
==============调用 /*
string sql = "insert into mytest (id,name) values(1,'abc')";
SqlHelper.ExecuteNonquery(sql);
*/
/*
string sql = "select * from mytest";
object obj = SqlHelper.ExecuteScalar(sql);
*/
/*
string sql = "select * from mytest";
DataSet obj = SqlHelper.GetDsByAdapter(sql);
*/
string sql = "select * from mytest";
SqlDataReader reader = SqlHelper.GetReader(sql);
Dictionary<string, string> dic = new Dictionary<string, string>();
while (reader.Read())
{
dic.Add(reader["Id"].ToString(),reader["Name"].ToString());
} |
ExecuteNonquery 用于 非查询操作,用于查询的操作,没有结果;如果sql中有查询的语句有非查询的语句,此操作返回所有insert update delete这些操作的影响行数;
ExecuteScalar 返回首行手列内容;不是说就不能执行 insert等操作,没问题,但是得不到反应的结果,数据能插入数据库没问题;多个操作,返回第一个有结果集操作的首行收列(比如 insert ...output或者select等) Adapter和reader返回 查询的结果,不是说不能执行 非查询操作,没问题数据照样执行,但是得不到任何反应; public class Comunicate
{
static string connStr = ConfigurationManager.AppSettings["connStr"].ToString();
public static void ExecuteNonquery()
{
//execurenonquery update delete insert 返回受这3中操作的影响的行数,【通过输出参数output可以输出一些内容】
// string sql = "insert into person (name ,age) values ('张三',25)";//插入一条数据,返回受影响行数1
// string sql = "select * from person";//-1
// string sql = "select * from person where name = 'shit'";//-1
using (SqlConnection conn = new SqlConnection(connStr))
{
using (SqlCommand cmd = new SqlCommand())
{
// string sql = "InsertOutAge";//得到的还是受影响的行数1,没有得到age
//string sql = "InsertOutAgeTwo";
//string sql = "InserTsELECT";
string sql = "InserTsELECT3";//添加1行删除1行 ,影响结果是2
conn.Open();
cmd.Connection = conn;
cmd.CommandText = sql;
//存储过程的
//cmd.CommandType = CommandType.StoredProcedure;
//cmd.Parameters.Add("@name","李四");
//SqlParameter p = new SqlParameter();
//p.Direction = ParameterDirection.Output;
//p.ParameterName = "@age";
//p.SqlDbType = SqlDbType.Int;
//p.Size = 4;
//cmd.Parameters.Add(p);
int result = cmd.ExecuteNonQuery();//影响行数1
// object re = p.Value;//输出参数 92
}
}
}
public static void ExeceteScalar()
{
using (SqlConnection conn = new SqlConnection(connStr))
{
using (SqlCommand cmd = new SqlCommand())
{
//string sql = "select * from person";//返回首航受列内容
string sql = "insert into person(age) values(30);select * from person;select * from person where id>6";//多个操作返回多张表时,一第一个为准,返回首行首列内容
cmd.Connection = conn;
conn.Open();
cmd.CommandText = sql;
object resltu = cmd.ExecuteScalar();
}
}
}
public static void GetDataTable()
{
//可以执行insert操作,但是此方法只是用来得到 select的内容 // string sql = "insert into person (name,age) values ('阿杜',25);select * from person";//执行了insert 把select的fill到datatable
string sql = "insert into person (name,age) values ('阿杜',26)";//能狗插入数据成功
using (SqlDataAdapter apt = new SqlDataAdapter(sql,connStr))
{
DataTable dt = new DataTable();
apt.Fill(dt);
}
}
} |
回顾Ado.Net的更多相关文章
- Oracle 应用于.NET平台
1. 回顾ADO.NET ADO.NET是一组用于和数据源进行交互的面向对象类库集,它存在于.Net Framework中.通常情况下,数据源可以是各种类型的数据库,利用ADO.NET可以访问目前几乎 ...
- .NET基础操作回顾_使用ADO.NET操作SqlServer使用的类
有些工具用的久了或者有新工具出现后,就慢慢的遗忘了很多,它们从熟悉的变成陌生,当然,对于我们来说不是好事吧. 今天回顾一下ADO.NET用到的MS的基础类库,先上代码(标准的SqlServer操作) ...
- ADO.NET基础巩固-----连接类和非连接类
最近的一段时间自己的状态还是不错的,早上,跑步,上自习看书,下午宿舍里面编程实战,晚上要么练习代码,要么去打球(在不打就没机会了),生活还是挺丰富的. 关于C#的基础回顾就先到前面哪里,这 ...
- ADO与ADO.NET的区别与介绍
1. ADO与ADO.NET简介ADO与ADO.NET既有相似也有区别,他们都能够编写对数据库服务器中的数据进行访问和操作的应用程序,并且易于使用.高速度.低内存支出和占用磁盘空间较少,支持用于建立基 ...
- ADO和ADO.NET的区别
1. ADO与ADO.NET简介 ADO与ADO.NET既有相似也有区别,他们都能够编写对数据库服务器中的数据进行访问和操作的应用程序,并且易于使用.高速度.低内存支出和占用磁盘空间较少,支持用于建立 ...
- ADO.NET之使用DataGridView控件显示从服务器上获取的数据
今天回顾下ADO.NET中关于使用DataGridiew控件显示数据的相关知识 理论整理: 使用 DataGridView 控件,可以显示和编辑来自多种不同类型的数据源的表格数据. SqlDataAd ...
- ADO.NET知识的运用一(Day 26)
哈哈,又到了总结的时间了,来回顾一下今天主要学了关于ADO.NET的哪些知识吧.(这次学的ADO访问数据库主要以访问SQL数据库为主) 理论: 首先我们要知道为什么要学习ADO.NET? 因为我们之 ...
- [转]一个普通IT人的十年回顾---金旭亮
金旭亮老师十年体会,很有收获.转自网络. 金旭亮于1989年与超级解霸的开发者梁肇新同时迈入广西大学的校门,却走了一条与其不同的路. 1994年起开始自学计算机专业本科课程,并开始编程,从未间断,迄今 ...
- 金老师的经典著作《一个普通IT人的十年回顾》
学习人生 -------一个普通IT人的十年回顾(上)序从1994到2003,不知不觉之间,我已在计算机技术的世界里沉浸了十年.有位哲人说过:如果一个人能用十年的时间专心致志地 ...
随机推荐
- Java事件总线
在平时写代码的过程中,我们需要实现这样一种功能:当执行某个逻辑时,希望能够进行其他逻辑的处理.最粗暴的方法是直接依赖其他模块,调用该模块的相应函数或者方法.但是,这样做带来一些问题. 模块间相互依赖, ...
- hdu 2838 树状数组
思路:从后面往前面插,用一个二维树状数组保存,c[i][0]表示比i小的元素和,c[i][1]表示比i小的元素个数. #include<iostream> #include<cstr ...
- 核心概念 —— 门面(Facades)
1.简介 门面为应用的服务容器中的绑定类提供了一个"静态"接口.Laravel 内置了很多门面,你可能在不知道的情况下正在使用它们.Laravel 的门面作为服务容器中的底层类的& ...
- GD库使用小结---2
接着上一篇.GD库可以折腾很多用法出来,当然得跟画图相关,除了前面的验证码.水印外,还可以进行图片的缩放,裁剪.旋转等操作,这在很多应用中可以见到. 1. 加水印 前面已经知道,我们可以使用image ...
- 推荐一款App运营工具:AYL爱盈利App榜单监控
对包括开发者.产品运营.投资人在内的诸多移动互联网从业人员而言,国内Android应用市场和IOS应用市场的榜单变化数据时大家的必修功课之一:看看这段时间所关注的垂直领域里最火的是哪几款应用:看看竞争 ...
- SQL server 2008 安装问题解决
安装sqlserver2008 出现的一些问题解决方法 1,安装sqlserver的时候出现如下图所示,解决办法是:开始→运行→输入“regedit”→找到“HKEY_LOCAL_MACHINE\SY ...
- 在Tomcat中配置基于springside的项目
注意点: Tomcat默认没有配置Transaction,需要在/Conf/Context.xml配置 1 <Transaction factory="org.objectweb.jo ...
- Html的maxlength属性
maxlength表示文本框只能输入的字符串,多的无法输入
- [Bootstrap]全局样式(二)
具体排版 1.标题和标题类 <h1> ~<h6>和.h1~h6|副标题<small>和.small font-size mar ...
- shell命令行快速编辑命令
ctrl r:命令行出现 reverse-i-search,输入字符将在输入历史中匹配命令 ctrl p:向前翻看历史 ctrl n:向后翻看历史 ctrl a:命令行首 ctrl e:命令行尾 ct ...