刚接触到数据库时总是被数据库中的一些基本概念,比如Connection、Command、DataReader等,给整的糊里糊涂。如今,对数据库的基本操作有了一定的认识,特此做出总结,以便后续工作中查阅。

  Microsoft公司提供了几种常见的数据源操作:Sql server数据库,OLEDB数据源,ODBC数据源,Oracle数据库,而针对它们的一些常规操作可以说是大同小异,本文借以对Sql server数据库的操作进行Connection、Command、DataSet、DataAdapter、DataReader的介绍。

SqlConnection:

Sqlconnection是对象用来连接sql server数据库的,程序员对数据库的一切操作都是建立在数据库已经连通的基础上,因此对它有必要做一些基本的了解。

SqlConnection的基本语法是(拿一个连接的语句):Data Source=192.168.100.46;Initial Catalog=database;User ID=sa;Password=sa

而在实际的操作过程中经常把它放到配置文件中,以便后续进行更改,当然也可以把其基本项放到前台界面填写操作。

放在配置文件中,参考代码:

<?xml version="1.0"?>
<configuration>
<appSettings>
<add key="ConnectionString" value="Data Source=192.168.100.46;Initial Catalog=database;User ID=sa;Password=sa"/>
</appSettings>
<startup><supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.0"/></startup></configuration>
一句话:SqlConnection是对象连接数据库的。

SqlCommand:

在对象和数据库建立连接后,可以使用Command对象对数据库进行增、删、改、查等基本操作,操作实现方式可以是使用sql语句进行,也可以是使用存储过程。下面简单介绍Command对象的常用属性及其方法。

常用属性:

CommandType:获取或设置Command对象要执行命令的类型

CommandText:获取或设置要对数据源执行的SQL语句、存储过程或表名

CommandTimeOut:获取或设置在终止对执行命令的尝试并生成错误之前的等待时间

Connection:获取或设置此Command对象使用的Connection对象的名称

Parameters:获取Command对象要使用的参数集合。

常用方法:

ExecuteNonQuery:执行sql语句并返回受影响的行数

ExecuteReader:执行返回数据集的select语句

ExecuteScalar:执行查询,并返回查询所返回的结果集中第一行第一列

一句话:SqlCommand是需要对数据库做出改变或调整时使用的,使用后(除查询)数据库会有变化。

DataSet:

DataSet是数据库操作过程中的核心对象,支持断开式、分布式数据方案的核心对象。DataSet对象是创建在内存中的集合对象,它可以包含任意数量的数据表,以及所有的表的约束、索引、和关系,就相当于一个小型关系的数据库。而一个dataset对象包含一组DataTable对象,这些对象可以与数据相关联,其中每个dataTable对象都是由DataColumn和DataRow对象组成的。

对DataSet的常见操作:

以编程方式在DataSet中创建dataTable、DataRelation、Constraint,并使用数据填充表

通过DataAdapter填充dataSet

使用XML加载和保持DataSet内容

一句话:DataSet是一个保存数据的小型数据库,支持断开数据库连接后的操作。

 DataAdapter:

DataAdapter对象是DataSet对象和数据源之间联系的桥梁,主要是从数据源中检索数据、填充DataSet对象中的表或者把用户对DataSet做出的更改写入到数据库中。

常用属性:

selectCommand:获取或设置用于在数据源中选择记录的命令

InsertCommand:获取或设置用于将新的记录插入到数据库中命令

UpdateCommand:获取或设置用于更新数据源中记录的命令

DeleteCommand:获取或设置用于从数据集中删除记录的命令

常用方法:

Fill:从数据源中提取数据以填充数据集

Update:更新数据源

一句话:DataAdapter对用于连接dataSet和数据源的。

DataReader:

DataReader是一个简单的数据集,用于从数据源中检索只读数据集,常用于检索大量数据。DataReader每次读取数据时只在内存中保留一行记录,开销非常小。

可以从Command对象的ExecuteReader方法从数据源中检索数据来创建DataReader对象。如:SqlDataReader sdr = cmd.ExecuteReader()

常用方法:

FieldCount:获取当前行的列数

RecordsAffectde:获取执行SQL语句所更改、添加或删除的行数

常用方法:

Read:使用DataReader对象前进到下一条记录

Close:关闭DataReader对象

Get:用来读取数据集的当前行的某一列记录

一句话:DataReader每次读取数据源时在内存中保留一行记录。

综合运用:


在实际项目开发中使用三层架构操作数据库,而最底层直接操作数据库会将上述所讲的一些基本概念综合运用,这里选择最常用到的两个方法以供参考:

connectionString:数据库连接语句

SQLString:sql语句

//执行查询语句,返回dataset
public static DataSet Query(string strSql)
{
using (SqlConnection conn = new SqlConnection(connectionString))
{
DataSet ds = new DataSet(); try
{
conn.Open();
SqlDataAdapter sqlDataAdapter = new SqlDataAdapter(strSql, conn);
sqlDataAdapter.Fill(ds, "ds");
}
catch (SqlException ex)
{
throw new Exception(ex.Message);
} return ds;
}
}
//执行sql语句,返回影响的记录数
public static int ExecuteSql(string strSql)
{
using (SqlConnection conn = new SqlConnection(connectionString))
{
using (SqlCommand cmd = new SqlCommand(strSql, conn))
{
try
{
conn.Open();
int rows = cmd.ExecuteNonQuery();
return rows;
}
catch (SqlException ex)
{
conn.Close();
throw new Exception(ex.Message);
}
}
}
}

