MySQL数据库工具类之——DataTable批量加入MySQL数据库(Net版)

MySQL数据库工具类之——DataTable批量加入数据库(Net版),MySqlDbHelper通用类希望能对大家有用,代码如下:

 

using MySql.Data.MySqlClient;
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Text;
public class MySqlDbHelper
{
#region 私有变量
private const string defaultConfigKeyName = "MySqlConnection";//连接字符串 Database='数据库';Data Source='IP地址';User Id='sa';Password='sa';pooling=true
private string connectionString;
private string providerName;
#endregion
#region 构造函数
/// <summary>
/// 默认构造函数(DbHelper)
/// </summary>
public MySqlDbHelper()
{
this.connectionString = ConfigurationManager.ConnectionStrings[defaultConfigKeyName].ConnectionString;
this.providerName = ConfigurationManager.ConnectionStrings[defaultConfigKeyName].ProviderName;
}
/// <summary>
/// DbHelper构造函数
/// </summary>
/// <param name="keyName">连接字符串名</param>
public MySqlDbHelper(string keyName)
{
this.connectionString = ConfigurationManager.ConnectionStrings[keyName].ConnectionString;
this.providerName = ConfigurationManager.ConnectionStrings[keyName].ProviderName;
}
#endregion
public int ExecuteNonQuery(string sql, params  MySqlParameter[] parameters)
{
int res = 0;
using (MySqlConnection con = new MySqlConnection(connectionString))
{
con.Open();
using (MySqlCommand cmd = new MySqlCommand(sql, con))
{
foreach (MySqlParameter parameter in parameters)
{
cmd.Parameters.Add(parameter);
}
try
{
res = cmd.ExecuteNonQuery();
}
catch
{
res = -1;
}
}
}
return res;
}
public object GetExeScalar(string sql, params MySqlParameter[] parameters)
{
object res = null;
using (MySqlConnection con = new MySqlConnection(connectionString))
{
con.Open();
using (MySqlCommand cmd = new MySqlCommand(sql, con))
{
foreach (MySqlParameter parameter in parameters)
{
cmd.Parameters.Add(parameter);
}
res = cmd.ExecuteScalar();
}
}
return res;
}
public DataTable GetDataTable(string sql, params MySqlParameter[] parameters)
{
DataSet dataset = new DataSet();
using (MySqlConnection con = new MySqlConnection(connectionString))
{
con.Open();
using (MySqlCommand cmd = new MySqlCommand(sql, con))
{
foreach (MySqlParameter parameter in parameters)
{
cmd.Parameters.Add(parameter);
}
MySqlDataAdapter adapter = new MySqlDataAdapter(cmd);
adapter.Fill(dataset);
}
}
return dataset.Tables[0];
}
/// <summary>
/// DataTable批量加入MYSQL数据库
/// </summary>
/// <param name="dataTable"></param>
/// <returns></returns>
public string InsertByDataTable(DataTable dataTable)
{
string result = string.Empty;
if (null == dataTable || dataTable.Rows.Count <= 0)
{
return "添加失败!DataTable暂无数据!";
}
if (string.IsNullOrEmpty(dataTable.TableName))
{
return "添加失败!请先设置DataTable的名称!";
}
// 构建INSERT语句
StringBuilder sb = new StringBuilder();
sb.Append("INSERT INTO " + dataTable.TableName + "(");
for (int i = 0; i < dataTable.Columns.Count; i++)
{
sb.Append(dataTable.Columns[i].ColumnName + ",");
}
sb.Remove(sb.ToString().LastIndexOf(','), 1);
sb.Append(") VALUES ");
for (int i = 0; i < dataTable.Rows.Count; i++)
{
sb.Append("(");
for (int j = 0; j < dataTable.Columns.Count; j++)
{
sb.Append("'" + dataTable.Rows[i][j] + "',");
}
sb.Remove(sb.ToString().LastIndexOf(','), 1);
sb.Append("),");
}
sb.Remove(sb.ToString().LastIndexOf(','), 1);
sb.Append(";");
int res = -1;
using (MySqlConnection con = new MySqlConnection(connectionString))
{
con.Open();
using (MySqlCommand cmd = new MySqlCommand(sb.ToString(), con))
{
try
{
res = cmd.ExecuteNonQuery();
}
catch (Exception ex)
{
res = -1;
// Unknown column 'names' in 'field list' 
result = "操作失败!" + ex.Message.Replace("Unknown column", "未知列").Replace("in 'field list'","存在字段集合中!");
}
}
}
if (res > 0)
{
result = "恭喜添加成功!";
}
return result;
}
}

 

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

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

