C# 连接ClickHouse 数据库

在 C# 中连接 ClickHouse 数据库,您可以使用 ClickHouse.Client 库。这个库提供了对 ClickHouse 数据库的高效访问。以下是详细的步骤指南,帮助您在 C# 项目中连接和操作 ClickHouse 数据库。

  1. 安装 ClickHouse.Client 包

首先,您需要在您的项目中安装 ClickHouse.Client 包。您可以使用 NuGet 包管理器来完成此操作。

使用 NuGet 包管理器控制台

cs 复制代码
Install-Package ClickHouse.Client -Version 1.4.1

使用 .NET CLI

cs 复制代码
dotnet add package ClickHouse.Client --version 1.4.1
  1. 配置 ClickHouse 客户端

接下来,您需要配置 ClickHouse 客户端以连接到您的 ClickHouse 实例。以下是一个基本的配置示例。

cs 复制代码
using ClickHouse.Client;
using ClickHouse.Client.ADO;
using System;
using System.Data;

namespace ClickHouseExample
{
    class Program
    {
        static void Main(string[] args)
        {
            // 配置 ClickHouse 连接字符串
            string connectionString = "Host=127.0.0.1;Port=9000;Username=default;Password=;Database=default";

            using (var connection = new ClickHouseConnection(connectionString))
            {
                try
                {
                    connection.Open();
                    Console.WriteLine("Connected to ClickHouse!");

                    // 执行查询
                    using (var command = new ClickHouseCommand("SELECT * FROM system.numbers LIMIT 10", connection))
                    {
                        using (var reader = command.ExecuteReader())
                        {
                            while (reader.Read())
                            {
                                Console.WriteLine(reader[0]);
                            }
                        }
                    }
                }
                catch (Exception ex)
                {
                    Console.WriteLine($"Error connecting to ClickHouse: {ex.Message}");
                }
            }
        }
    }
}
  1. 创建表

如果您还没有创建表,可以使用 ClickHouse.Client 创建一个新的表。

cs 复制代码
using ClickHouse.Client;
using ClickHouse.Client.ADO;
using System;

namespace ClickHouseExample
{
    class Program
    {
        static void Main(string[] args)
        {
            string connectionString = "Host=127.0.0.1;Port=9000;Username=default;Password=;Database=default";

            using (var connection = new ClickHouseConnection(connectionString))
            {
                try
                {
                    connection.Open();
                    Console.WriteLine("Connected to ClickHouse!");

                    // 创建表
                    string createTableQuery = @"
                        CREATE TABLE IF NOT EXISTS my_table
                        (
                            id UInt32,
                            name String,
                            description String
                        ) ENGINE = MergeTree() ORDER BY id;
                    ";

                    using (var command = new ClickHouseCommand(createTableQuery, connection))
                    {
                        command.ExecuteNonQuery();
                        Console.WriteLine("Table created successfully.");
                    }
                }
                catch (Exception ex)
                {
                    Console.WriteLine($"Error connecting to ClickHouse: {ex.Message}");
                }
            }
        }
    }
}
  1. 插入数据

您可以使用 ClickHouse.Client 将数据插入到 ClickHouse 中。

cs 复制代码
using ClickHouse.Client;
using ClickHouse.Client.ADO;
using System;

namespace ClickHouseExample
{
    class Program
    {
        static void Main(string[] args)
        {
            string connectionString = "Host=127.0.0.1;Port=9000;Username=default;Password=;Database=default";

            using (var connection = new ClickHouseConnection(connectionString))
            {
                try
                {
                    connection.Open();
                    Console.WriteLine("Connected to ClickHouse!");

                    // 插入数据
                    string insertQuery = @"
                        INSERT INTO my_table (id, name, description) VALUES
                        (1, 'Sample Document', 'This is a sample document.'),
                        (2, 'Another Document', 'This is another sample document.');
                    ";

                    using (var command = new ClickHouseCommand(insertQuery, connection))
                    {
                        command.ExecuteNonQuery();
                        Console.WriteLine("Data inserted successfully.");
                    }
                }
                catch (Exception ex)
                {
                    Console.WriteLine($"Error connecting to ClickHouse: {ex.Message}");
                }
            }
        }
    }
}
  1. 查询数据

您可以使用 ClickHouse.Client 执行查询以检索数据。

cs 复制代码
using ClickHouse.Client;
using ClickHouse.Client.ADO;
using System;
using System.Data;

