C#操作Excel数据增删改查示例

c#操作excel数据增删改查。 

首先创建exceldb.xlsx文件,并添加两张工作表。 

工作表1: 

userinfo表,字段:userid、username、age、address、createtime。 

工作表2: 

order表,字段:orderno、productname、quantity、money、saledate。 

1、创建excelhelper.cs类,excel文件处理类 

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data.OleDb; using System.Data; namespace MyStudy.DAL { ///  /// Excel文件处理类 ///  public class ExcelHelper { private static string fileName = AppDomain.CurrentDomain.SetupInformation.ApplicationBase + @"/ExcelFile/ExcelDB.xlsx"; private static OleDbConnection connection; public static OleDbConnection Connection { get { string connectionString = ""; string fileType = System.IO.Path.GetExtension(fileName); if (string.IsNullOrEmpty(fileType)) return null; if (fileType == ".xls") { connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + fileName + ";" + ";Extended Properties=\"Excel 8.0;HDR=YES;IMEX=2\""; } else { connectionString = "Provider=Microsoft.ACE.OLEDB.12.0;" + "Data Source=" + fileName + ";" + ";Extended Properties=\"Excel 12.0;HDR=YES;IMEX=2\""; } if (connection == null) { connection = new OleDbConnection(connectionString); connection.Open(); } else if (connection.State == System.Data.ConnectionState.Closed) { connection.Open(); } else if (connection.State == System.Data.ConnectionState.Broken) { connection.Close(); connection.Open(); } return connection; } } ///  /// 执行无参数的SQL语句 ///  /// SQL语句 /// 返回受SQL语句影响的行数 public static int ExecuteCommand(string sql) { OleDbCommand cmd = new OleDbCommand(sql, Connection); int result = cmd.ExecuteNonQuery(); connection.Close(); return result; } ///  /// 执行有参数的SQL语句 ///  /// SQL语句 /// 参数集合 /// 返回受SQL语句影响的行数 public static int ExecuteCommand(string sql, params OleDbParameter[] values) { OleDbCommand cmd = new OleDbCommand(sql, Connection); cmd.Parameters.AddRange(values); int result = cmd.ExecuteNonQuery(); connection.Close(); return result; } ///  /// 返回单个值无参数的SQL语句 ///  /// SQL语句 /// 返回受SQL语句查询的行数 public static int GetScalar(string sql) { OleDbCommand cmd = new OleDbCommand(sql, Connection); int result = Convert.ToInt32(cmd.ExecuteScalar()); connection.Close(); return result; } ///  /// 返回单个值有参数的SQL语句 ///  /// SQL语句 /// 参数集合 /// 返回受SQL语句查询的行数 public static int GetScalar(string sql, params OleDbParameter[] parameters) { OleDbCommand cmd = new OleDbCommand(sql, Connection); cmd.Parameters.AddRange(parameters); int result = Convert.ToInt32(cmd.ExecuteScalar()); connection.Close(); return result; } ///  /// 执行查询无参数SQL语句 ///  /// SQL语句 /// 返回数据集 public static DataSet GetReader(string sql) { OleDbDataAdapter da = new OleDbDataAdapter(sql, Connection); DataSet ds = new DataSet(); da.Fill(ds, "UserInfo"); connection.Close(); return ds; } ///  /// 执行查询有参数SQL语句 ///  /// SQL语句 /// 参数集合 /// 返回数据集 public static DataSet GetReader(string sql, params OleDbParameter[] parameters) { OleDbDataAdapter da = new OleDbDataAdapter(sql, Connection); da.SelectCommand.Parameters.AddRange(parameters); DataSet ds = new DataSet(); da.Fill(ds); connection.Close(); return ds; } } }

2、 创建实体类 

2.1 创建UserInfo.cs类,用户信息实体类。 

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data; namespace MyStudy.Model { ///  /// 用户信息实体类 ///  public class UserInfo { public int UserId { get; set; } public string UserName { get; set; } public int? Age { get; set; } public string Address { get; set; } public DateTime? CreateTime { get; set; } ///  /// 将DataTable转换成List数据 ///  public static List ToList(DataSet dataSet) { List userList = new List(); if (dataSet != null && dataSet.Tables.Count > 0) { foreach (DataRow row in dataSet.Tables[0].Rows) { UserInfo user = new UserInfo(); if (dataSet.Tables[0].Columns.Contains("UserId") && !Convert.IsDBNull(row["UserId"])) user.UserId = Convert.ToInt32(row["UserId"]); if (dataSet.Tables[0].Columns.Contains("UserName") && !Convert.IsDBNull(row["UserName"])) user.UserName = (string)row["UserName"]; if (dataSet.Tables[0].Columns.Contains("Age") && !Convert.IsDBNull(row["Age"])) user.Age = Convert.ToInt32(row["Age"]); if (dataSet.Tables[0].Columns.Contains("Address") && !Convert.IsDBNull(row["Address"])) user.Address = (string)row["Address"]; if (dataSet.Tables[0].Columns.Contains("CreateTime") && !Convert.IsDBNull(row["CreateTime"])) user.CreateTime = Convert.ToDateTime(row["CreateTime"]); userList.Add(user); } } return userList; } } }

2.2 创建Order.cs类,订单实体类。 

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data; namespace MyStudy.Model { ///  /// 订单实体类 ///  public class Order { public string OrderNo { get; set; } public string ProductName { get; set; } public int? Quantity { get; set; } public decimal? Money { get; set; } public DateTime? SaleDate { get; set; } ///  /// 将DataTable转换成List数据 ///  public static List ToList(DataSet dataSet) { List orderList = new List(); if (dataSet != null && dataSet.Tables.Count > 0) { foreach (DataRow row in dataSet.Tables[0].Rows) { Order order = new Order(); if (dataSet.Tables[0].Columns.Contains("OrderNo") && !Convert.IsDBNull(row["OrderNo"])) order.OrderNo = (string)row["OrderNo"]; if (dataSet.Tables[0].Columns.Contains("ProductName") && !Convert.IsDBNull(row["ProductName"])) order.ProductName = (string)row["ProductName"]; if (dataSet.Tables[0].Columns.Contains("Quantity") && !Convert.IsDBNull(row["Quantity"])) order.Quantity = Convert.ToInt32(row["Quantity"]); if (dataSet.Tables[0].Columns.Contains("Money") && !Convert.IsDBNull(row["Money"])) order.Money = Convert.ToDecimal(row["Money"]); if (dataSet.Tables[0].Columns.Contains("SaleDate") && !Convert.IsDBNull(row["SaleDate"])) order.SaleDate = Convert.ToDateTime(row["SaleDate"]); orderList.Add(order); } } return orderList; } } }

3、创建业务逻辑类 

3.1 创建UserInfoBLL.cs类,用户信息业务类。 

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data; using MyStudy.Model; using MyStudy.DAL; using System.Data.OleDb; namespace MyStudy.BLL { ///  /// 用户信息业务类 ///  public class UserInfoBLL { ///  /// 查询用户列表 ///  public List GetUserList() { List userList = new List(); string sql = "SELECT * FROM [UserInfo$]"; DataSet dateSet = ExcelHelper.GetReader(sql); userList = UserInfo.ToList(dateSet); return userList; } ///  /// 获取用户总数 ///  public int GetUserCount() { int result = 0; string sql = "SELECT COUNT(*) FROM [UserInfo$]"; result = ExcelHelper.GetScalar(sql); return result; } ///  /// 新增用户信息 ///  public int AddUserInfo(UserInfo param) { int result = 0; string sql = "INSERT INTO [UserInfo$](UserId,UserName,Age,Address,CreateTime) VALUES(@UserId,@UserName,@Age,@Address,@CreateTime)"; OleDbParameter[] oleDbParam = new OleDbParameter[] { new OleDbParameter("@UserId", param.UserId), new OleDbParameter("@UserName", param.UserName), new OleDbParameter("@Age", param.Age), new OleDbParameter("@Address",param.Address), new OleDbParameter("@CreateTime",param.CreateTime) }; result = ExcelHelper.ExecuteCommand(sql, oleDbParam); return result; } ///  /// 修改用户信息 ///  public int UpdateUserInfo(UserInfo param) { int result = 0; if (param.UserId > 0) { string sql = "UPDATE [UserInfo$] SET UserName=@UserName,Age=@Age,Address=@Address WHERE UserId=@UserId"; OleDbParameter[] sqlParam = new OleDbParameter[] { new OleDbParameter("@UserId",param.UserId), new OleDbParameter("@UserName", param.UserName), new OleDbParameter("@Age", param.Age), new OleDbParameter("@Address",param.Address) }; result = ExcelHelper.ExecuteCommand(sql, sqlParam); } return result; } ///  /// 删除用户信息 ///  public int DeleteUserInfo(UserInfo param) { int result = 0; if (param.UserId > 0) { string sql = "DELETE [UserInfo$] WHERE UserId=@UserId"; OleDbParameter[] sqlParam = new OleDbParameter[] { new OleDbParameter("@UserId",param.UserId), }; result = ExcelHelper.ExecuteCommand(sql, sqlParam); } return result; } } }

3.2 创建OrderBLL.cs类,订单业务类 

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data; using MyStudy.Model; using MyStudy.DAL; using System.Data.OleDb; namespace MyStudy.BLL { ///  /// 订单业务类 ///  public class OrderBLL { ///  /// 查询订单列表 ///  public List GetOrderList() { List orderList = new List(); string sql = "SELECT * FROM [Order$]"; DataSet dateSet = ExcelHelper.GetReader(sql); orderList = Order.ToList(dateSet); return orderList; } ///  /// 获取订单总数 ///  public int GetOrderCount() { int result = 0; string sql = "SELECT COUNT(*) FROM [Order$]"; result = ExcelHelper.GetScalar(sql); return result; } ///  /// 新增订单 ///  public int AddOrder(Order param) { int result = 0; string sql = "INSERT INTO [Order$](OrderNo,ProductName,Quantity,Money,SaleDate) VALUES(@OrderNo,@ProductName,@Quantity,@Money,@SaleDate)"; OleDbParameter[] oleDbParam = new OleDbParameter[] { new OleDbParameter("@OrderNo", param.OrderNo), new OleDbParameter("@ProductName", param.ProductName), new OleDbParameter("@Quantity", param.Quantity), new OleDbParameter("@Money",param.Money), new OleDbParameter("@SaleDate",param.SaleDate) }; result = ExcelHelper.ExecuteCommand(sql, oleDbParam); return result; } ///  /// 修改订单 ///  public int UpdateOrder(Order param) { int result = 0; if (!String.IsNullOrEmpty(param.OrderNo)) { string sql = "UPDATE [Order$] SET ProductName=@ProductName,Quantity=@Quantity,Money=@Money WHERE OrderNo=@OrderNo"; OleDbParameter[] sqlParam = new OleDbParameter[] { new OleDbParameter("@OrderNo",param.OrderNo), new OleDbParameter("@ProductName",param.ProductName), new OleDbParameter("@Quantity", param.Quantity), new OleDbParameter("@Money", param.Money) }; result = ExcelHelper.ExecuteCommand(sql, sqlParam); } return result; } ///  /// 删除订单 ///  public int DeleteOrder(Order param) { int result = 0; if (!String.IsNullOrEmpty(param.OrderNo)) { string sql = "DELETE [Order$] WHERE OrderNo=@OrderNo"; OleDbParameter[] sqlParam = new OleDbParameter[] { new OleDbParameter("@OrderNo",param.OrderNo), }; result = ExcelHelper.ExecuteCommand(sql, sqlParam); } return result; } } }

以上就是C#操作Excel数据增删改查示例的内容,更多相关内容请关注PHP中文网(www.php.cn)!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1431932.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 05:57:03
下一篇 2025年12月13日 12:13:22

相关推荐

  • c#加密类使用方法示例

    c#加密类使用方法示例 using System;using System.IO;using System.Text;using System.Security.Cryptography;using System.Web;namespace Encryption.App_Code{ /// /// …

    好文分享 2025年12月17日
    000
  • 通过C#动态生成图书信息XML文件

    通过c#动态生成图书信息xml文件(books.xml),文件如下:  Harry Potter J K. Rowling 2005-08-15 29.99 Learning XML Erik T. Ray 2003-10-18 39.95 方法1:使用StringBuilder拼接XML  ///…

    好文分享 2025年12月17日
    000
  • C#获取当前页面的URL示例代码

    本实例的测试url:http://www.mystudy.cn/web/index.aspx  1、通过c#获取当前页面的url  string url = Request.Url.AbsoluteUri; //结果: http://www.mystudy.cn/web/index.aspx str…

    好文分享 2025年12月17日
    000
  • C++设计模式浅识装饰模式

    装饰模式:动态的给一个对象添加一些额外的职责,就增加功能来说,装饰模式比生成子类更加灵活。  装饰模式的四个角色: 组件类:component 具体组件类:coneretecomponent 装饰类:decorator(从外类来扩展component类的功能,但对于component来说是无需知道d…

    好文分享 2025年12月17日
    000
  • C++设计模式浅识迭代器模式

    迭代器模式:提供一中方法顺序访问一个聚合对象中的各个元素,而又不暴露该对象的内部表示。【dp】 四个角色: iterator迭代器抽象类: 用于定义得到开始对象,得到下一个对象、判断是否到结尾、当前对象等抽象方法,统一接口。 concreteiterator具体迭代器类: 继承iterator,实现…

    好文分享 2025年12月17日
    000
  • C++设计模式浅识外观模式

    外观模式(facade):为子系统中的一组接口提供一个一致的界面,此模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。 两大角色: 外观类facade: 知道哪些子系统类负责处理请求,将客户的请求代理给适当的子系统对象。 子系统集合subsystem: 实现子系统的功能,处理facade对…

    好文分享 2025年12月17日
    000
  • C++设计模式浅识模板方法模式

    模板方法模式:定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。 适用的一个时机:当我们要完成在某一细节层次一致的一个过程或一系列步骤,但其个别步骤在更详细的层次上的实现可能不同时,我们通常考虑用模板方法模式来处理。 模板方…

    2025年12月17日
    000
  • C++设计模式浅识原型模式

    定义:用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象。 原型模式其实就是从一个对象再创建另外一个可定制的对象,而且不需要知道任何创建的细节。 原型模式主要考虑的深复制与浅复制,在c++++的类设计中,拷贝构造函数就是浅复制,当重载赋值运算符时就是深复制。 浅复制:被复制对象的所有变量…

    好文分享 2025年12月17日
    000
  • C++设计模式浅识工厂方法模式

    工厂方法模式(factory method):定义一个用于创建对象的接口,让子类去实例化哪一个类,工厂方法使一个类的实例化延迟到其子类。 与简单工厂的区别:简单工厂需要修改原有类,违背了开闭原则。而工厂方法就避免类这个问题。保持了封装对象的创建过程的优点,只需增加工厂类就可以,解决了简单工厂分支判断…

    2025年12月17日
    000
  • C++设计模式浅识代理模式

    代理模式(proxy): 为其他对象提供一种代理以控制对这个对象(被代理者,即本人)的访问。  在c++#中实现方法是使用接口interface定义需要的方法,而在c++中需要实现一个类作为接口使用,其中定义需要的方法。这样对我话,本人并不需要参与其中的具体活动,而由代理人出面。客户端(第三方)也不…

    好文分享 2025年12月17日
    000
  • C++设计模式浅识简单工厂模式

    简单工厂定义: 实现一个工厂函数对其他操作类选择性的调用,实现用户的实际需求。  将需要的功能分成多个组件,可以减少代码的耦合性,提高代码复用。在以后对某个功能改需求时,只需局部修改,不至于牵一发而动全身,大大提高效率。  面向对象的设计思想是通过封装、继承、多态把程序的耦合度降低,而设计模式是对o…

    好文分享 2025年12月17日
    000
  • XML中如何生成XML报表模板_XML生成XML报表模板的方法与示例

    利用XSLT、编程语言或模板引擎可生成XML报表模板:1. XSLT将源XML转换为结构化报表;2. Python等语言通过DOM操作动态构建XML;3. Jinja2等模板引擎支持变量与逻辑控制,实现灵活输出。 在XML中生成XML报表模板,实际上是指利用XML的结构化特性设计一个可复用的数据模板…

    2025年12月17日
    000
  • XML中如何解压XML字符串_XML解压XML字符串的操作方法

    先解压再解析XML。C#用GZipStream解压字节流并转字符串,Java用GZIPInputStream或InflaterInputStream读取压缩数据,结合StreamReader或BufferedReader还原为明文XML后,交由XDocument或DocumentBuilder解析;…

    2025年12月17日
    000
  • 如何用XML表示时间序列数据

    XML通过层级结构和属性封装时间戳与数值,适合表示含丰富元数据和不规则采样的时间序列数据,便于跨系统交换;其优势在于自描述性、可扩展性和平台无关性,但存在冗余大、解析慢等问题,海量数据时不如二进制格式或专用数据库高效。 在XML中表示时间序列数据,核心在于利用其层级结构和属性来封装每个时间点的数据值…

    2025年12月17日
    000
  • XML中如何反序列化XML对象_XML反序列化XML对象的操作方法

    答案:C#和Java可通过XmlSerializer和JAXB实现XML反序列化,需定义匹配类并使用特性/注解映射字段,确保无参构造函数和正确命名空间,最终将XML数据转换为对象。 在处理XML数据时,反序列化是将XML格式的数据转换为程序中的对象的过程。这一操作广泛应用于配置读取、网络通信和数据存…

    2025年12月17日
    000
  • XML中如何反序列化XML为对象_XML反序列化XML为对象的操作方法

    答案:XML反序列化是将XML数据转换为程序对象的过程,C#使用XmlSerializer类,Java使用JAXB实现。需定义与XML结构匹配的类,添加相应特性或注解,确保无参构造函数存在,通过Deserialize或unmarshal方法完成转换,注意标签名匹配、命名空间和集合类型处理,避免解析失…

    2025年12月17日
    000
  • XML Schema数据类型有哪些

    XML Schema数据类型分为原子类型和派生类型,前者如string、boolean、dateTime等基础类型,后者通过限制或组合原子类型形成更具体类型,用于提升数据验证精度、语义清晰度和系统互操作性。 XML Schema定义了丰富的数据类型,它们主要可以归结为两大类:原子数据类型(primi…

    2025年12月17日
    000
  • XML中如何按节点顺序排序_XML按节点顺序排序的方法与步骤

    答案:处理XML节点排序常用XSLT和编程语言两种方法。使用XSLT时通过xsl:sort指令定义排序规则,并结合xsl:for-each或xpl:apply-templates实现节点重排;编程方式如Python的ElementTree可解析XML、提取节点并按标签、属性或文本内容排序,再保存结果…

    2025年12月17日
    000
  • XML中如何压缩XML内容_XML压缩XML内容的操作步骤

    XML压缩通过去除冗余、GZIP/ZIP压缩、二进制格式转换(如EXI)等方式减小体积;可借助工具自动化处理,适用于传输优化与存储节约。 在处理XML文件时,压缩XML内容可以减小文件体积,提高传输效率和存储利用率。实现XML压缩通常包括去除冗余信息、使用专用压缩算法等步骤。以下是具体操作方法。 1…

    2025年12月17日
    000
  • XML中如何生成带CDATA节点的XML_XML生成带CDATA节点的XML的方法

    答案:CDATA用于在XML中保留特殊字符原样输出,语法为,不同语言通过API如createCDATASection生成,避免解析器解析标签或实体。 在生成XML时,如果需要保留文本中的特殊字符(如 、& 等)原样输出而不被解析,可以使用CDATA(Character Data)节点。CDA…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信