ADO .Net操作SQL Server数据库

news2025/1/19 8:14:22

//ADO.NET是.NET Framework提供的数据访问服务的类库,应用程序可以使用ADO.NET连接到这些数据源,并检索、处理和更新数据
//常用的数据源包括四种:
1Microsoft SQL Server数据源:使用System.Data.SqlClient名称空间

2OLEDB数据源:使用System.Data.OleDb名称空间

3ODBC数据源:使用System.Data.Odbc名称空间

4Oracle数据源:使用System.Data.OracleClient名称空间

ADO.NET用于访问和处理数据的类库包含以下两个组件:

  • 1.NET Framework 数据提供程序
  • 2DataSet

Microsoft SQL Server .NET Framework数据提供程序:

  • SqlConnection:建立与Microsoft SQL Server数据源的连接
  • SqlCommand:对数据源执行各种SQL命令
  • SqlDataReader:从数据源中抽取数据(只读)
  • SqlDataAdapter:用数据源填充DataSet

//一.SQL Server数据库查询

using (SqlConnection conn = new SqlConnection())
{
    //创建打开连接
    conn.ConnectionString = "";
    conn.Open();

    //创建查询
    SqlCommand cmd1 = new SqlCommand("select id,name from users", conn);

    //执行查询ExecuteReader()
    SqlDataReader sdr = cmd1.ExecuteReader();

    //获取查询结果
    Console.WriteLine($"id\tname");
    if (sdr.Read())
        Console.WriteLine($"{sdr[0]}\t{sdr[1]}");
    sdr.Close();
}

//二.使用ADO.NET在数据库表中 "增删改" 操作的一般步骤为:
//1.先建立数据库连接
//2.然后使用SQL Insert/Update/Delete语句创建命令,
//3.并使用Command 的 Parameters 属性来设置输入参数
//4.最后使用命令的ExecuteNonQuery()方法执行数据库记录插入操作,并根据返回的结果判断插入的结果

using (SqlConnection conn = new SqlConnection())
{
    //创建连接
    conn.ConnectionString = "";
    conn.Open();

    //创建查询
    //SqlCommand cmd_update = new SqlCommand("update users set name = @name where id = @id", conn);
    //SqlCommand cmd_delete = new SqlCommand("delete from users where id = @id", conn);
    SqlCommand cmd_insert = new SqlCommand("insert users(id,name) values(@id,@name)", conn);
    cmd_insert.CommandType = System.Data.CommandType.Text;
    //设置参数
    //方法1
    SqlParameter[] sqlparams = new SqlParameter[2] { new SqlParameter("@id",10), new SqlParameter("@name", "David") } ;
    cmd_insert.Parameters.AddRange(sqlparams);
    //方法2
    cmd_insert.Parameters.Add(new SqlParameter("@id", 10));
    cmd_insert.Parameters.Add(new SqlParameter("@name", "David"));
    //方法3
    cmd_insert.Parameters.AddWithValue("@id", 10);
    cmd_insert.Parameters.AddWithValue("@name", "David");

    //执行查询ExecuteReader()
    int r = cmd_insert.ExecuteNonQuery();

    //获取查询结果
    if(r == 1)
    {
        Console.WriteLine("insert OK");
    }
    else
    {
        Console.WriteLine("insert failed");
    }
}


//三.使用DataAdapter和DataSet访问数据库
//使用DataAdapter和DataSet访问数据库的典型步骤如下:
//(1)建立数据库连接
//(2)创建DataAdapter, 从DataAdapter填充DataSet
//(3)操作和处理DataSet
//(4)使用DataAdapter更新数据源


