-
C#操作MySQL增删改查
在C#中操作MySQL数据库进行增删改查(CRUD)操作时,使用`MySql.Data`库是一种常见的做法。这里我将给出一个更加精炼和具体的示例,展示如何在C#中使用`MySql.Data`库执行MySQL数据库的增删改查操作。
首先,确保你的项目中已经通过NuGet安装了`MySql.Data`包。
然后,你可以创建一个类来封装数据库操作。这个类将包含四个主要的方法:`Insert`、`Select`、`Update`和`Delete`。但是,由于直接执行SQL查询并返回具体类型的数据集可能会很复杂,我将在`Select`方法中返回一个`DataTable`对象,这样你就可以在调用端灵活处理查询结果。
以下是一个简单的示例类:
**注意**:
1. 在`Insert`、`Update`和`Delete`方法中,我直接将SQL查询语句中的参数拼接到了查询字符串中。这在实际应用中可能导致SQL注入安全问题。为了避免这种情况,你应该使用参数化查询(就像你在`Select`方法中看到的那样,但`Select`通常返回数据集,因此它可能不使用参数化
最后,如果你对python语言还有任何疑问或者需要进一步的帮助,请访问https://www.xin3721.com 本站原创,转载请注明出处:https://www.xin3721.com/ArticlecSharp/c50053.html
首先,确保你的项目中已经通过NuGet安装了`MySql.Data`包。
然后,你可以创建一个类来封装数据库操作。这个类将包含四个主要的方法:`Insert`、`Select`、`Update`和`Delete`。但是,由于直接执行SQL查询并返回具体类型的数据集可能会很复杂,我将在`Select`方法中返回一个`DataTable`对象,这样你就可以在调用端灵活处理查询结果。
以下是一个简单的示例类:
using System;
using System.Data;
using MySql.Data.MySqlClient;
public class MySqlHelper
{
private string connectionString = "server=localhost;user=root;database=yourdatabase;port=3306;password=yourpassword;";
// 插入数据
public void Insert(string tableName, string insertColumns, string values)
{
string query = $"INSERT INTO {tableName} ({insertColumns}) VALUES ({values})";
using (MySqlConnection conn = new MySqlConnection(connectionString))
{
conn.Open();
using (MySqlCommand cmd = new MySqlCommand(query, conn))
{
int result = cmd.ExecuteNonQuery();
if (result > 0)
{
Console.WriteLine("数据插入成功!");
}
}
}
}
// 读取数据
public DataTable Select(string tableName, string selectColumns, string whereClause = "")
{
string query = $"SELECT {selectColumns} FROM {tableName}";
if (!string.IsNullOrEmpty(whereClause))
{
query += $" WHERE {whereClause}";
}
DataTable table = new DataTable();
using (MySqlConnection conn = new MySqlConnection(connectionString))
{
conn.Open();
using (MySqlCommand cmd = new MySqlCommand(query, conn))
{
using (MySqlDataAdapter adapter = new MySqlDataAdapter(cmd))
{
adapter.Fill(table);
}
}
}
return table;
}
// 更新数据
public void Update(string tableName, string updateColumns, string whereClause)
{
string query = $"UPDATE {tableName} SET {updateColumns} WHERE {whereClause}";
using (MySqlConnection conn = new MySqlConnection(connectionString))
{
conn.Open();
using (MySqlCommand cmd = new MySqlCommand(query, conn))
{
int result = cmd.ExecuteNonQuery();
if (result > 0)
{
Console.WriteLine("数据更新成功!");
}
}
}
}
// 删除数据
public void Delete(string tableName, string whereClause)
{
string query = $"DELETE FROM {tableName} WHERE {whereClause}";
using (MySqlConnection conn = new MySqlConnection(connectionString))
{
conn.Open();
using (MySqlCommand cmd = new MySqlCommand(query, conn))
{
int result = cmd.ExecuteNonQuery();
if (result > 0)
{
Console.WriteLine("数据删除成功!");
}
}
}
}
}
// 使用示例
class Program
{
static void Main(string[] args)
{
MySqlHelper dbHelper = new MySqlHelper();
// 插入数据
dbHelper.Insert("students", "name, age", "'John Doe', 20");
// 读取数据
DataTable dataTable = dbHelper.Select("students", "*");
foreach (DataRow row in dataTable.Rows)
{
Console.WriteLine($"Name: {row["name"]}, Age: {row["age"]}");
}
// 更新和删除数据(可以根据需要调用Update和Delete方法)
}
}
using System.Data;
using MySql.Data.MySqlClient;
public class MySqlHelper
{
private string connectionString = "server=localhost;user=root;database=yourdatabase;port=3306;password=yourpassword;";
// 插入数据
public void Insert(string tableName, string insertColumns, string values)
{
string query = $"INSERT INTO {tableName} ({insertColumns}) VALUES ({values})";
using (MySqlConnection conn = new MySqlConnection(connectionString))
{
conn.Open();
using (MySqlCommand cmd = new MySqlCommand(query, conn))
{
int result = cmd.ExecuteNonQuery();
if (result > 0)
{
Console.WriteLine("数据插入成功!");
}
}
}
}
// 读取数据
public DataTable Select(string tableName, string selectColumns, string whereClause = "")
{
string query = $"SELECT {selectColumns} FROM {tableName}";
if (!string.IsNullOrEmpty(whereClause))
{
query += $" WHERE {whereClause}";
}
DataTable table = new DataTable();
using (MySqlConnection conn = new MySqlConnection(connectionString))
{
conn.Open();
using (MySqlCommand cmd = new MySqlCommand(query, conn))
{
using (MySqlDataAdapter adapter = new MySqlDataAdapter(cmd))
{
adapter.Fill(table);
}
}
}
return table;
}
// 更新数据
public void Update(string tableName, string updateColumns, string whereClause)
{
string query = $"UPDATE {tableName} SET {updateColumns} WHERE {whereClause}";
using (MySqlConnection conn = new MySqlConnection(connectionString))
{
conn.Open();
using (MySqlCommand cmd = new MySqlCommand(query, conn))
{
int result = cmd.ExecuteNonQuery();
if (result > 0)
{
Console.WriteLine("数据更新成功!");
}
}
}
}
// 删除数据
public void Delete(string tableName, string whereClause)
{
string query = $"DELETE FROM {tableName} WHERE {whereClause}";
using (MySqlConnection conn = new MySqlConnection(connectionString))
{
conn.Open();
using (MySqlCommand cmd = new MySqlCommand(query, conn))
{
int result = cmd.ExecuteNonQuery();
if (result > 0)
{
Console.WriteLine("数据删除成功!");
}
}
}
}
}
// 使用示例
class Program
{
static void Main(string[] args)
{
MySqlHelper dbHelper = new MySqlHelper();
// 插入数据
dbHelper.Insert("students", "name, age", "'John Doe', 20");
// 读取数据
DataTable dataTable = dbHelper.Select("students", "*");
foreach (DataRow row in dataTable.Rows)
{
Console.WriteLine($"Name: {row["name"]}, Age: {row["age"]}");
}
// 更新和删除数据(可以根据需要调用Update和Delete方法)
}
}
**注意**:
1. 在`Insert`、`Update`和`Delete`方法中,我直接将SQL查询语句中的参数拼接到了查询字符串中。这在实际应用中可能导致SQL注入安全问题。为了避免这种情况,你应该使用参数化查询(就像你在`Select`方法中看到的那样,但`Select`通常返回数据集,因此它可能不使用参数化
最后,如果你对python语言还有任何疑问或者需要进一步的帮助,请访问https://www.xin3721.com 本站原创,转载请注明出处:https://www.xin3721.com/ArticlecSharp/c50053.html
栏目列表
最新更新
详解MyBatis延迟加载是如何实现的
IDEA 控制台中文乱码4种解决方案
SpringBoot中版本兼容性处理的实现示例
Spring的IOC解决程序耦合的实现
详解Spring多数据源如何切换
Java报错:UnsupportedOperationException in Col
使用Spring Batch实现批处理任务的详细教程
java中怎么将多个音频文件拼接合成一个
SpringBoot整合ES多个精确值查询 terms功能实
Java使用poi生成word文档的简单实例
计算机二级考试MySQL常考点 8种MySQL数据库
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
uniapp/H5 获取手机桌面壁纸 (静态壁纸)
[前端] DNS解析与优化
为什么在js中需要添加addEventListener()?
JS模块化系统
js通过Object.defineProperty() 定义和控制对象
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比