C#语言的数据库编程
C#语言的数据库编程
在现代软件开发中,数据库是不可或缺的一部分。无论是企业级应用还是个人项目,数据的存储与管理都是程序的核心功能之一。C#作为一种强类型、面向对象的编程语言,广泛应用于Windows平台的开发,尤其是在构建与数据库交互的应用时,其强大的功能和丰富的库支持使得开发变得相对容易。本文将深入探讨C#语言的数据库编程,覆盖基础知识、ADO.NET、Entity Framework等核心概念以及一些实用示例。
一、C#与数据库编程的基础
在开始数据库编程之前,首先要了解一些基础概念:
1. 数据库的基本组成
数据库通常由以下几个部分组成:
- 表:数据库中存储数据的核心单位,表由行和列组成。
- 行:表中的一条记录,表示一个具体的数据项。
- 列:表中的一个字段,定义了数据项的属性。
- 主键:唯一标识表中每一行的字段,确保数据的唯一性。
- 外键:用于在不同表之间建立联系的字段。
2. 数据库管理系统(DBMS)
常见的数据库管理系统包括:
- 关系型数据库:如SQL Server、MySQL、PostgreSQL、Oracle等。
- 非关系型数据库:如MongoDB、Redis等。
本文主要集中于关系型数据库的编程,从而使用C#与SQL Server进行交互。
二、ADO.NET入门
ADO.NET是用于与数据源进行交互的核心组件,提供了全面的功能,用于数据访问、更新和管理。
1. ADO.NET的组成
ADO.NET的核心组件包括:
- Connection:表示与数据库的连接。
- Command:用于执行数据库命令(如查询和更新)。
- DataReader:用于从数据库中读取数据的高效方式。
- DataSet:用于在内存中保存数据的容器,可以看作是多个DataTable的集合。
2. 连接数据库
在使用C#进行数据库编程时,第一步通常是创建与数据库的连接。下面是一个简单的示例,展示如何使用SqlConnection连接到SQL Server数据库。
```csharp using System; using System.Data.SqlClient;
class Program { static void Main() { // 连接字符串 string connectionString = "Server=myServerAddress;Database=myDataBase;User Id=myUsername;Password=myPassword;";
using (SqlConnection connection = new SqlConnection(connectionString)){try{// 打开连接connection.Open();Console.WriteLine("数据库连接成功!");}catch (Exception ex){Console.WriteLine("数据库连接失败: " + ex.Message);}}
}
} ```
3. 执行命令
连接成功后,我们可以使用SqlCommand执行SQL命令。以下示例演示了如何查询数据:
```csharp using System; using System.Data.SqlClient;
class Program { static void Main() { string connectionString = "Server=myServerAddress;Database=myDataBase;User Id=myUsername;Password=myPassword;";
using (SqlConnection connection = new SqlConnection(connectionString)){connection.Open();string sqlQuery = "SELECT * FROM Users";using (SqlCommand command = new SqlCommand(sqlQuery, connection)){SqlDataReader reader = command.ExecuteReader();while (reader.Read()){Console.WriteLine($"用户ID: {reader["UserId"]}, 用户名: {reader["UserName"]}");}}}
}
} ```
三、数据操作
1. 插入数据
要向数据库插入数据,我们可以使用INSERT语句。以下是插入用户数据的示例代码:
```csharp using System; using System.Data.SqlClient;
class Program { static void Main() { string connectionString = "Server=myServerAddress;Database=myDataBase;User Id=myUsername;Password=myPassword;";
using (SqlConnection connection = new SqlConnection(connectionString)){connection.Open();string insertQuery = "INSERT INTO Users (UserName) VALUES (@UserName)";using (SqlCommand command = new SqlCommand(insertQuery, connection)){command.Parameters.AddWithValue("@UserName", "新用户");int rowsAffected = command.ExecuteNonQuery();Console.WriteLine($"{rowsAffected} 行被插入。");}}
}
} ```
2. 更新数据
更新数据的方式与插入相似,只需使用UPDATE语句:
```csharp using System; using System.Data.SqlClient;
class Program { static void Main() { string connectionString = "Server=myServerAddress;Database=myDataBase;User Id=myUsername;Password=myPassword;";
using (SqlConnection connection = new SqlConnection(connectionString)){connection.Open();string updateQuery = "UPDATE Users SET UserName = @NewName WHERE UserId = @UserId";using (SqlCommand command = new SqlCommand(updateQuery, connection)){command.Parameters.AddWithValue("@NewName", "更新后的用户");command.Parameters.AddWithValue("@UserId", 1); // 假设要更新的用户ID为1int rowsAffected = command.ExecuteNonQuery();Console.WriteLine($"{rowsAffected} 行被更新。");}}
}
} ```
3. 删除数据
删除数据使用DELETE语句,例如:
```csharp using System; using System.Data.SqlClient;
class Program { static void Main() { string connectionString = "Server=myServerAddress;Database=myDataBase;User Id=myUsername;Password=myPassword;";
using (SqlConnection connection = new SqlConnection(connectionString)){connection.Open();string deleteQuery = "DELETE FROM Users WHERE UserId = @UserId";using (SqlCommand command = new SqlCommand(deleteQuery, connection)){command.Parameters.AddWithValue("@UserId", 1); // 假设要删除的用户ID为1int rowsAffected = command.ExecuteNonQuery();Console.WriteLine($"{rowsAffected} 行被删除。");}}
}
} ```
四、使用Entity Framework
ADO.NET虽然功能强大,但在处理复杂的数据操作时,手动的代码可能会变得繁琐。Entity Framework(EF)作为一个对象关系映射(ORM)框架,提供了更高层次的抽象,使得数据库操作更加简洁和直观。
1. 安装Entity Framework
通过NuGet包管理器安装Entity Framework:
bash Install-Package EntityFramework
2. 创建数据模型
定义一个代表数据表的模型类。例如,一个用户类可以如下定义:
csharp public class User { public int UserId { get; set; } public string UserName { get; set; } }
3. 创建数据库上下文
创建一个数据库上下文类,用于与数据库交互:
```csharp using System.Data.Entity;
public class MyDbContext : DbContext { public DbSet Users { get; set; } } ```
4. CRUD操作示例
使用Entity Framework进行CRUD操作十分简单。以下是一个简单的示例:
```csharp using System; using System.Linq;
class Program { static void Main() { using (var context = new MyDbContext()) { // 插入数据 var newUser = new User { UserName = "新用户" }; context.Users.Add(newUser); context.SaveChanges(); Console.WriteLine("用户已插入。");
// 查询数据var user = context.Users.FirstOrDefault(u => u.UserId == newUser.UserId);Console.WriteLine($"查询到用户: {user.UserName}");// 更新数据user.UserName = "更新后的用户";context.SaveChanges();Console.WriteLine("用户已更新。");// 删除数据context.Users.Remove(user);context.SaveChanges();Console.WriteLine("用户已删除。");}
}
} ```
五、总结
本文探讨了C#语言在数据库编程中的应用,介绍了ADO.NET的基本概念和使用方法,以及如何利用Entity Framework简化数据库操作。通过示例代码,演示了常见的数据库操作:连接、查询、插入、更新和删除。在实际开发中,还可以根据业务需求进行扩展和优化,更好地利用数据库的性能。
未来的数据库编程中,随着大数据和云计算的发展,可能会有更多的技术和工具涌现,而C#作为一门灵活的语言,将持续发挥其作用。无论是传统关系数据库还是新兴的非关系数据库,了解其基本原理与操作方法,将拓宽开发者的技术视野。
希望本文能够帮助读者更好地理解和掌握C#的数据库编程技能,为实际项目的开发打下坚实的基础。
相关文章:
C#语言的数据库编程
C#语言的数据库编程 在现代软件开发中,数据库是不可或缺的一部分。无论是企业级应用还是个人项目,数据的存储与管理都是程序的核心功能之一。C#作为一种强类型、面向对象的编程语言,广泛应用于Windows平台的开发,尤其是在构建与数…...
时频分析之S变换
S变换的提出 1996年,由R.G Stockwell 提出了S变换,和其他时频分析工具一样,通过S变换,我们可以同时从时域以及频域观察一个信号的能量分布。S变换融合了短时傅里叶变换和小波变换的优点。关于S变换,最早发表于TSP上的…...
第二十八周学习周报
目录 摘要Abstract1 GFPGAN1.1 总体结构1.2 实验研究1.3 代码分析 总结 摘要 本周主要的学习内容是GFPGAN模型。GFPGAN是一种基于生成对抗网络(GAN)的模型,其利用封装在预训练的人脸GAN中的丰富多样的先验进行人脸图像的修复。这种生成面部先验(GFP&…...
SurfaceFlinger MessageQueue原理
SurfaceFlinger MessageQueue 有2个作用: 处理SurfaceFlinger INVALIDATE、REFRESH事件管理SurfaceFlinger主线程挂起和恢复 SurfaceFlinger::run() { while (true) { mEventQueue->waitMessage(); } } waitMessage {do {IPCThreadState::self()->flushComm…...
component-动态控制 div width 的值 根据传入的变量决定width的值 vue
1.实现 根据参数的值,div显示不同的长度 <div class"node-line" :style"lineProgress"></div> <script>export default {name: "trainSummaryInfo",data(){return{linePercentage:200,}},computed:{lineProgress…...
C#中的常用集合
目录 一、动态数组ArrayList 二、List 三、栈(Stack) 四、队列(Queue) 五、字典(Dictionary),int> 一、动态数组ArrayList ArrayList 是 C# 中提供的一种动态数组类,位于命名空间 Syste…...
插入实体自增主键太长,mybatis-plaus自增主键
1、问题 spring-boot整合mybtais执行insert语句时,主键id为长文本数据。 2、分析问题 1)数据库主键是否自增 2)数据库主键的种子值设置的多少 3、解决问题 1)数据库主键设置的时自增 3)种子值是1 所以排查是数据库的问题 4、继…...
晨辉面试抽签和评分管理系统之一:考生信息管理和编排
晨辉面试抽签和评分管理系统(下载地址:www.chenhuisoft.cn)是公务员招录面试、教师资格考试面试、企业招录面试等各类面试通用的考生编排、考生入场抽签、候考室倒计时管理、面试考官抽签、面试评分记录和成绩核算的面试全流程信息化管理软件。提供了考生…...
【MySQL】MVCC详解, 图文并茂简单易懂
欢迎来到啊妮莫的学习小屋 祝读本文的朋友都天天开心呀 目录 MVCC简介快照读与当前读快照读当前读 隔离级别隐藏字段和Undo Log版本链✨MVCC原理--ReadView✨ReadView简介设计思路适用隔离级别重要内容 ReadView规则MVCC整体流程 不同隔离级别下的MVCC读已提交可重复读 总结 M…...
中国数字化发展的问题与机会
橙蜂智能公司致力于提供先进的人工智能和物联网解决方案,帮助企业优化运营并实现技术潜能。公司主要服务包括AI数字人、AI翻译、埃域知识库、大模型服务等。其核心价值观为创新、客户至上、质量、合作和可持续发展。 橙蜂智农的智慧农业产品涵盖了多方面的功能,如智能化推荐、…...
【ROS2】☆ launch之Python
☆重点 ROS1和ROS2其中一个很大区别之一就是launch的编写方式。在ROS1中采用xml格式编写launch,而ROS2保留了XML 格式launch,还另外引入了Python和YAML 编写方式。选择哪种编写取决于每位开发人员的爱好,但是ROS2官方推荐使用Python方式编写…...
如何稳定使用 O1 / O1 Pro,让“降智”现象不再困扰?
近期,不少朋友在使用 O1 或 O1 Pro 模型时,都会碰到“降智”或“忽高忽低”的智力波动,比如无法识图、无法生成图片、甚至回答准确度也不稳定。面对这些问题,你是不是也感到头疼呢? 为了找到更可靠的解决办法…...
zookeeper监听机制(Watcher机制)
文章目录 引言I zookeeper监听机制Watcher机制实现分布式的通知功能触发事件种类Watcher的三个过程II watch机制特点一次性触发事件封装event异步发送先注册再触发常见的通知状态和事件类型III 应用案例(Kafka)Kafka的消息模型Kafka在Zookeeper中保存的元数据Kafka 基于Contr…...
docker 启动 nacos 单机模式
docker 启动 nacos 单机模式 # 拉取镜像# 启动,如果不拉镜像会自动拉取最新的 image docker run --name standalong_nacos -p 8848:8848 -p 9848:9848 -p 9849:9849 -e MODEstandalone -d nacos/nacos-server# 状态查看外部访问验证 输入部署的 docker ip 地址以及…...
学习threejs,导入babylon格式的模型
👨⚕️ 主页: gis分享者 👨⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨⚕️ 收录于专栏:threejs gis工程师 文章目录 一、🍀前言1.1 ☘️THREE.BabylonLoader babyl…...
03.MPLS静态LSP配置实验
MPLS静态LSP配置实验 1、实验环境2、基础配置开启全局mpls接口下开启mpls配置静态LSP配置FEC从1.1.1.1到3.3.3.3配置FEC从3.3.3.3到1.1.1.13、信息查看查看LFIB表(标签转发信息表)查看FIB表(转发信息表)查看详细FFIB表tracert lsp iptracert -vping lsp ip4、抓包验证1、实…...
程序血缘分析技术在工商银行软件工程中的应用
当前,随着软件领域技术更新换代速度的日益加快,市场需求也变得更加多样化和个性化,业界普遍通过加速产品迭代来满足客户需求,但在此过程中也暴露出一些研发管理痛点问题,如服务和程序类资产信息分散于各个不同的应用和系统中,信息归集费时费力;设计、开发和测试人员无法…...
计算机毕业设计Django+Tensorflow音乐推荐系统 音乐可视化 卷积神经网络CNN LSTM音乐情感分析 机器学习 深度学习 Flask 大
温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…...
macOS 使用 FreeRDP 远程访问 Windows:完整指南20250109
🖥️ macOS 使用 FreeRDP 远程访问 Windows:完整指南 引言 随着远程办公需求的快速增长,跨平台远程管理已经成为不可或缺的技能之一。作为一款开源轻量的远程桌面协议实现工具,FreeRDP 为 macOS 用户提供了一个简单、高效的解决…...
Java agent
Java Agent是一种特殊的Java程序,它可以在JVM启动时或运行时动态加载,用于监控和修改其他Java应用程序的行为。通过Java Agent,开发者可以在不修改目标应用程序源码的情况下,动态地插入功能,如性能分析、日志记录…...
分切机程序开发:上下收放卷张力控制实现
分切机程序 ,上下收放卷张力控制,无电子凸轮功能。 触摸屏威纶通,PLC是三菱FX3U系列 在自动化生产领域,分切机的稳定运行至关重要,尤其是上下收放卷张力的精准控制。本文将探讨基于威纶通触摸屏和三菱FX3U系列PLC&…...
客户决策链地图怎么画:老板、采购、技术、项目、法务分别怎么看你
在很多B2B企业的表达体系里,“客户”这个词经常被用得过于整齐。 官网会写“服务行业客户”,销售会说“面向大型企业”,PPT会写“解决复杂需求”。这些话都没问题,但它们通常默认一个前提:客户像一个人一样在决策。而真…...
JBoltAI Agent OS:企业AI转型的“智慧管家”
在AI技术席卷全球的浪潮中,企业如何高效管理员工手中的AI Agent,确保其既助力业务又不失控?JBoltAI Agent OS应运而生,它如同一位“智慧管家”,为企业提供了一套集中式的Agent治理与转型管理方案。一、为何需要企业级A…...
rabbitmq新手福音,快马ai生成带详解注释的入门代码,轻松理解消息队列
RabbitMQ新手入门:从零开始理解消息队列 最近在学习消息队列技术,发现RabbitMQ作为最流行的开源消息代理之一,对于新手来说概念确实有点抽象。不过通过InsCode(快马)平台的帮助,我很快就能上手实践了。下面分享我的学习过程&…...
用MATLAB FFT手把手教你分析NRZ、2ASK、2FSK、2PSK信号的频谱(附完整代码)
MATLAB FFT实战:从零解析NRZ/2ASK/2FSK/2PSK信号频谱特性 通信仿真中频谱分析就像医生的听诊器,能让我们"听见"信号最本质的特征。但很多初学者面对FFT频谱图时,常陷入三个典型困惑:为什么我的频谱图与教材理论对不上&a…...
Phi-4-mini-reasoning部署指南:多模型共存时GPU显存隔离与服务端口分配
Phi-4-mini-reasoning部署指南:多模型共存时GPU显存隔离与服务端口分配 1. 项目概述 Phi-4-mini-reasoning是微软推出的3.8B参数轻量级开源模型,专为数学推理、逻辑推导和多步解题等强逻辑任务设计。这个模型主打"小参数、强推理、长上下文、低延…...
PADS Layout VX.1.2设计规则全解析:从安全间距到布线优化的实战技巧
PADS Layout VX.1.2设计规则全解析:从安全间距到布线优化的实战技巧 在高速PCB设计领域,规则约束如同交通信号灯般重要——它们决定了电流的"通行权"和"避让规则"。作为Mentor Graphics旗下的经典工具,PADS Layout VX.1…...
OpCore-Simplify终极指南:15分钟完成黑苹果EFI配置的智能工具
OpCore-Simplify终极指南:15分钟完成黑苹果EFI配置的智能工具 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 黑苹果配置一直是技术爱好者…...
Matlab实现不等间距数据可视化:自定义colorbar与尖角设计技巧
1. 不等间距数据可视化的核心挑战 处理不等间距数据时,常规的colorbar会面临两个典型问题:一是默认的等距色阶无法准确反映数据分布特征,二是极端值区域的标识不够直观。我在分析气象数据时就遇到过这种情况——当降水量的数值范围从0.1mm跨…...
硬件狗狗全方位硬件监控:实时掌握电脑运行状态
对于电脑用户来说,了解硬件的运行状态是非常重要的。 通过监控硬件的使用情况,用户可以及时发现问题,避免硬件过载,还可以优化系统的性能。 硬件狗狗在这方面提供了全面而实用的功能,帮助用户实时掌握电脑的运行状态…...