相关文章

显示播客信息-bloginfo() 函数

该标签显示用户博客的相关信息&#xff0c;这些信息通常来自用户在WordPress网站后台“我的配置”和“设置>常规”菜单中填写的内容。该标签可以用在页面模板的任何区域内&#xff0c;且该标签总是将结果输出给浏览器。如果用户需要将输出内容用在PHP中&#xff0c;请使用ge…

计算机的访问资料,怎么从一台电脑访问另一台电脑上的资料?

如果两台电脑用路由器上网&#xff0c;可以按下面方法设置&#xff0c;如果没有可以用网线和网卡连接。用一根网线让两台电脑共享文件网卡连接&#xff0c;首先准备好两张10/100m的网卡。然后&#xff0c;准备几米长的网线&#xff0c;具体长度由你决定。按特定的方式接好插头。…

在pandas中遍历DataFrame行

有如下 Pandas DataFrame&#xff1a; import pandas as pd inp [{c1:10, c2:100}, {c1:11,c2:110}, {c1:12,c2:120}] df pd.DataFrame(inp) print df 上面代码输出&#xff1a; c1 c2 0 10 100 1 11 110 2 12 120 现在需要遍历上面DataFrame的行。对于每一行&#x…

pomelo获取客户端IP

代码&#xff1a; Handler.prototype.getClientIp function(msg, session, next) {var ip session.__session__.__socket__.remoteAddress.ipconsole.log(ip);}

linux内核2.6.35编译过程

一、实验目的 学习重新编译Linux内核&#xff0c;理解、掌握Linux内核和发行版本的区别。 二、实验内容 在Linux操作系统环境下重新编译内核。实验主要内容&#xff1a; A. 查找并且下载一份内核源代码&#xff0c;本实验使用最新的Linux内核2.6.36。 B. 配置内核。 C. 编…

MySQL索引的Index method中btree和hash的区别

2019独角兽企业重金招聘Python工程师标准>>> 在MySQL中&#xff0c;大多数索引&#xff08;如 PRIMARY KEY,UNIQUE,INDEX和FULLTEXT&#xff09;都是在BTREE中存储&#xff0c;但使用memory引擎可以选择BTREE索引或者HASH索引&#xff0c;两种不同类型的索引各自有其…

软件研发测试工程师英文怎么说,软件测试工程师面试英文自我介绍

《软件测试工程师面试英文自我介绍》由会员分享&#xff0c;可在线阅读&#xff0c;更多相关《软件测试工程师面试英文自我介绍(4页珍藏版)》请在人人文库网上搜索。1、软件测试工程师面试英文自我介绍篇一、范文Im , Im twenty-six year old, I majored in E-business and wit…

JavaScript禁用页面刷新

JavaScript禁用页面刷新代码如下&#xff1a; //禁用F5刷新document.onkeydown function (){if (event.keyCode 116) {event.keyCode 0;event.cancelBubble true;return false;}}//禁止右键弹出菜单document.oncontextmenu function () {return false;} 添加完成之后&…

Linux (Ubuntu/CentOS) 添加用户并授予sudo的权限

添加用户 添加新用户username&#xff0c;创建的用户默认的登陆Shell是/bin/bash# useradd username 设置密码# passwd username 为该用户指定命令解释程序&#xff08;通常为/bin/bash&#xff09;# usermod -s /bin/bash csdn 如果是为了启动apache、nginx、mysql等服务&am…

Oracle 11g数据库管理与开发指南

为什么80%的码农都做不了架构师&#xff1f;>>> Oracle 11g数据库管理与开发指南 本书内容系统而全面&#xff0c;详细讲解了Oracle数据库的管理、开发、性能优化、以及PL/SQL 编程的相关知识&#xff0c;面面俱到&#xff1b;注重实战&#xff0c;为每个知识…

