是的,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
ExecuteAsync(string sql, object param = null) { using (var connection = new SqlConnection(_connectionString)) { return await connection.ExecuteAsync(sql, param); } } public async Task > QueryAsync (string sql, object param = null) { using (var connection = new SqlConnection(_connectionString)) { return await connection.QueryAsync (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
("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 等。