ADO.NET目录汇总1
1.引用命名空间:
using System.Data;
using System.Data.SqlClient;【访问SQL Server定义的类】
2.连接字符串
string connectionString
= "server=.;integrated security=true;database=mydb"
= "server=.;database=mydb;user id=sa;password=123"
= "server=.;database=mydb;uid=sa;pwd=123"
3.访问数据库
System.Data.SqlClient.SqlConnection connection
= new SqlConnection (connectionString);
a.与数据库建立连接:connection.Open();
b.断开数据库的连接:connection.Close();或者//connection.Dispose();
4.数据库操作【命令对象和事务对象】
string sql = "insert into ...";
System.Data.SqlClient.SqlCommand command = new SqlCommand(sql, connection);
command.ExecuteNonQuery(); //返回一个影响数(int)
a.以上是隐式事务下工作
b.显式事务工作
System.Data.SqlClient.SqlTransaction trans = connection.BeginTransaction();
command.Transaction = trans;
-----》
int effectCount = command.ExecuteNonQuery(); //工作内容
《-----
->trans.Commit();
->trans.Rollback();
5.访问存储过程-传入参数-传出参数
a.传入参数
string sql = "存储过程名字";
System.Data.SqlClient.SqlCommand command = new SqlCommand(sql, connection);
command.CommandType = = CommandType.StoreProcedure;//设置存储过程
System.Data.SqlClient.SqlParameter pEnd = new SqlParameter("@end",System.Data.SqlDbType.Int);
pEnd.Value = 100; //参数对象
command.Parameters.Add(pEnd);//加入参数
-->command.ExecuteNonQuery();
b.传出参数
System.Data.SqlClient.SqlParameter pResult = new SqlParameter("@result",System.Data.SqlDbType.Int);
pResult.Direction = ParameterDirection.Output;//参数对象
command.Parameters.Add(pResult);--OK
-->int result = (int) pResult.Value;
c.Return参数
System.Data.SqlClient.SqlParameter pReturn = new SqlParameter("@returnValue",System.Data.SqlDbType.Int);
pReturn.Direction = ParameterDirection.ReturnValue;
command.Parameters.Add(pReturn);--OK
-->int returnValue = pReturn.Value as int;
6.DataReader查询
using ( SqlConnection connection = new SqlConnect(connectionString))
{
connection.Open();
string sql = "select sid,sname,salias,sage from tb_students";
SqlCommand command = new SqlCommand(sql, connection);
SqlDataReader reader = command.ExecuteReader();
while(reader.Read()) //返回boolean
{
int id = reader.GetInt32(0); //支持索引器 reader[0]\reader["sid"];
string name = reader.GetString(1);
string alias = null;
if(!reader.IsDBNull(2))
{
salias = reader.GetString(2);
}
int? age = null; //可空类型,用于值类型
age = reader.GetInt32(3);
if(age.HasValue)
{
age.value;
}
}
reader.Dispose();
}
7.读取单个的值-数据访问接口-数据访问对象
a.第一行,第一列:
object obj = command.ExecuteScalar();
System.Data.SqlClient.SqlConnection
System.Data.SqlClient.SqlCommand
System.Data.SqlClient.SqlTransaction
System.Data.SqlClient.SqlParameter
Command.ExecuteNonQuery
Command.ExecuteReader
Command.ExecuteScalar
8.数据访问对象的实现
如:scope_identity()
string connectionString = "server=.;database=mydb;integrated security=true;";
using(SqlConnection connection = new SqlConnection(connectionString))
{
string sql = "insert into ...;select scope_identity();";
SqlCommand command = new SqlCommand(sql, connection);
SqlParameter pval1 = new SqlParameter("@pval1",SqlDbType.ValChar,10);
SqlParameter pval2 = new SqlParameter("@pval2",SqlDbType.ValChar,10);
pval1.value="111";
pval2.value="222";
command.Parameters.Add(pval1);
command.Parameters.Add(pval2);
connection.Open();
object obj = command.ExecuteScalor(); //numeric(38,0)
}
9.DataTable
System.Data.DataTable table = new System.Data.DataTable();
System.Data.DataColumn idColumn
= new System.Data.DataColumn("sid",System.Type.GetType("System.Int32"));
= new System.Data.DataColumn("sid",typeof(int));
System.Data.DataColumn nameColumn = new System.Data.DataColumn("sid",typeof(string));
//表结构
table.Columns.Add(idColumn);
table.Columns.Add(nameColumn);
//主键约束
table.ParmaryKey = new DataColumn[]{ idColumn };
idColumn.AllowDBNull = false;
//idColumn.Unique
...
DataRow row = table.NewRow();
row[idColum]=1;
row[1]="Jasonlny";
table.Rows.Add(row);
foreach(DataRow dr in table.Rows)
{
...dr[..]
}
==========================================
DataTable table = new DataTable();
string connectionString = "server=.;database=mydb;integrated security=true;";
using(SqlConnection connection = new SqlConnection(connectionString))
{
string sql = "select ... ...";
SqlCommand command = new SqlCommand(sql, connection);
connection.Open();
using(SqlDataReader reader = command.ExecuteReader())
{
int columnCount = reader.FieldCount;
for(int i=0; i<columnCount; i++)
{
DataColumn column = new DataColumn(reader.GetName(i), reader.GetFieldType(i));
table.Columns.Add(column);
}
while(reader.Read())
{
DataRow dr = table.NewRow();
for(int i=0; i<columnCount; i++)
{
dr[i] = reader[i];
}
table.Rows.Add(dr);
}
}
}
10.DataAdapter-DataSet
System.Data.DataSet dset = new System.Data.DataSet();
//dset.Tables...
string connectionString = "...";
string sql = "select ...";
System.Data.SqlClient.SqlDataAdapter adapter = new SqlDataAdapter(sql,connectionString);
adapter.Fill(dset);
System.Data.DataTable table = dset.Tables[0];
//adapter.SelectCommand...
ADO.NET目录汇总1的更多相关文章
- ASP.NET MVC4入门到精通系列目录汇总
序言 最近公司在招.NET程序员,我发现好多来公司面试的.NET程序员居然都没有 ASP.NET MVC项目经验,其中包括一些工作4.5年了,甚至8年10年的,许多人给我的感觉是:工作了4.5年,We ...
- ASP.NET MVC4入门到精通系列目录汇总(转)
序言 最近公司在招.NET程序员,我发现好多来公司面试的.NET程序员居然都没有 ASP.NET MVC项目经验,其中包括一些工作4.5年了,甚至8年10年的,许多人给我的感觉是:工作了4.5年,We ...
- 史上最全面的SignalR系列教程-目录汇总
1.引言 最遗憾的不是把理想丢在路上,而是理想从未上路. 每一个将想法变成现实的人,都值得称赞和学习. 致正在奔跑的您! 2.SignalR介绍 SignalR实现服务器与客户端的实时通信 ,她是一个 ...
- Spring Cloud Eureka(一): 开篇说明及目录汇总
开篇简述 基于Spring Boot 和 Spring Cloud 的微服务应用,本人在工作中已经使用两年有余了,伴随着个人学习计划的实施,希望借助博文的方式,将工作中使用到的技术点体系化的总结出来, ...
- 跟我学SpringMVC目录汇总贴、PDF下载、源码下载
国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...
- Java 9 揭秘全目录汇总
Tips 做一个终身学习的人. 当写这篇文章时,关于Java 9的学习就先告一段落了. 首先介绍一下背景,大概两个月前,我突然有兴趣想看看Java 9,当时读了一本英文原著<Java 9 Rev ...
- openstack pike 集群高可用 安装 部署 目录汇总
# openstack pike 集群高可用 安装部署#安装环境 centos 7 史上最详细的openstack pike版 部署文档欢迎经验分享,欢迎笔记分享欢迎留言,或加QQ群663105353 ...
- 《Java 9 揭秘》全目录汇总
Tips 做一个终身学习的人. 当写这篇文章时,关于Java 9的学习就先告一段落了. 首先介绍一下背景,大概两个月前,我突然有兴趣想看看Java 9,当时读了一本英文原著<Java 9 Rev ...
- 死磕salt系列-salt文章目录汇总
死磕salt系列-salt入门 死磕salt系列-salt配置文件 死磕salt系列-salt grains pillar 配置 死磕salt系列-salt 常用modules 死磕salt系列-sa ...
随机推荐
- threejs绘制顺序
renderer.sortObjects = false; 然后,scene.add(),就可以先add先画了,否则add的顺序和渲染出来的顺序不一定一致.
- ORA-00600: internal error code, arguments: [kcblasm_1], [103], [] bug
巡检发现存在alert 日志存在ORA-600 1.0 查询alter 对应的Trace日志 /oracle/admin/fgsquery/udump/fgsquery_ora_21777.trc O ...
- Samsung_tiny4412(驱动笔记04)----volatile,container_of,file_operations,file,inode
/*********************************************************************************** * * volatile,co ...
- 关于PHP程序员技术职业生涯规划[转]
看到很多PHP程序员职业规划的文章,都是直接上来就提Linux.PHP.MySQL.Nginx.Redis.Memcache.jQuery这些,然后就直接上手搭环境.做项目,中级就是学习各种PHP框架 ...
- [LeetCode&Python] Problem 237. Delete Node in a Linked List
Write a function to delete a node (except the tail) in a singly linked list, given only access to th ...
- [LeetCode&Python] Problem 520. Detect Capital
Given a word, you need to judge whether the usage of capitals in it is right or not. We define the u ...
- 测试那些事儿—Linux搭建环境基础步骤
Linux搭建环境基础步骤 准备工具:SecureCRT工具(Linux工具,连接服务器)FTP传输工具(上传文件到服务器)MySQL连接工具 安装包(以下文件均为压缩包rpm格式和tar.gz):J ...
- (0)MySQL 的指令(包含了解知识点)
第七章索引:入门安装 - 增删改查基本操作 - 外键(不同表之间的关联) - 数据库的建立和操作 - MySQL的查询操作(模糊.通配.限制符等) - MySQL的引擎 - MySQL的事物(数据回滚 ...
- linux----别名
经常一些命令太长,输入太麻烦,给该命令起个别名,直接执行,简单又方便. 1.查看别名 alias 2.编辑别名 vi ~/.brashrc 3.添加自己的别名 例如:重启网卡 alias netres ...
- MySQL联结查询和组合查询
联结查询 1.关系表 主键:一列或一组列,能够唯一区分表中的每一行,用来表示一个特定的行 外键:为某个表中的一列,包含另一个表的主键,定义量表的关系. 2.创建联结 规定要连接的表和他们如何关联即可 ...