using (SqlConnection con = new SqlConnection("conn string"))
{
    //打开数据库连接
    con.Open();

    //DataAdapter用于从数据源检索数据并填充DataSet中的表(select command),
    //DataAdapter还将对DataSet的更改解析回数据源(InsertCommand、UpdateCommand或DeleteCommand)
    //创建DataAdapter,明确connection和command
    SqlDataAdapter sda = new SqlDataAdapter();
    sda.InsertCommand = new SqlCommand("Insert sql", con);
                
    //创建dataset对象
    DataSet ds = new DataSet("Users_ds");

    //从DataAdapter填充到DataSet
    //DataAdapter的Fill方法使用DataAdapter的SelectCommand的结果集来填充DataSet
    //Fill方法使用DataReader对象隐式的返回用于在DataSet上创建的表以及用于填充DataSet中的数据
    sda.Fill(ds);

    //操作和处理dateset
    Console.WriteLine($"id\tname");
    foreach (DataRow dr in ds.Tables["Users_ds"].Rows) 
    {
        Console.WriteLine($"dr[0]\tdr[1]");
    }
    //更新datesheet中第一行的指定字段数据
    ds.Tables[0].Rows[0]["name"] = "LittleStone";

    //将dateset数据更新到数据库
    sda.Update(ds);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1515228.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

力扣27. 移除元素

思路:数组的空间是连续的,没办法删除,所以只能是覆盖; 把有用的元素排上来之后,剩下的空间放什么元素可以直接忽视,然 后我们只需要返回新数组中长度即可; 快慢指针法:我们需要新建两…

数据仓库的基本概念、基本特征、体系结构

个人看书学习心得及日常复习思考记录,个人随笔。 数据仓库的基本概念、基本特征 数据仓库的定义:数据仓库是一个面向主题的、集成的、不可更新的、随时间不断变化的数据集合,用以更好地支持企业或组织的决策分析处理。 数据仓库中数据的4个…

[LeetCode][LCR169]招式拆解 II——巧妙利用字母的固定顺序实现查找复杂度为O(1)的哈希表

题目 LCR 169. 招式拆解 II 某套连招动作记作仅由小写字母组成的序列 arr,其中 arr[i] 第 i 个招式的名字。请返回第一个只出现一次的招式名称,如不存在请返回空格。 示例 1: 输入:arr "abbccdeff" 输出:a…

基于SSM的协同过滤算法的电影推荐系统(有报告)。Javaee项目。ssm项目。

演示视频: 基于SSM的协同过滤算法的电影推荐系统(有报告)。Javaee项目。ssm项目。 项目介绍: 采用M(model)V(view)C(controller)三层体系结构,通…

LDA主题模型学习笔记

(1)LDA的基本介绍(wiki) LDA是一种典型的词袋模型,即它认为一篇文档是由一组词构成的一个集合,词与词之间没有顺序以及先后的关系。一篇文档可以包含多个主题,文档中每一个词都由其中的一个主题…

软考高级:信息系统开发方法2(形式化方法、统计过程方法等)概念和例题

作者:明明如月学长, CSDN 博客专家,大厂高级 Java 工程师,《性能优化方法论》作者、《解锁大厂思维:剖析《阿里巴巴Java开发手册》》、《再学经典:《Effective Java》独家解析》专栏作者。 热门文章推荐&am…

前端学习笔记 | WebAPIs(DOM+BOM)

一、作用和分类 1、基本概念 作用:使用JS去操作HTML和浏览器 分类:DOM(文档对象模型)和BOM(浏览器对象模型) html的标签JS的DOM对象 2、获取DOM对象-参数必须加引号 (1)选择匹配的第…

计算机三级错题整理

计算机三级整理 注意事项 第二道大题1.(第二套)2.(第四套真题)3.三十一套 第三道大题1.(第一套真题)2.(第二份真题)3.(第四套真题)4.二十九套5.三十套6.三十三…

《智能便利,畅享便利柜平台的架构奇妙之旅》

便利柜平台作为一种智能化、便捷的自助服务解决方案,正在逐渐走进人们的生活。本篇博客将深入探讨便利柜平台的架构设计理念、优势和实践,帮助读者了解如何构建智能便利柜平台,提供更便捷的自助服务体验。 ### 便利柜平台架构设计 #### 1. …

UE4案例记录

UE4案例记录(制作3D角色显示在UI中) 制作3D角色显示在UI中 转载自youtube视频 https://www.youtube.com/channel/UCC8f6SxKJElVvaRb7nF4Axg 新建项目 创建一个Actor 场景组件->摄像机组件->场景捕获组件2D,之后添加一个骨骼网格体…

Python基础课堂最后一课23——正则对象

文章目录 前言一、正则对象是什么?二、正则表达式基本分类1.普通字符2.元字符 总结 前言 很开心能和你们一些学习进步,在这一个多月的时间中,是你们让我坚持了下来,完成了python基础课堂编写,不管如何,我们…

ubuntu 23.04 安装 中文输入法

1、安装 fcitx sudo apt install fcitxfcitx 安装好后,可以使用 fcitx-configtool 命令进行配置,其界面如下所示。在这里可以配置不同输入法的切换快捷键,默认输入法等。刚安装系统后,这里只有一个输入法,所以接下来要…

SORA和大语言模型的区别

OpenAI的文生视频模型SORA与大语言模型(LLM)的主要区别在于它们的应用领域和处理的数据类型,数据处理能力、技术架构、多模态能力和创新点。SORA作为一款专注于视频生成的模型,展现了在处理视觉数据方面的独特优势和创新能力。 1…

HttpContext请求接收上下文模块设计与实现(http模块四)

目录 类功能 类定义 类实现 编译测试 类功能 类定义 // HttpContext接收请求上下文模块功能设计 typedef enum {RECV_HTTP_ERROR,RECV_HTTP_LINE,RECV_HTTP_HEAD,RECV_HTTP_BODY,RECV_HTTP_OVER } HttpRecvStatu;class HttpContext { private:int _resp_statu; …

刷题日记——反转公约数、循环位移(厦门大学机试)

题目 分析 将输入的数字看作字符串&#xff0c;然后将字符串转成真实值计算两个真实值&#xff0c;然后从1开始遍历公约数&#xff0c;每次发现一个更大的公约数就替换&#xff0c;直到找不到公约数 代码 #include <cstdio> #include <map> #include <string…

Redis第8讲——Cluster集群模式详解

前面两篇文章介绍了Redis主从和哨兵模式&#xff0c;不难发现&#xff0c;它们都有一些共同的缺点&#xff0c;首先在主从切换的过程中会丢失数据&#xff1b;另一个就是只有一个master&#xff0c;只能单点写&#xff0c;并没有水平扩容能力。而且每个节点都保存了所有的数据&…

请说一下卷积神经网络里的特征图和感受野怎么计算?VGG网络的特点?如何解释?

请说一下卷积神经网络里的特征图和感受野怎么计算&#xff1f; 特征图的计算 首先要明确什么是特征图&#xff1f; 特征图是卷积层输出的二维数组&#xff0c;每个元素表示一个特定区域的特征。特征图的大小取决于输入图像的大小、卷积核的大小、步幅&#xff08;stride&…

专升本 C语言笔记-08 goto语句

goto语句 无条件跳转运算符(凡是执行到goto语句会直接跳转到 定义的标签) 缺点&#xff1a;滥用goto语句将会导致逻辑混乱&#xff0c;导致系统崩溃等问题! ! ! 代码演示 int i 0; //定义标签 jump(名字随便起哦) jump:printf("%d ",i); i; if(i < 10)goto j…

JS高级_数据类型

undefined与null的区别? undefined代表没有赋值null代表赋值了, 只是值为null // 1. undefined与null的区别?var a1var a2 nullconsole.log(a1, a2)什么时候给变量赋值为null呢? var a null //已经确定a是一个对象, 但还没具体赋值&#xff08;开始&#xff09;a null …

软考高级:系统工程方法(霍尔三维结构、切克兰德方法等)概念和例题

作者&#xff1a;明明如月学长&#xff0c; CSDN 博客专家&#xff0c;大厂高级 Java 工程师&#xff0c;《性能优化方法论》作者、《解锁大厂思维&#xff1a;剖析《阿里巴巴Java开发手册》》、《再学经典&#xff1a;《Effective Java》独家解析》专栏作者。 热门文章推荐&am…