是的,C# 可以在 Linux 上进行数据库操作。虽然 Windows 上的 .NET Core 和 .NET 5/6/7 等版本提供了对数据库操作的支持,但是在 Linux 上,你需要使用 .NET 的跨平台库,如 Dapper、Entity Framework Core 等来进行数据库操作。
以下是一些建议的步骤:
安装 .NET Core 或更高版本的 SDK。你可以在 .NET 官方网站 上下载并安装适用于 Linux 的 .NET Core SDK。
创建一个新的 C# 控制台应用程序或类库项目。在终端中,使用 dotnet new
命令创建一个新项目,例如:
dotnet new console -o MyLinuxApp
cd MyLinuxApp
添加数据库操作库。根据你的需求,选择 Dapper 或 Entity Framework Core。在本例中,我们将使用 Dapper。要添加 Dapper,请在终端中运行以下命令:
dotnet add package Dapper
编写数据库操作代码。在你的项目中,创建一个名为 DatabaseHelper.cs
的新文件,并编写以下代码:
using System.Data;
using System.Data.SqlClient;
using Dapper;
public class DatabaseHelper
{
private readonly string _connectionString;
public DatabaseHelper(string connectionString)
{
_connectionString = connectionString;
}
public async Task<int> ExecuteAsync(string sql, object param = null)
{
using (var connection = new SqlConnection(_connectionString))
{
return await connection.ExecuteAsync(sql, param);
}
}
public async Task<IEnumerable<T>> QueryAsync<T>(string sql, object param = null)
{
using (var connection = new SqlConnection(_connectionString))
{
return await connection.QueryAsync<T>(sql, param);
}
}
}
配置数据库连接字符串。在 appsettings.json
文件中,添加一个名为 ConnectionStrings
的属性,并填写你的数据库连接字符串。例如:
{
"ConnectionStrings": {
"Default": "Server=my_server;Database=my_database;User Id=my_user;Password=my_password;"
}
}
在你的应用程序中使用 DatabaseHelper
类。在你的 Program.cs
或其他需要执行数据库操作的地方,创建一个 DatabaseHelper
实例,并调用其方法。例如:
using System;
using System.Threading.Tasks;
using MyLinuxApp;
class Program
{
static async Task Main(string[] args)
{
var connectionString = Configuration["ConnectionStrings:Default"];
var dbHelper = new DatabaseHelper(connectionString);
// 插入数据
var insertResult = await dbHelper.ExecuteAsync("INSERT INTO my_table (name) VALUES (@Name)", new { Name = "John Doe" });
Console.WriteLine($"Inserted {insertResult} row(s).");
// 查询数据
var users = await dbHelper.QueryAsync<User>("SELECT * FROM my_table WHERE name = @Name", new { Name = "John Doe" });
foreach (var user in users)
{
Console.WriteLine($"ID: {user.Id}, Name: {user.Name}");
}
}
}
public class User
{
public int Id { get; set; }
public string Name { get; set; }
}
现在,你可以在 Linux 上使用 C# 进行数据库操作了。请注意,这里的示例使用了 SQL Server 数据库,但你可以根据需要更改为其他数据库类型,如 MySQL、PostgreSQL 等。