c#数据库: 9.删除和添加新字段/数据更新

2024-04-30 18:12

本文主要是介绍c#数据库: 9.删除和添加新字段/数据更新,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先把原来数据表的sexy字段删除,然后重新在添加字段sexy,如果添加成功,sexy列的随机内容会更新.原数据表如下:

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.Common;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace StudentAlter
{internal class Program{static void Main(string[] args){Random random = new Random();string connectionString =                                                  //数据库连接字符串"Data Source=.\\SQLExpress;Database=aq;Trusted_Connection=true;";SqlConnection connection = new SqlConnection(connectionString);//创建数据库连接实例connection.Open();                                                         //打开数据库连接Console.WriteLine("数据库aq连接成功!");string sql = "ALTER TABLE staq_info DROP COLUMN sexy;";using (SqlCommand command = new SqlCommand(sql, connection)){command.ExecuteNonQuery();Console.WriteLine("字段sexy已删除。");}Console.ReadKey();//ALTER TABLE staq_info DROP COLUMN age, DROP COLUMN grade;//为表staq_info增加sexy字段SqlCommand cmd = new SqlCommand();                    //创建数据查询类实例cmd.Connection = connection;cmd.CommandText = "ALTER TABLE staq_info ADD sexy varchar(2)";cmd.ExecuteNonQuery();                                //执行添加sex字段SQL语句cmd.Dispose();//利用数据集对所有学生信息的sex字段赋值SqlDataAdapter adapter = new SqlDataAdapter("SELECT * FROM staq_info","Data Source=.\\SQLExpress;Database=aq;Trusted_Connection=true;");DataSet dataSet = new DataSet();                                    //创建数据集adapter.Fill(dataSet);                                              //填充数据集int columnCount = dataSet.Tables[0].Columns.Count-1; //获取表总列数减1,for (int i = 0; i < dataSet.Tables[0].Rows.Count; i++)//i表格第几行{dataSet.Tables[0].Rows[i][columnCount] = random.Next(2) == 0 ? "男" : "女";//修改性别值。[columnCount] 中的值代表在第几列添加(初始是第0列),本例是最后一行}SqlCommandBuilder builder = new SqlCommandBuilder(adapter);    //将数据集更新以便与数据库协调adapter.Update(dataSet);                                   //更新数据集到数据库                                                Console.WriteLine("tj成功!");Console.ReadKey();}}
}

 本实例代码主要实现了向数据表中添加新字段。首先利用SqlConnection对象连接学生数据库,然后通过SqlCommand对象执行向学生信息表中增加性别字段的SQL语句,接着通过SqlDataAdapter对象查询修改后的学生表记录。此时所有记录的性别字段都为空,先将查询结果填充到数据集,然后通过逐行为数据集表中最后一列赋值,实现为性别字段赋值,接着创建SqlCommandBuilder协调数据集更新与数据库连接,最后调用SqlDataAdapter对象的Update方法实现将数据集的修改更新到数据库中。

运行C#代码:

然后在SQL Server Management Studio Management Studio 查看更新(先删除后添加)后的结果(先刷新):最后一列对比不同.

---------------------------------------            --------------------------------------

综合测试代码,删除和添加新字段及数据更新:

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.Common;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace StudentAlter
{internal class Program{static void Main(string[] args){ Random random = new Random();string connectionString =                                                  //数据库连接字符串"Data Source=.\\SQLExpress;Database=aq;Trusted_Connection=true;";SqlConnection connection = new SqlConnection(connectionString);//创建数据库连接实例connection.Open();                                                         //打开数据库连接Console.WriteLine("数据库aq连接成功!");string sql = "ALTER TABLE staq_info DROP COLUMN sexy;";try {using (SqlCommand command = new SqlCommand(sql, connection)){command.ExecuteNonQuery();Console.WriteLine("字段sexy已删除。");}} catch (Exception) { };string sq2 = "ALTER TABLE staq_info DROP COLUMN sexy1;";try{using (SqlCommand command = new SqlCommand(sq2, connection)){command.ExecuteNonQuery();Console.WriteLine("字段sexy1已删除。");}}catch (Exception) { };Console.ReadKey();// 为表staq_info增加age字段  try { using (SqlCommand cmd1 = new SqlCommand("ALTER TABLE staq_info ADD age int", connection)){cmd1.ExecuteNonQuery();}}catch (Exception) { };try {// 为表staq_info增加sexy字段  using (SqlCommand cmd = new SqlCommand("ALTER TABLE staq_info ADD sexy varchar(2)", connection)){cmd.ExecuteNonQuery();}}catch (Exception) { };SqlDataAdapter adapter = new SqlDataAdapter("SELECT * FROM staq_info","Data Source=.\\SQLExpress;Database=aq;Trusted_Connection=true;");DataSet dataSet = new DataSet();                                    //创建数据集adapter.Fill(dataSet);                                              //填充数据集int columnCount = dataSet.Tables[0].Columns.Count-1; //获取表总列数减1,for (int i = 0; i < dataSet.Tables[0].Rows.Count; i++)//i表格第几行{dataSet.Tables[0].Rows[i][2] = random.Next(1, 5);//更新第2列(grade)的内容dataSet.Tables[0].Rows[i][columnCount-1] = random.Next(20,25);//更新倒数第2列的内容dataSet.Tables[0].Rows[i][columnCount] = random.Next(2) == 0 ? "男" : "女";//修改性别值。[columnCount] 中的值代表在第几列添加(初始是第0列),本例是最后一行}SqlCommandBuilder builder = new SqlCommandBuilder(adapter);    //将数据集更新以便与数据库协调adapter.Update(dataSet);                                   //更新数据集到数据库                                                Console.WriteLine("tj成功!");Console.ReadKey();}}
}

运行C#代码: 

这篇关于c#数据库: 9.删除和添加新字段/数据更新的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/949566

相关文章

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

C#下Newtonsoft.Json的具体使用

《C#下Newtonsoft.Json的具体使用》Newtonsoft.Json是一个非常流行的C#JSON序列化和反序列化库,它可以方便地将C#对象转换为JSON格式,或者将JSON数据解析为C#对... 目录安装 Newtonsoft.json基本用法1. 序列化 C# 对象为 JSON2. 反序列化

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1