JS性能优化

下面是一些关于客户端JS性能的一些优化的小技巧&#xff1a; 1.关于JS的循环&#xff0c;循环是一种常用的流程控制。JS提供了三种循环&#xff1a;for(;;)、while()、for(in)。在这三种循环中 for(in)的效率最差&#xff0c;因为它需要查询Hash键&#xff0c;因此应尽量少用f…

跨考计算机教研室,跨考教研室专家:脱离题海沉浮 做到有效做题_跨考网

很多同学在考研数学复习时&#xff0c;只知道一味的做题&#xff0c;诚然做题是必须的&#xff0c;但是应该采取相应的规划&#xff0c;有思想、有计划的去做题。那么&#xff0c;如何做题能够有效高效的提升数学水准呢&#xff0c;这里跨考教育教研室李老师给大家几点建议。思…

Ubuntu下安装配置JDK1.7

1、下载JDK 对于下载方法&#xff0c;可以使用命令&#xff0c;也可以手动下载。本人采用手动下载jdk的方式。 下载jdk-7u7-linux-i586.tar.gz到Ubuntu桌面。 2、 将下载的文件移动到这个文件夹下面并进行解压 如果目标文件夹存在则跳过此步骤&#xff0c;否则输入如下命令…

山东省计算机春季高考大纲,2017年山东春季高考专业知识考试大纲.doc

2017年山东春季高考专业知识考试大纲土建类专业知识考试说明本专业知识考试说明以山东省教育厅制定的中等职业学校《建筑施工专业教学指导方案》为依据&#xff0c;结合山东省中等职业学校的教学实际编写&#xff0c;以省教育厅公布的中等职业学校教学用书目录为主要参考教材。…

SQL Server 跨网段(跨机房)复制

一.本文所涉及的内容&#xff08;Contents&#xff09; 本文所涉及的内容&#xff08;Contents&#xff09;背景&#xff08;Contexts&#xff09;解决方案&#xff08;Solution&#xff09;搭建过程&#xff08;Process&#xff09;注意事项&#xff08;Attention&#xff09;…

gcc编译C++程序

单个源文件生成可执行程序 下面是一个保存在文件 helloworld.cpp 中一个简单的 C 程序的代码&#xff1a; /* helloworld.cpp */ #include <iostream> int main(int argc,char *argv[]) { std::cout << "hello, world" << std::endl; return(…

Twitter Storm安装配置(Ubuntu系统)单机版

要使用storm首先要安装以下工具&#xff1a;JDK、Python、zookeeper、zeromq、jzmq、storm &#xff08;注&#xff1a;各个模块都是独立的&#xff0c;如果安装失败或者卡顿可以单独百度某个模块的安装&#xff0c;都是可以的。&#xff09; JDK1.7安装 参见上篇《Ubuntu下安…

活动目录应用篇一:使用windows server 2008 backup备份AD是的账户权限问题

使用windowsserver2008backup备份AD的时候&#xff0c;需要提供执行账户的权限在指定备份计划的时候需要logonasabatchjob权限的用户这个权限到哪里添加呢&#xff1f;这个需要在组策略中去添加&#xff1a;说到组策略&#xff0c;我们知道组策略分为本地组策略与域组策略本地组…

计算机中隐藏的文件找不到了怎么办,隐藏文件夹找不到了怎么办【图解】

在今天&#xff0c;越来越多的人利用电脑来办公。甚至有一些工作&#xff0c;已经与电脑密切相关了。电脑以其强大的功能辅助人们工作&#xff0c;但有时在操作过程中会碰到这样或那样的问题。这个时候人们就会叹其操作的复杂性。就好比如有时你隐藏了一个文件&#xff0c;可是…

CentOS6 配置 yum 阿里源

一、CentOS6停止维护更新日期2020年11月30日 二、2020年12月2日下架了包括官方所有的CentOS6源&#xff08;包括国内的镜像站&#xff09; 三、CentOS6也完成了它的历史使命 在生产的环境中依旧由很多CentOS6系统依然在坚持&#xff0c;那么可以采取挂载光盘或者使用centos-va…