回顾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代码]由点及面,一叶知秋----集合大家族
Java中的集合类实在是太丰富了,有常用的ArrayList.HashMap,也有不常用的Stack. Queue,有线程安全的Vector.HashTable,也有线程不安全的LinkedList. ...
- 24小时学通Linux内核之有关Linux文件系统实现的问题
有时间睡懒觉了,却还是五点多醒了,不过一直躺倒九点多才算起来,昨晚一直在弄飞凌的嵌入式开发板,有些问题没解决,自己电脑系统的问题,虽然Win10发布了,,但我还是好喜欢XP呀,好想回家用用家里的XP来 ...
- Jersey(1.19.1) - Representations and Java Types
Previous sections on @Produces and @Consumes referred to MIME media types of representations and sho ...
- 转 Android中this、super的区别
在Java中,this通常指当前对象,super则指父类的.当你想要引用当前对象的某种东西,比如当前对象的某个方法,或当前对象的某个成员,你便可以利用this来实现这个目 的,当然,this的另一个用 ...
- boost库区间range基本原理及使用实例
由 www.169it.com 搜集整理 区间的概念类似于STL中的容器概念.一个区间提供了可以访问半开放区间[first,one_past_last)中元素的迭代器,还提供了区间中的元素数量的信息. ...
- 分布式系统怎样体现了CAP
`references:` 1. http://zh.wikipedia.org/wiki/CAP%E5%AE%9A%E7%90%86 2. http://en.wikipedia.org/wiki/ ...
- FastSocket学习笔记~制定自已的传输协议
对于TCP或者UDP来说,它们作于传输层的协议,有着自己的标准,或者叫格式,在我们看TCP格式之前先了解一下计算机的基础知识,字节,它是计算机世界的一个小单位,也是我们可以理会到的,如一个utf-8英 ...
- 对JavaScript莫名的愤怒
很多时候,我都察觉JavaScript有一中描述性语言的特性,为了实现他的功能,在浏览器中完美的发挥作用,他就像是一个巨型的工厂工程模式,外挂了很多API和功能集,他们试图用完美的方案去解释所有必须的 ...
- Java 读写XML文件 API--org.dom4j
om4j是一个Java的XML API,类似于jdom,用来读写XML文件的.dom4j是一个十分优秀的JavaXML API,具有性能优异.功能强大和极其易使用的特点,同时它也是一个开放源代码的软件 ...
- Java实战之04JavaWeb-03会话技术
一.会话技术简介 1.什么是会话,为什么需要会话技术? 会话:从打开一个浏览器,访问某个网站,到关闭这个浏览器的这个过程称为一次会话.http协议是状态的. 2.会话技术的分类 客户端存储技术:Coo ...