【ADO.NET基础知识】SqlConnection、command、DataSet 、DataTable、dataAdapter
1.使用Connection连接数据库的步骤:
(1).添加命名空间 System.Data.SqlClient(注意:初学者经常会忘记)
(2)定义连接字符串。连接SQL Server 数据库时:
server=服务器名;database=数据库名;uid=用户名;pwd=密码;例如:要连接本机上的StudentManagement数据库,用户名为sa,密码为111
string connString="server=.;database=StudentManagement;uid=sa;pwd=111;"
(3).创建Connection对象:
SqlConnection connStr=new SqlConnection(connSting);
(4).打开数据库:
conn.Open();
(5).对数据库操作完毕后关闭数据库连接
conn.Close();
2.Command对象:
(1).command对象可以用来对数据库发出具体的操作指令,例如对数据库的查询、增加、修改、删除
(2).创建Command对象,并设置它的属性:
SqlCommand command =new SqlCommand();
command.Connection=connection;
command.CommandText=sqlQuery(sqlQuery为查询语句);
(3).Command对象的主要方法:
ExecuteNonQuery:执行后不返回任何行,对于update、insert、delete语句,返回影响的行数对于其他类型的语句,返回值为-1
ExecuteReader:执行查询语句,返回DataReader对象
ExecuteScalar:执行查询,并返回查询结果的第一行第一列,忽略其他列或行
ExecuteXmlreader:将CommandText发送到Connection并生成一个XmlReader
3.DataReader对象:
(1).DataReader对象可以从数据库中一只读、只进的方式查询数据,每次的操作只有一个记录保存在内存中
(2).DataReader对象的主要方法:
Read:读取下一条数据
Close:关闭DataReader对象
(3).使用DataReader提取数据的步骤:
(a).建立与数据库的连接并打开
(b).创建一个Command对象
(c).从Command对象中创建DataReader对象
(d).使用DataReader读取并显示
可以使用一个循环利用Read方法便利数据库中行的信息,如果要获取该行中某列的值,只需要使用"["和"]"运算符就可以了
(e).分别关闭DataReader对象和数据库的连接
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.SqlClient; namespace ado.netDemo
{
class Program
{
static void Main(string[] args)
{
//定义连接字符串
string connStr = @"server=SUNNY\SQLEXPRESS;database=TestDB;UID=sa;PWD=123456";
//连接数据库
SqlConnection conn = new SqlConnection(connStr);
//SQL语句
string sql = "select * from tb_Students";
//string sql = "insert into tb_Students(SID, Name, Password, Sex, Age, Address, Phone, QQ) Values('20117750120','小鸟电动车','123','男',21,'HONGKONG','18736000000','1147016165')";
//string sql = "update tb_Students set SID='20117750119' where SID='20117750120'";
//string sql = "delete from tb_Students where SID='20117750101'";
//执行SQL语句
SqlCommand cmd = new SqlCommand(sql,conn); conn.Open(); SqlDataReader reader = cmd.ExecuteReader();
while (reader.Read())//read()一直读取下一个数据
{ Console.WriteLine(string.Format("{0}\t{1}\t{2}\t{3}", reader[],reader[], reader[], reader[]));
}
reader.Close();
//查询数据
#region
//ExecuteScalar执行sql查询语句的第一行第一列,忽略其他行其他列。
//object result = cmd.ExecuteScalar();
//Console.WriteLine("共查询到有:{0}行数据", result.ToString()); #endregion
//增加数据
#region
//int result = cmd.ExecuteNonQuery();
//if (result < 1)
//{
// Console.WriteLine("数据插入失败,请检查填写信息,重新操作");
//}
//else
//{
// Console.WriteLine("数据插入成功!");
//}
#endregion
//修改数据
#region
//int result = cmd.ExecuteNonQuery();
//if (result < 1)
//{
// Console.WriteLine("数据修改失败,请检查填写信息,重新操作");
//}
//else
//{
// Console.WriteLine("数据修改成功!");
//}
#endregion
//删除数据
#region
//int result = cmd.ExecuteNonQuery();
//if (result < 1)
//{
// Console.WriteLine("数据删除失败,请检查填写信息,重新操作");
// Console.WriteLine("{0}行收到影响", result);
//}
//else
//{
// Console.WriteLine("数据删除成功!");
// Console.WriteLine("{0}行收到影响", result);
//}
#endregion conn.Close();
Console.ReadKey(); }
}
}
(二)ADO.NET数据库访问技术:
通过这几天的学习,下面来把有关数据适配器和数据集方面的知识点总结一下:
一.DataSet 和DataTable:
数据集在ADO.net中的对象是DataSet,DataSet由一个或多个DataTable组成
1.DataTable:
(1).DataTable是表格数据块在内存中的表示,DataTable对象由DataColumns集合以及DataRows集合组成。对数据库检索后,被取回的数据就存放在DataTable对象中
(2).DataTable对象的主要的属性:
CaseSensitive:表中的字符串是否区分大小写
Columns:返回属于这个表的列集合
DataSet:获得这个表的行集合
TableName:获得或设置表的名称
HasChanges:判断数据集是否更改了
(3).dataTable对象的主要方法:
Clear:清除DataTable内所有的行数
NewRow:增加一行
2、DataSet:数据装置
(1).DataSet的主要属性:
Table:可以访问DataSet中表的集合
(2).DataSet对象的主要方法
Clear:完全清除DataSet的数据
Clone:创建与原DataSet具有相同结构和相同行的DataSet
Copy:创建具有相同结构的新DataSet,但不包含任何行
(3).填充DataSet数据集:使用数据适配器DataAdapter,DataAdapter对象的Fill()方法可以给DataSet填充数据,例如
(Fill(参数1,参数2 )第一个参数指定要填充的DataSet,第二个参数是dataSet中要加载数据的Datatable名称)
(4).使用dataAdapter对象填充DataSet数据库的步骤:
(a).建立数据库的连接,并打开盖连接
string connString="、、、";
SqlConnection mySqlConnection=new SqlConnection(connString);
mySqlConnection.Open();
(b).定义要执行的SQl语句
string sqlQuery="、、、、";
(c).创建数据集DataSet对象
DataSet ds=new DataSet();
(d) .创建数据适配器DataAdapter
sqlDataAdapter da=new sqlDataAdapter(sqlQuery,mySqlConnection);
(e).使用DataAdapter对象的Fill()方法填充数据集
a.Fill(ds,"Table");//DataSet可以被看作是一个虚拟的表或表的集合,这里被填充的表的名称在Fill方法中命名为Table
(f).关闭数据库连接
mySqlConnection.Close();
注意:close与Dispose的区别:Close关闭以后还能打开;Dispose是直接销毁,不能再次使用
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data.SqlClient;
using System.Configuration;
using System.Data; namespace ado.netDemo1
{
public partial class Test1 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
//string connStr = ConfigurationManager.ConnectionStrings["connStr"].ToString();
//SqlConnection conn = new SqlConnection(connStr);
//conn.Open();
//string sql = "select * from tb_Students";
//SqlDataAdapter adapter = new SqlDataAdapter(sql, conn);
//DataSet dataset = new DataSet();
//adapter.Fill(dataset);
//conn.Close();
//GridView1.DataSource = dataset.Tables[0].ToString();
//GridView1.DataBind(); GridView1.DataSource = getResult();
this.GridView1.DataBind();
} //将数据库信息田中到DataSet的DataTable中
public DataSet getResult()
{
string connStr = ConfigurationManager.ConnectionStrings["connStr"].ToString();
SqlConnection conn = new SqlConnection(connStr);
conn.Open();
string sql = "select * from tb_Students";
//创建数据适配器
SqlDataAdapter adapter = new SqlDataAdapter(sql, conn);
//创建数据集对象
DataSet dataset = new DataSet();
//使用适配器对象Fill()方法填充DataSet数据集
adapter.Fill(dataset);
conn.Close();
return dataset;
}
}
}
(3)访问DataSet数据集:
(1).访问DataTable:当访问的数据被存放到数据集中后,可以用两种方式访问DataTable:按表名访问和按索引(索引从0开始)访问
(2).访问行和列
总结:希望通过小编写的 ADO.NET数据库访问技术的两种方法可以帮助各位网友们在做网站开发的时候,数据库连接时可以得到更好的解答。
【ADO.NET基础知识】SqlConnection、command、DataSet 、DataTable、dataAdapter的更多相关文章
- ADO.NET基础知识学习(SQLCOnnection&SQLCommand&SQLDataReader&SQLDataAdapter&DataSet)
通过ADO.NET技术,我们可以高效的完成客户端同数据库之间的数据访问操作,便于我们在客户端程序简便高效的访问以及获取数据库中的有用数据,同时也可以对数据库中的数据进行更新,即可以完成客户端与数据库之 ...
- ADO.NET基础知识
ADO.NET定义 ADO是ActiveX Data Objects的缩写,ADO.NET是数据库应用程序和数据源之间沟通的桥梁,主要提供一个面向对象的数据访问架构,用来开发数据库应用程序,就是一组类 ...
- ado.net中的 sqlconnection sqlcommand datareader dataset SqlDataAdapter之间的关系
Connection: 和数据库交互,必须连接它.连接帮助指明数据库服务器.数据库名字.用户名.密码,和连接数据库所需要的其它参数.Connection对象会被Command对象使用,这样就能够知道是 ...
- ADO.NET基础巩固-----连接类和非连接类
最近的一段时间自己的状态还是不错的,早上,跑步,上自习看书,下午宿舍里面编程实战,晚上要么练习代码,要么去打球(在不打就没机会了),生活还是挺丰富的. 关于C#的基础回顾就先到前面哪里,这 ...
- .Net Core 系列:2、ADO.Net 基础
目录: 1.环境搭建 2.ADO.Net 基础 3.ASP.Net Core 基础 4.MD5.Sha256.AES 加密 5.实现登录注册功能 6.实现目录管理功能 7.实现文章发布.编辑.阅览和删 ...
- ADO.NET基础开发
ADO.NET是微软新一代.NET数据库的访问架构,ADO是ActiveX Data Objects的缩写.ADO.NET是数据库应用程序和数据源之间沟通的桥梁,主要提供了一个面向对象的数据访问架构, ...
- ADO.NET基础03
数据库和VS的连接,实现数据的同步,让用户的一切信息都可以在数据库中留下记录. ADO.NET基础 它是连接所有数据库的一种特殊的技术,提供对不同的数据库统一操作接口. 在VS中也可以添加数 ...
- ADO.NET基础01(ADO.NET组成,数据库的方式,SqlCommand,SqlDataReader)
什么是ADO.NET: ADO.NET就是一组类库,这组类库可以让我们通过程序的方式访问数据库,就像System.IO下的类操作文件一样, System.Data.这组类是用来操作数据库(不光是MSS ...
- 如鹏网学习笔记(六)ADO.Net基础
ADO.Net基础 一.ADO.Net简介 1,程序要通过SQL语句自动化的操作数据库,必须要用一个类库, 类库要提供execute("insert into ...")/exec ...
随机推荐
- SpringBoot_@valid_参数校验
SpringBoot @valid 参数校验 空检查 @Null 验证对象是否为null @NotNull 验证对象是否不为null, 无法查检长度为0的字符串 @NotBlank 检查约束字符串是不 ...
- gin-jwt对API进行权限控制
前言 之前文章简单介绍了如何运行gin+vue的前后端分离开源项目,该项目是学习了Gin实践教程后结合vue-element-admin写的,该教程讲得很详细,适合入门Gin.本篇文章将介绍gin+v ...
- FastDFS初印象
是什么? FastDFS是一个轻量级分布式文件系统. 能干嘛? 对文件进行管理,功能包括:文件存储.文件同步.文件访问(文件上传.文件下载)等. 相关概念 ...
- 表单模糊查询的三种简单方式(springboot-h2-mybatis)
前几天运营提到说后台管理系统有几个地方想要模糊查询.. 想了下是简单的,就是要注意以前方法的被调用情况,进行增量改动,以免牵一发而动全身.整理一波记录下(本次案例是按名字模糊查询学生信息). 三种 ...
- ScrollView中页面显示自动滑到最后问题的解决
转载:https://blog.csdn.net/a644904088/article/details/80241176 原因:ScrollView中包含其余控件,但控件显示不全,此时会存在焦点问题, ...
- Beego orm 模型字段与数据库类型的对应
深度学习,ORM 推荐的对应数据库类型,在此列出,自动建表功能也会以此为标准.默认所有的字段都是 NOT NULL MySQL go mysql int, int32-设置auto或者名称为Id in ...
- GO.数据库接口
Go没有内置的驱动支持任何的数据库,但是Go定义了database/sql接口,用户可以基于驱动接口开发相应数据库的驱动. 目前NOSQL已经成为Web开发的一个潮流,很多应用采用了NOSQL作为数据 ...
- NLP(十五) 聊天机器人
对话引擎 1.了解目标用户 2.理解用于沟通得语言 3.了解用户的意图 4.应答用户,并给出进一步线索 NLTK中的引擎 eliza,iesha,rude,suntsu,zen import nltk ...
- P2154 [SDOI2009]虔诚的墓主人 树状数组
https://www.luogu.org/problemnew/show/P2154 题意 在一个坐标系中,有w(1e5)个点,这个图中空点的权值是正上,正下,正左,正右各取k个的排列组合情况.计算 ...
- 【Edu49 1027D】 Mouse Hunt DFS 环
1027D. Mouse Hunt:http://codeforces.com/contest/1027/problem/D 题意: 有n个房间,每个房间放置捕鼠器的费用是不同的,已知老鼠在一个房间x ...