.net数据库操作的更多相关文章

  1. 如何在高并发环境下设计出无锁的数据库操作(Java版本)

    一个在线2k的游戏,每秒钟并发都吓死人.传统的hibernate直接插库基本上是不可行的.我就一步步推导出一个无锁的数据库操作. 1. 并发中如何无锁. 一个很简单的思路,把并发转化成为单线程.Jav ...

  2. 【知识必备】ezSQL,最好用的数据库操作类,让php操作sql更简单~

    最近用php做了点小东东,用上了ezSQL,感觉真的很ez,所以拿来跟大家分享一下~ ezSQL是一个非常好用的PHP数据库操作类.著名的开源博客WordPress的数据库操作就使用了ezSQL的My ...

  3. MySQL 系列(二) 你不知道的数据库操作

    第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 本章内容: 查看\创建\使用\删除 数据库 用户管理及授权实战 局域网 ...

  4. ABP创建数据库操作步骤

    1 ABP创建数据库操作步骤 1.1 SimpleTaskSystem.Web项目中的Web.config文件修改数据库配置. <add name="Default" pro ...

  5. 【第一篇】ASP.NET MVC快速入门之数据库操作(MVC5+EF6)

    目录 [第一篇]ASP.NET MVC快速入门之数据库操作(MVC5+EF6) [第二篇]ASP.NET MVC快速入门之数据注解(MVC5+EF6) [第三篇]ASP.NET MVC快速入门之安全策 ...

  6. django数据库操作和中间件

    数据库配置 django的数据库相关表配置在models.py文件中,数据库的连接相关信息配置在settings.py中 models.py相关相关参数配置 from django.db import ...

  7. [Android Pro] 完美Android Cursor使用例子(Android数据库操作)

    reference to : http://www.ablanxue.com/prone_10575_1.html 完美 Android Cursor使用例子(Android数据库操作),Androi ...

  8. phpcms v9 中的数据库操作函数

    1.查询 $this->select($where = '', $data = '*', $limit = '', $order = '', $group = '', $key='')   返回 ...

  9. Android打造属于自己的数据库操作类。

    1.概述 开发Android的同学都知道sdk已经为我们提供了一个SQLiteOpenHelper类来创建和管理SQLite数据库,通过写一个子类去继承它,就可以方便的创建.管理数据库.但是当我们需要 ...

  10. python之数据库操作

    数据库操作 Python 操作 Mysql 模块的安装 1 2 3 4 5 linux:     yum install MySQL-python   window:     http://files ...

随机推荐

  1. AndFix热修复 —— 实战与源码解析

    当你的应用发布后第二天却发现一个重要的bug要修复,头疼的同时你可能想着赶紧修复重新打个包发布出去,让用户收到自动更新重新下载.但是万事皆有可能,万一隔一天又发现一个急需修复的bug呢?难道再次发布打 ...

  2. 自定义圆形控件RoundImageView并认识一下attr.xml

    今天我们来讲一下有关自定义控件的问题,今天讲的这篇是从布局自定义开始的,难度不大,一看就明白,估计有的同学或者开发者看了说,这种方式多此一举,但是小编我不这么认为,多一种解决方式,就多一种举一反三的学 ...

  3. 基于canvas实现物理运动效果与动画效果(一)

    一.为什么要写这篇文章 某年某月某时某种原因,我在慕课网上看到了一个大神实现了关于小球的抛物线运动的代码,心中很是欣喜,故而写这篇文章来向这位大神致敬,同时也为了弥补自己在运动效果和动画效果制作方面的 ...

  4. 深入理解计算机系统(2.4)---C语言的有符号与无符号、二进制整数的扩展与截断

    开篇请各位猿友允许LZ啰嗦几句,最近一直在写计算机系统原理这系列文章,也已经下定决心要把这本书的内容写完.主要目的其实是为了巩固LZ的理解,另外也想把这些内容分享给猿友们,毕竟LZ觉得这些内容对程序猿 ...

  5. ModernUI教程:目录 (完结)

    入门 My first Modern UI app (manually)                         第一个ModernUI应用(手动编写)(已完成) My first Moder ...

  6. [BZOJ1116][Poi2008]LCO(并查集)

    题目:http://hzwer.com/3010.html 分析:注意这里无向边是对入度没有贡献的. 那么对于一个n个点的连通块而言,如果它是一颗树(n-1条边),那么把所有边全部从某个根开始向下指, ...

  7. SD卡状态广播

    SD状态发生改变的时候会对外发送广播.SD卡的状态一般有挂载.未挂载和无SD卡. 清单文件 一个广播接受者可以接受多条广播.这里在意图过滤器中添加是data属性是因为广播也需要进行匹配的.对方发送的广 ...

  8. android开发------Activity生命周期

    这几天工作比较忙,基本没有什么时间更新播客了. 趁着今晚有点时间,我们来简单说一下什么是Activity生命周期和它们各阶段的特征 什么是生命周期 在还没有接触android开发的时候,听到有人说Ac ...

  9. 顺序队列C/C++实现

    #include <iostream> using namespace std; const int MAXSIZE = 1000; typedef int ELEMTYPE; const ...

  10. 分布式搜索引擎Elasticsearch PHP类封装 使用原生api

    //官方的 php  api写的鸡肋了,下面这个类可以使用 es api 操作. <?php class ElasticSearch { public $index; function __co ...