c#

c# linux开发能进行数据库操作吗

小樊
89
2024-12-09 23:43:31
栏目: 编程语言

是的,C# 可以在 Linux 上进行数据库操作。虽然 Windows 上的 .NET Core 和 .NET 5/6/7 等版本提供了对数据库操作的支持,但是在 Linux 上,你需要使用 .NET 的跨平台库,如 Dapper、Entity Framework Core 等来进行数据库操作。

以下是一些建议的步骤:

  1. 安装 .NET Core 或更高版本的 SDK。你可以在 .NET 官方网站 上下载并安装适用于 Linux 的 .NET Core SDK。

  2. 创建一个新的 C# 控制台应用程序或类库项目。在终端中,使用 dotnet new 命令创建一个新项目,例如:

    dotnet new console -o MyLinuxApp
    cd MyLinuxApp
    
  3. 添加数据库操作库。根据你的需求,选择 Dapper 或 Entity Framework Core。在本例中,我们将使用 Dapper。要添加 Dapper,请在终端中运行以下命令:

    dotnet add package Dapper
    
  4. 编写数据库操作代码。在你的项目中,创建一个名为 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);
            }
        }
    }
    
  5. 配置数据库连接字符串。在 appsettings.json 文件中,添加一个名为 ConnectionStrings 的属性,并填写你的数据库连接字符串。例如:

    {
      "ConnectionStrings": {
        "Default": "Server=my_server;Database=my_database;User Id=my_user;Password=my_password;"
      }
    }
    
  6. 在你的应用程序中使用 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 等。

0
看了该问题的人还看了