namespace ClickHouseExample
{
    class Program
    {
        static void Main(string[] args)
        {
            string connectionString = "Host=127.0.0.1;Port=9000;Username=default;Password=;Database=default";

            using (var connection = new ClickHouseConnection(connectionString))
            {
                try
                {
                    connection.Open();
                    Console.WriteLine("Connected to ClickHouse!");

                    // 查询数据
                    string selectQuery = "SELECT * FROM my_table";

                    using (var command = new ClickHouseCommand(selectQuery, connection))
                    {
                        using (var reader = command.ExecuteReader())
                        {
                            while (reader.Read())
                            {
                                Console.WriteLine($"Id: {reader["id"]}, Name: {reader["name"]}, Description: {reader["description"]}");
                            }
                        }
                    }
                }
                catch (Exception ex)
                {
                    Console.WriteLine($"Error connecting to ClickHouse: {ex.Message}");
                }
            }
        }
    }
}
  1. 更新数据

ClickHouse 不直接支持 UPDATE 操作,但您可以使用 ALTER TABLE ... UPDATE 语句来更新数据。不过,这种操作相对复杂且性能较低,通常建议使用 INSERT 和 DELETE 组合来实现类似的效果。

cs 复制代码
using ClickHouse.Client;
using ClickHouse.Client.ADO;
using System;

namespace ClickHouseExample
{
    class Program
    {
        static void Main(string[] args)
        {
            string connectionString = "Host=127.0.0.1;Port=9000;Username=default;Password=;Database=default";

            using (var connection = new ClickHouseConnection(connectionString))
            {
                try
                {
                    connection.Open();
                    Console.WriteLine("Connected to ClickHouse!");

                    // 更新数据
                    string updateQuery = @"
                        ALTER TABLE my_table UPDATE name = 'Updated Document' WHERE id = 1;
                    ";

                    using (var command = new ClickHouseCommand(updateQuery, connection))
                    {
                        command.ExecuteNonQuery();
                        Console.WriteLine("Data updated successfully.");
                    }
                }
                catch (Exception ex)
                {
                    Console.WriteLine($"Error connecting to ClickHouse: {ex.Message}");
                }
            }
        }
    }
}
  1. 删除数据

您可以使用 ClickHouse.Client 删除数据。

cs 复制代码
using ClickHouse.Client;
using ClickHouse.Client.ADO;
using System;

namespace ClickHouseExample
{
    class Program
    {
        static void Main(string[] args)
        {
            string connectionString = "Host=127.0.0.1;Port=9000;Username=default;Password=;Database=default";

            using (var connection = new ClickHouseConnection(connectionString))
            {
                try
                {
                    connection.Open();
                    Console.WriteLine("Connected to ClickHouse!");

                    // 删除数据
                    string deleteQuery = @"
                        ALTER TABLE my_table DELETE WHERE id = 2;
                    ";

                    using (var command = new ClickHouseCommand(deleteQuery, connection))
                    {
                        command.ExecuteNonQuery();
                        Console.WriteLine("Data deleted successfully.");
                    }
                }
                catch (Exception ex)
                {
                    Console.WriteLine($"Error connecting to ClickHouse: {ex.Message}");
                }
            }
        }
    }
}

总结

通过以上步骤,您可以在 C# 项目中成功连接和操作 ClickHouse 数据库。ClickHouse.Client 提供了丰富的 API 来执行各种操作,如创建表、插入数据、查询数据、更新数据和删除数据。确保您的 ClickHouse 实例正在运行,并且客户端配置正确,以便顺利进行这些操作。如果遇到任何问题,可以参考 ClickHouse.Client 的官方文档或社区资源以获取更多帮助。

参考资料:

• ClickHouse 官方文档 https://clickhouse.com/docs/zh/getting-started/install

• ClickHouse.Client https://github.com/yandex/ClickHouse.Client

相关推荐
RisingWave中文开源社区43 分钟前
经验分享|用开源产品构建一个高性能实时推荐引擎
数据库·后端·开源
小码编匠1 小时前
西门子PLC通信掌握这几项技能,效率大幅提升
人工智能·后端·c#
小码编匠1 小时前
.NET 快速开发企业级CMS内容管理系统,告别重复造轮子!
后端·c#·.net
木木黄木木2 小时前
Theos环境搭建与XM文件开发指南,以及iOS弹窗源码分享
ios·c#
jay丿2 小时前
Django 初始化导入数据详解
数据库·django·sqlite
CodeJourney.2 小时前
用DEEPSEEK做数据看板:高效、实用与创新的融合
数据库·人工智能·python·算法
xuanloyer3 小时前
第二篇《Active Data Guard 实战:打造高可用数据库》(ADG)
运维·数据库·oracle
吾与谁归in3 小时前
【C#实现手写Ollama服务交互,实现本地模型对话】
c#·ollama·deepseek·本地模型
小王不会写code4 小时前
Unknown collation: ‘utf8mb4_0900_ai_ci‘
数据库·mysql
局外人LZ4 小时前
windows安装Neo4j图数据库
数据库·windows·neo4j