C#中使用LINQtoSQL管理SQL数据库之添加、修改和删除

目录

一、添加数据

二、修改数据

三、删除数据 

四、添加、修改和删除的源码

五、生成效果

1.VS和SSMS原始记录

2.删除ID=2和5的记录

3.添加记录ID=2、5和8

 4.修改ID=3和ID=4的记录 


        用LINQtoSQL管理SQL Server数据库时,主要有添加、修改和删除3种操作。

        项目中创建LINQtoSQL类的方法已经在本文作者的其他文章中有过叙述,此处不再赘述。

一、添加数据

        使用LINQ向SQL Server数据库中添加数据时,需要使用InsertOnSubmit()方法和SubmitChanges()方法。其中,InsertOnSubmit()方法用来将处于pending insert状态的实体添加到SQL数据表中,其语法格式如下:

void InsertOnSubmit(Object entity) 
其中,entity表示要添加的实体。

        SubmitChanges()方法用来记录要插入、更新或删除的对象,并执行相应命令以实现对数据库的更改,其语法格式如下:

public void SubmitChanges()

二、修改数据

         使用LINQ修改SQL Server数据库中的数据时,需要用SubmitChanges()方法。

三、删除数据 

        使用LINQ删除SQL Server数据库中的数据时,需要使用DeleteAllOnSubmit()方法和SubmitChanges()方法。

        DeleteAllOnSubmit()方法用来将集合中的所有实体置于pending delete状态

void DeleteAllOnSubmit(IEnumerable entities)
其中,entities表示要移除所有项的集合。

四、添加、修改和删除的源码

