从C#中连接到SQL Server数据库,再通过C#编程实现SQL数据库的增删改查。

ado.net提供了丰富的数据库操作,这些操作可以分为三个步骤:

  • 第一,使用SqlConnection对象连接数据库;
  • 第二,建立SqlCommand对象,负责SQL语句的执行和存储过程的调用;(在使用适配器查找记录时不用建立sqlcommand对象)
  • 第三,对SQL或存储过程执行后返回的“结果”进行操作。对结果的操作分为两种,一种为SqlDataReader一行一行读取数据集,另一种为DataSet联合SqlDataAdapter读取数据集。

1.打开连接通道:

        #region 打开连接通道
/// <summary>
///1.连接通道的连接字符串
///2.连接通道对象
///3.打开通道
///4.关闭通道
/// </summary>
public static void OpenConnection()
{
//1.连接通道的连接字符串
string conStr = "server=192.168.1.100;database=JNU;uid=sa;pwd=123456aa;";//指定哪台服务器
//2.连接通道对象
SqlConnection conn = new SqlConnection(conStr);
//3.打开通道
conn.Open();
//4.关闭通道
conn.Close();
Console.WriteLine("连接对象新建操作成功");
}
#endregion

2.增加记录

        #region 增加记录
/// <summary>
/// 增加记录
/// </summary>
public static void AddRecord()
{
int res = -;//准备比接受新增受影响的行数
string conStr = "server=192.168.1.100;database=JNU;uid=sa;pwd=123456aa;";
//1.新建连接通道
SqlConnection conn = new SqlConnection();
//2.手动指定连接字符串
conn.ConnectionString = conStr;
//3.准备新增的sql命令
string sqlStr = "insert into TEST(NAME) values('SHUAI')";
//4.新建命令对象,并且告诉他走那条路(conn),做什么事('sqlStr')单引号一定要加
SqlCommand cmd = new SqlCommand(sqlStr, conn);
//5.打开连接通道
conn.Open();
//6.调用方法去数据库执行sql语句
res = cmd.ExecuteNonQuery();//此方法负责增删改,返回受影响的行数(int),开始进入数据库进行操作
//7.关闭连接通道
conn.Close();
if (res > )
{
Console.WriteLine("新增成功");
}
else
{
Console.WriteLine("新增失败");
}
}
#endregion

3.删除记录和更改记录(软删除)与新增记录的代码相同,只有SQL语句不一样,其SQL语句为

            //3.准备删除的sql命令
string sqlStr = "delete from TEST where ID=8";
//3.准备修改的sql命令
string sqlStr = "update TEST set NAME='qiang' where ID=7";

4.查询单个值时,使用的是命令对象SqlCommand进行查询

        #region 查询单个值
/// <summary>
/// 查询单个值
/// </summary>
public static void QuerySingle()
{
SqlConnection conn = new SqlConnection(conStr);
// string sqlStr = "select count(*) from TEST";
string sqlStr = "select * from TEST";
SqlCommand cmd = new SqlCommand(sqlStr, conn);
conn.Open();
//调用此方法,获得查询语句在数据库执行后得到的结果集的第一个单元格的值,返回类型为object
object obj = cmd.ExecuteScalar();
conn.Close();
Console.WriteLine(obj.ToString()); }
#endregion

5.读取器查询多行数据,逐行读取,通过下标访问数据,还可以通过列名和get方法访问数据

        #region 读取器查询多行数据,逐行读取,通过get方法访问数据