//Form1.cs
//使用LINQ管理SQL Server数据库
//对数据库添加、删除、修改
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Data.Linq;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Xml.Linq;namespace _07
{public partial class Form1 : Form{public Form1(){InitializeComponent();}//定义数据库连接字符串public string strCon = "Data Source=DESKTOP-S11C97H\\SQLEXPRESS;Initial Catalog=db_CSharp;Integrated Security=True;";DataClasses1DataContext _Linq;          //声明Linq连接对象public string _strID = "";                      //记录选中的员工编号/// <summary>/// 初始化Form1/// 调用方法,在datagridview1中显示数据库/// </summary>private void Form1_Load(object sender, EventArgs e){label1.Text = "编码:";label2.Text = "姓名:";label3.Text = "年龄:";label4.Text = "电话:";label5.Text = "地址:";label6.Text = "QQ:";label7.Text = "EMAIL:";label8.Text = "性别:";button1.Text = "添加";button2.Text = "删除";button3.Text = "修改";groupBox1.Text = "员工信息";comboBox1.Items.AddRange(new object[] {"男","女"});textBox1.Size = new System.Drawing.Size(100,21);textBox2.Size = new System.Drawing.Size(100, 21);textBox3.Size = new System.Drawing.Size(40, 21);textBox4.Size = new System.Drawing.Size(100, 21);textBox5.Size = new System.Drawing.Size(100, 21);textBox6.Size = new System.Drawing.Size(100, 21);textBox7.Size = new System.Drawing.Size(100, 21);comboBox1.Size = new System.Drawing.Size(40, 21);button1 .Size = new Size(50, 21);button2.Size = new Size(50, 21);button3.Size = new Size(50, 21);dataGridView1.AllowUserToAddRows = true;dataGridView1.AllowUserToDeleteRows = true;dataGridView1.AllowUserToResizeColumns = true ;dataGridView1.AllowUserToResizeRows = false;dataGridView1.RowHeadersVisible = false;            dataGridView1.SelectionMode=DataGridViewSelectionMode.FullRowSelect;dataGridView1.ReadOnly = false;dataGridView1.ContextMenuStrip = contextMenuStrip1;     //绑定contextMenuStrip1button2.ContextMenuStrip = contextMenuStrip1;               //绑定contextMenuStrip1contextMenuStrip1.Items.AddRange(new System.Windows.Forms.ToolStripItem[] {toolStripMenuItem1});toolStripMenuItem1.Text = "删除";toolStripMenuItem1.Size = new Size(40,21);BindInfo();           }#region 显示所有员工信息/// <summary>/// 显示所有员工信息/// </summary>private void BindInfo(){_Linq = new DataClasses1DataContext(strCon);    //实例化Linq连接对象//获取所有员工信息var result = from info in _Linq.tb_Employeeselect new{info.ID,info.Name,info.Sex,info.Age,info.Tel,info.Address,info.QQ,info.Email};dataGridView1.DataSource = result;            //对DataGridView控件进行数据绑定dataGridView1.Columns[0].Width = 60;dataGridView1.Columns[1].Width = 60;dataGridView1.Columns[2].Width = 30;dataGridView1.Columns[3].Width = 30;dataGridView1.Columns[4].Width = 80;dataGridView1.Columns[5].Width = 150;dataGridView1.Columns[6].Width = 80;dataGridView1.Columns[7].Width = 150;}#endregion/// <summary>/// 鼠标点击cell,获得选中行的编号/// </summary>private void DataGridView1_CellClick(object sender, DataGridViewCellEventArgs e){//获取选中的员工编号,给删除事件使用_strID = Convert.ToString(dataGridView1[0, e.RowIndex].Value).Trim();//以下,给修改事件使用_Linq = new DataClasses1DataContext(strCon);    //实例化Linq连接对象//获取选中的员工编号textBox1.Text = Convert.ToString(dataGridView1[0, e.RowIndex].Value).Trim();//根据选中的员工编号获取其详细信息,并重新成成一个表var result = from info in _Linq.tb_Employeewhere info.ID == textBox1.Textselect new{info.ID,info.Name,info.Sex,info.Age,info.Tel,info.Address,info.QQ,info.Email};//相应的文本框及下拉列表中显示选中员工的详细信息foreach (var item in result){textBox2.Text = item.Name;comboBox1.Text = item.Sex;textBox3.Text = item.Age.ToString();textBox4.Text = item.Tel;textBox5.Text = item.Address;textBox6.Text = item.QQ.ToString();textBox7.Text = item.Email;}}/// <summary>/// ToolStripMenuItem1控件的删除事件/// </summary>private void ToolStripMenuItem1_Click(object sender, EventArgs e){if (_strID == ""){MessageBox.Show("请选择要删除的记录");return;}_Linq = new DataClasses1DataContext(strCon);//实例化Linq连接对象//查找要删除的员工信息var result = from employee in _Linq.tb_Employeewhere employee.ID == _strIDselect employee;_Linq.tb_Employee.DeleteAllOnSubmit(result); //删除员工信息_Linq.SubmitChanges();                                  //实例化Linq连接对象提交操作MessageBox.Show("员工信息删除成功");BindInfo();}/// <summary>/// 按钮事件:向数据库追加新记录/// </summary>private void Button1_Click(object sender, EventArgs e){_Linq = new DataClasses1DataContext(strCon);    //实例化Linq连接对象tb_Employee _employee = new tb_Employee{//为tb_Employee类中的员工实体赋值ID = textBox1.Text,Name = textBox2.Text,Sex = comboBox1.Text,Age = Convert.ToInt32(textBox3.Text),Tel = textBox4.Text,Address = textBox5.Text,QQ = Convert.ToInt32(textBox6.Text),Email = textBox7.Text};   //实例化tb_Employee类对象_Linq.tb_Employee.InsertOnSubmit(_employee);    //删除员工信息_Linq.SubmitChanges();                                        //实例化Linq连接对象提交操作MessageBox.Show("员工信息添加成功");BindInfo();}/// <summary>/// 按钮事件:删除选中的记录/// new方法新定义的实例不能用于修改,因为new后的实例用的是新的主键值/// 只可以追加记录,不可以修改记录,对已有记录进行修改应用foreach方法/// </summary>private void Button2_Click(object sender, EventArgs e){_Linq = new DataClasses1DataContext(strCon);    //实例化Linq连接对象//tb_Employee _employee = new tb_Employee//{//    //为tb_Employee类中的员工实体赋值//    ID = textBox1.Text,                //    Name = textBox2.Text,//    Sex = comboBox1.Text,//    Age = Convert.ToInt32(textBox3.Text),//    Tel = textBox4.Text,//    Address = textBox5.Text,//    QQ = Convert.ToInt32(textBox6.Text),//    Email = textBox7.Text//};   //实例化tb_Employee类对象if (_strID == ""){MessageBox.Show("请选择要删除的记录");return;}_Linq = new DataClasses1DataContext(strCon);//实例化Linq连接对象//查找要删除的员工信息var result = from employee in _Linq.tb_Employeewhere employee.ID == _strIDselect employee;_Linq.tb_Employee.DeleteAllOnSubmit(result); //删除员工信息_Linq.SubmitChanges();                                  //实例化Linq连接对象提交操作MessageBox.Show("员工信息删除成功");BindInfo();}/// <summary>/// 按钮事件:修改选中的记录/// </summary>private void Button3_Click(object sender, EventArgs e){_Linq = new DataClasses1DataContext(strCon);    //实例化Linq连接对象if (textBox1.Text == ""){MessageBox.Show("请选择要修改的记录");return;}//查找要修改的员工信息var result = from _employee in _Linq.tb_Employeewhere _employee.ID == textBox1.Textselect _employee;//对指定的员工信息进行修改foreach (tb_Employee _employee in result){_employee.Name = textBox2.Text;_employee.Sex = comboBox1.Text;_employee.Age = Convert.ToInt32(textBox3.Text);_employee.Tel = textBox4.Text;_employee.Address = textBox5.Text;_employee.QQ = Convert.ToInt32(textBox6.Text);_employee.Email = textBox7.Text;}_Linq.SubmitChanges();  //更新数据库MessageBox.Show("员工信息修改成功");BindInfo();                     //把修改后的数据库更新到datagridview1中显示}}
}

五、生成效果

1.VS和SSMS原始记录

  

2.删除ID=2和5的记录

 

3.添加记录ID=2、5和8

 

 4.修改ID=3和ID=4的记录 

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

纠结蓝桥杯参加嵌入式还是单片机组?

纠结蓝桥杯参加嵌入式还是单片机组? 单片机包含于嵌入式&#xff0c;嵌入式不只是单片机。. 你只有浅浅的的单片机基础&#xff0c;只能报单片机了。最近很多小伙伴找我&#xff0c;说想要一些单片机资料&#xff0c;然后我根据自己从业十年经验&#xff0c;熬夜搞了几个通宵…

Linux-----nginx的简介,nginx搭载负载均衡以及nginx部署前后端分离项目

目录 nginx的简介 是什么 nginx的特点以及功能 Nginx负载均衡 下载 安装 负载均衡 nginx的简介 是什么 Nginx是一个高性能的开源Web服务器和反向代理服务器。它的设计目标是为了解决C10k问题&#xff0c;即在同一时间内支持上万个并发连接。 Nginx采用事件驱动的异…

redis-plus-plus常用函数介绍以及redis的一些边缘知识

文章目录 渐进式遍历scan数据库管理使用C调用redis安装redis-plus-plus get, set, exists , del, keysexpire, typestring的set, mset, mgetgetrange, setrangeincr, decrlpush, lrange,lpop, rpopblpop, llensadd, smemberssismember, scardsinter, sinterstorehset, hget, he…

MVCC详解

什么是MVCC&#xff1f; MVCC&#xff0c;即Multi-Version Concurrency Control &#xff08;多版本并发控制&#xff09;。它是一种并发控制的方法&#xff0c;一般在数据库管理系统中&#xff0c;实现对数据库的并发访问&#xff0c;在编程语言中实现事务内存。 通俗的讲&am…

Azure 机器学习 - 使用 AutoML 和 Python 训练物体检测模型

目录 一、Azure环境准备二、计算目标设置三、试验设置四、直观呈现输入数据五、上传数据并创建 MLTable六、配置物体检测试验适用于图像任务的自动超参数扫描 (AutoMode)适用于图像任务的手动超参数扫描作业限制 七、注册和部署模型获取最佳试用版注册模型配置联机终结点创建终…

框架安全-CVE 复现Apache ShiroApache Solr漏洞复现

文章目录 服务攻防-框架安全&CVE 复现&Apache Shiro&Apache Solr漏洞复现中间件列表常见开发框架Apache Shiro-组件框架安全暴露的安全问题漏洞复现Apache Shiro认证绕过漏洞&#xff08;CVE-2020-1957&#xff09;CVE-2020-11989验证绕过漏洞CVE_2016_4437 Shiro-…

【微服务 Spring Cloud Alibaba】- Nacos 服务注册中心

目录 1. 什么是注册中心&#xff1f; 1.2 注册中心的作用 2. SpringBoot 整合 Nacos 实现服务注册中心 2.1 将服务注册到 Nacos 2.2 实现消费者 3. 服务列表各个参数的含义、作用以及应用场景 1. 什么是注册中心&#xff1f; 注册中心是微服务架构中的一个重要组件&…

算法---缺失的第一个正数

题目 给你一个未排序的整数数组 nums &#xff0c;请你找出其中没有出现的最小的正整数。 请你实现时间复杂度为 O(n) 并且只使用常数级别额外空间的解决方案。示例 1&#xff1a;输入&#xff1a;nums [1,2,0] 输出&#xff1a;3 示例 2&#xff1a;输入&#xff1a;nums …

分享一下怎么做小程序营销活动

小程序营销活动已经成为现代营销的必备利器&#xff0c;它能够帮助企业提高品牌知名度、促进产品销售&#xff0c;以及加强与用户的互动。然而&#xff0c;要想成功地策划和执行一个小程序营销活动&#xff0c;需要精心设计和全面规划。本文将为您介绍小程序营销活动的策划和执…

计算机的输入输出设备

文章目录 前言一、常见的输入输出设备1.字符输入设备2.图形输入设备3.图像输出设备 二、输入输出接口的通用设计三、CPU与IO设备的通信1.程序中断2.DMA&#xff08;直接存储器访问&#xff09; 前言 今天给大家介绍计算机的输入输出设备&#xff0c;包括三个板块&#xff1a;常…

基于QT的简易计算器(一)

目录 0 简介1.设计原理1.1界面设计1.1.1界面基本布局1.1.2 界面调整和美化1.1.2 控件重命名 1.2 连接信号和槽1.3 软件逻辑1.3.1四则运算1.3.2 连续运算&#xff08;不完全&#xff09;的原理1.3.3 清屏1.3.4 退格1.3.5 等于1.3.6 小数点 2.总结与拓展 0 简介 最近在学QT&…

初识FFmpeg

前言 无意间见到群里的小伙伴展示视频工具。功能比较多&#xff0c;包括视频编码修改&#xff0c;画质处理&#xff0c;比例处理、名称提取&#xff0c;剪辑、标题拆解。因此开始了FFmpeg学习。以下摘自百度百科的解释。 FFmpeg是一套可以用来记录、转换数字音频、视频&#xf…