/// <summary>
/// 查询多行数据——DataReader,逐行读取
/// </summary>
public static void QueryListByGet()
{
SqlConnection conn = new SqlConnection(conStr);
string sqlStr = "select * from TEST";
SqlCommand cmd = new SqlCommand(sqlStr, conn);
conn.Open();
//调用此方法,获得一个读取器对象,SqlDataReader不能实例化
SqlDataReader dr = cmd.ExecuteReader();
//if (dr.HasRows)//判断有无数据
//{
// Console.WriteLine("有数据");
//}
//else
//{
// Console.WriteLine("无数据");
//}
if (dr.HasRows)
{
//每调用一次read,读取一行数据
while (dr.Read())//read方法,如果读到下一行数据,则返回true,而且dr本身就等于哪一行数据
{
//读取第一列的数据
//Console.WriteLine(dr[0].ToString());//通过下标访问数据,数组下标从0开始
//Console.WriteLine(dr["ID"].ToString());//通过列名访问数据,以结果集的列名作为标志,可以避免as为别名后的查询错误
Console.WriteLine(dr.GetString());//通过get访问数据,数组下标从0开始,只能用于char类型的变量,不能获取int类型的数据
Console.WriteLine(dr.GetInt32());//只能获取int类型
Console.WriteLine(dr.GetValue().ToString());//以object的方式拿出数据
dr.GetOrdinal("ID");//传入列名,获得列的下标 }
}
else
Console.WriteLine("无数据");
//先关闭读取器,再关闭连接通道
dr.Close();
conn.Close();
}
#endregion

6.适配器查询多行数据

        #region 适配器查询多行数据
/// <summary>
/// 使用适配器读取数据,不需要代码手动打开、关闭连接通道
/// </summary>
public static void QueryListByAdapter()
{
SqlConnection conn = new SqlConnection(conStr);
string sqlStr = "select * from TEST";
//创建适配器对象(SqlDataAdapter),告诉他做什么事(sqlStr),走哪条路(conn)
SqlDataAdapter sqlda = new SqlDataAdapter(sqlStr, conn);
//创建数据集对象(程序端的临时数据库)
DataSet ds = new DataSet();
//调用fill方法,添加数据到数据集。(先去数据库查询结果集,并把结果集返回赋值给数据集)
sqlda.Fill(ds);//开始进入数据库进行操作
DataTable dt = ds.Tables[];//获得数据集中的第一张表(数据集可以存放多张表)
for (int i = ; i < dt.Rows.Count; i++)//循环该表中的每一行,dt.Rows为获取该数据表的行集合
{
DataRow dr = dt.Rows[i];//dr对象获取表中的当前行
Console.WriteLine(dr[].ToString());//通过索引的方式读某一列的值
Console.WriteLine(dr["ID".ToString()]);//通过列名的方式读列
}
}
#endregion

2018.08.12

新手C#SQLServer在程序里实现语句的学习2018.08.12的更多相关文章

  1. (转)新手C#SQL语句的学习2018.08.13

    1.创建数据库(create) CREATE DATABASE database-name 2.删除数据库(drop) drop database dbname 3.备份数据库 --- 创建 备份数据 ...

  2. 新手C#异常的学习2018.08.07

    异常是在程序执行期间出现的问题.C# 中的异常是对程序运行时出现的特殊情况的一种响应,比如尝试除以零. class Program { static void Main(string[] args) ...

  3. 新手C#构造函数、继承、组合的学习2018.08.06/07

    构造函数,是一种特殊的方法.主要用来在创建对象时初始化对象,即为对象成员变量赋初始值,总与new运算符一起使用在创建对象的语句中.特别的一个类可以有多个构造函数,可根据其参数个数的不同或参数类型的不同 ...

  4. 新手C#面向对象的学习2018.08.06

    class Person//声明一个Person类 { //类中的声明与Main中不同,类中声明的是字段而不是函数. public string gender; public string name= ...

  5. 新手C#s.Split(),s.Substring(,)以及读取txt文件中的字符串的学习2018.08.05

    s.split()用于字符串分割,具有多种重载方法,可以通过指定字符或字符串分割原字符串成为字符串数组. //s.Split()用于分割字符串为字符串数组,StringSplitOptions.Rem ...

  6. 新手C#int.Parse、int.TryParse的学习2018.08.04

    int.Parse()用于将字符串转换为32为int类型,但是在遇到非数字或者类似1.545这种小数的时候会报错,后来采用了int.TryParse,这个在转换后会判断是否可以正常转换,若不能,会返回 ...

  7. [转帖]召冠总的 SQLSERVER常用的性能诊断语句. --保存学习备查

    CopyFrom https://www.cnblogs.com/zhaoguan_wang /*常规服务器动态管理对象包括:dm_db_*:数据库和数据库对象dm_exec_*:执行用户代码和关联的 ...

  8. 新手C#类、对象、字段、方法的学习2018.08.05

    类:具有相似属性和方法的对象的集合,如“人”是个类. 对象(实例):对象是具体的看得见摸得着的,如“张三”是“人”这个类的对象.(new Person()开辟了堆空间中,=开辟了栈空间,变量P存放在该 ...

  9. 新手C#string类常用函数的学习2018.08.04

    ToLower()用于将字符串变为小写,注意字符串的不可变特性,需要重新赋值给另一个字符串变量. s = s.ToLower();//字符串具有不可变性,转换后需要重新赋值,不可仅有s.ToLower ...

随机推荐

  1. Linq快速入门——扩展方法

    Linq为我们提供了许多扩展方法,方便我们对数据源进行操作(Where,Select...).即使你不了解算法,也能使用Linq当回牛人.扩展方法本质并不是什么高深的技术,说白了就是一个Static静 ...

  2. TraceView 使用详解 android eclipse

    先看命令 (配置好环境变量的情况下,直接traceview+空格+ trace文件路径即可): TraceView是什么 Traceview是android平台配备一个很好的性能分析的工具.它可以通过 ...

  3. HDU 2066 一个人的旅行 (Dijkstra算法)

    一个人的旅行 Time Limit : 1000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Submis ...

  4. 学习笔记之Kubernetes

    Kubernetes | Production-Grade Container Orchestration https://kubernetes.io/ Kubernetes is an open-s ...

  5. Find substring with K distinct characters

    Given a string and number K, find the substrings of size K with K distinct characters. If no, output ...

  6. [UE4]通过代码改变材质

    OrangeMaterial = ConstructorStatics.OrangeMaterial.Get(); , OrangeMaterial); 使用到的结构体如下: struct FCons ...

  7. select count(*) as total from(select count(*) from tab_cb_casim group by `card_no`) as cai;

    子查询必须加一个别名才能执行!!

  8. Thread 1 cannot allocate new log的问题分析 (转载)

    Thread 1 cannot allocate new log的问题分析 发生oracle宕机事故,alert文件中报告如下错误: Fri Jan 12 04:07:49 2007Thread 1 ...

  9. Linux下Nagios的安装与配置 及遇到的坑

    原文http://www.jianshu.com/p/7bc822fa8278 不愿意看前5.6c部分可以直接跳到最后看命令. 一.Nagios简介 Nagios是一款开源的电脑系统和网络监视工具,能 ...

  10. 搭建pyspider爬虫服务

    1. 环境准备 首先yum更新 yum update -y 安装开发编译工具 yum install gcc gcc-c++ -y 安装依赖库 yum install python-pip pytho ...