# Vitorm.ClickHouse Vitorm.ClickHouse is a lightweight yet comprehensive ORM for ClickHouse that strikes the perfect balance between simplicity and functionality. Similar to Dapper in its lightweight design, Vitorm offers an easy-to-use, efficient interface for data access. However, it doesn't stop there; Vitorm goes beyond basic ORM capabilities to provide a rich feature set akin to Entity Framework. This means you get the best of both worlds: the performance and simplicity of Dapper with the robust features and flexibility of Entity Framework, making Vitorm an ideal choice for developers seeking a powerful yet streamlined ORM solution. > source address: [https://github.com/VitormLib/Vitorm.ClickHouse](https://github.com/VitormLib/Vitorm.ClickHouse "https://github.com/VitormLib/Vitorm.ClickHouse") ![](https://img.shields.io/github/license/VitormLib/Vitorm.ClickHouse.svg) ![](https://img.shields.io/github/repo-size/VitormLib/Vitorm.ClickHouse.svg) ![](https://img.shields.io/github/last-commit/VitormLib/Vitorm.ClickHouse.svg) | Build | NuGet | | -------- | -------- | |![](https://github.com/VitormLib/Vitorm.ClickHouse/workflows/ki_devops3/badge.svg) | [![](https://img.shields.io/nuget/v/Vitorm.ClickHouse.svg)](https://www.nuget.org/packages/Vitorm.ClickHouse) ![](https://img.shields.io/nuget/dt/Vitorm.ClickHouse.svg) | # Vitorm.ClickHouse Documentation This guide will walk you through the steps to set up and use Vitorm.ClickHouse. ## Installation Before using Vitorm.ClickHouse, install the necessary package: ``` bash dotnet add package Vitorm.ClickHouse ``` ## Using Vitorm.ClickHouse > This example provides a comprehensive guide to utilizing Vitorm for basic and advanced database operations while maintaining lightweight performance. ``` csharp using Vitorm; namespace App { public class Program { static void Main(string[] args) { // #1 Create an empty SQLite database file and configures Vitorm using var dbContext = new Vitorm.Sql.SqlDbContext(); dbContext.UseClickHouse("Host=localhost;Port=8123;Database=dev-orm;User=default;Password=;Compress=True;CheckCompressedHash=False;Compressor=lz4;"); // #2 Create Table dbContext.Drop(); dbContext.Create(); // #3 Insert Records dbContext.Add(new User { id = 1, name = "lith" }); dbContext.AddRange(new[] { new User { id = 2, name = "lith", fatherId = 1 }, new User { id = 3, name = "lith", fatherId = 1 } }); // #4 Query Records { var user = dbContext.Get(1); var users = dbContext.Query().Where(u => u.name.Contains("li")).ToList(); var sql = dbContext.Query().Where(u => u.name.Contains("li")).ToExecuteString(); } // #5 Update Records dbContext.Update(new User { id = 1, name = "lith1" }); dbContext.UpdateRange(new[] { new User { id = 2, name = "lith2", fatherId = 1 }, new User { id = 3, name = "lith3", fatherId = 2 } }); dbContext.Query().Where(u => u.name.Contains("li")) .ExecuteUpdate(u => new User { name = "Lith" + u.id }); // #6 Delete Records dbContext.Delete(new User { id = 1, name = "lith1" }); dbContext.DeleteRange(new[] { new User { id = 2, name = "lith2", fatherId = 1 }, new User { id = 3, name = "lith3", fatherId = 2 } }); dbContext.DeleteByKey(1); dbContext.DeleteByKeys(new[] { 1, 2 }); dbContext.Query().Where(u => u.name.Contains("li")) .ExecuteDelete(); // #7 Join Queries { var query = from user in dbContext.Query() from father in dbContext.Query().Where(father => user.fatherId == father.id).DefaultIfEmpty() where father != null orderby user.id select new { user, father }; var sql = query.ToExecuteString(); var users = query.ToList(); } // #8 Transactions { using var tran1 = dbContext.BeginTransaction(); dbContext.Update(new User { id = 4, name = "u4001" }); using (var tran2 = dbContext.BeginTransaction()) { dbContext.Update(new User { id = 4, name = "u4002" }); // will rollback } using (var tran2 = dbContext.BeginTransaction()) { dbContext.Update(new User { id = 4, name = "u4002" }); tran2.Rollback(); } using (var tran2 = dbContext.BeginTransaction()) { dbContext.Update(new User { id = 4, name = "u4003" }); tran2.Commit(); } tran1.Commit(); } // #9 Database Functions { // select * from User where IIF(t0.fatherId is not null, true, false); var query = dbContext.Query().Where(u => DbFunction.Call("IIF", u.fatherId != null, true, false)); var sql = query.ToExecuteString(); var userList = query.ToList(); } } // Entity Definition [System.ComponentModel.DataAnnotations.Schema.Table("User")] public class User { [System.ComponentModel.DataAnnotations.Key] public int id { get; set; } public string name { get; set; } public DateTime? birth { get; set; } public int? fatherId { get; set; } } } } ``` ## Explanation 1. **Setup**: Initializes the SQLite database and configures Vitorm. 2. **Create Table**: Drops and recreates the `User` table. 3. **Insert Records**: Adds single and multiple user records. 4. **Query Records**: Retrieves user records using various querying methods. 5. **Update Records**: Updates single and multiple user records. 6. **Delete Records**: Deletes single and multiple user records. 7. **Join Queries**: Performs a join operation between user and father records. 8. **Transactions**: Demonstrates nested transactions and rollback/commit operations. 9. **Database Functions**: Uses custom database functions in queries. # Vitorm.Data Documentation Vitorm.Data is a static class that allows you to use Vitorm without explicitly creating or disposing of a DbContext. ## Installation Before using Vitorm.Data, install the necessary package: ``` bash dotnet add package Vitorm.Data dotnet add package Vitorm.ClickHouse ``` ## Config settings ``` json // appsettings.json { "Vitorm": { "Data": [ { "provider": "ClickHouse", "namespace": "App", "connectionString": "Host=localhost;Port=8123;Database=dev-orm;User=default;Password=;Compress=True;CheckCompressedHash=False;Compressor=lz4;" } ] } } ``` ## Using Vitorm.Data ``` csharp using Vitorm; namespace App { public class Program { static void Main(string[] args) { // #1 // #2 Create Table Data.Drop(); Data.Create(); // #3 Insert Records Data.Add(new User { id = 1, name = "lith" }); Data.AddRange(new[] { new User { id = 2, name = "lith", fatherId = 1 }, new User { id = 3, name = "lith", fatherId = 1 } }); // #4 Query Records { var user = Data.Get(1); var users = Data.Query().Where(u => u.name.Contains("li")).ToList(); var sql = Data.Query().Where(u => u.name.Contains("li")).ToExecuteString(); } // #5 Update Records Data.Update(new User { id = 1, name = "lith1" }); Data.UpdateRange(new[] { new User { id = 2, name = "lith2", fatherId = 1 }, new User { id = 3, name = "lith3", fatherId = 2 } }); Data.Query().Where(u => u.name.Contains("li")) .ExecuteUpdate(u => new User { name = "Lith" + u.id }); // #6 Delete Records Data.Delete(new User { id = 1, name = "lith1" }); Data.DeleteRange(new[] { new User { id = 2, name = "lith2", fatherId = 1 }, new User { id = 3, name = "lith3", fatherId = 2 } }); Data.DeleteByKey(1); Data.DeleteByKeys(new[] { 1, 2 }); Data.Query().Where(u => u.name.Contains("li")) .ExecuteDelete(); // #7 Join Queries { var query = from user in Data.Query() from father in Data.Query().Where(father => user.fatherId == father.id).DefaultIfEmpty() where father != null orderby user.id select new { user, father }; var sql = query.ToExecuteString(); var users = query.ToList(); } // #8 Transactions { using var dbContext = Data.DataProvider().CreateSqlDbContext(); using var tran1 = dbContext.BeginTransaction(); dbContext.Update(new User { id = 4, name = "u4001" }); using (var tran2 = dbContext.BeginTransaction()) { dbContext.Update(new User { id = 4, name = "u4002" }); // will rollback } using (var tran2 = dbContext.BeginTransaction()) { dbContext.Update(new User { id = 4, name = "u4002" }); tran2.Rollback(); } using (var tran2 = dbContext.BeginTransaction()) { dbContext.Update(new User { id = 4, name = "u4003" }); tran2.Commit(); } tran1.Commit(); } // #9 Database Functions { // select * from User where IIF(t0.fatherId is not null, true, false); var query = Data.Query().Where(u => DbFunction.Call("IIF", u.fatherId != null, true, false)); var sql = query.ToExecuteString(); var userList = query.ToList(); } } // Entity Definition [System.ComponentModel.DataAnnotations.Schema.Table("User")] public class User { [System.ComponentModel.DataAnnotations.Key] public int id { get; set; } public string name { get; set; } public DateTime? birth { get; set; } public int? fatherId { get; set; } } } } ``` [Test Example](https://github.com/VitormLib/Vitorm/tree/master/test/Vitorm.ClickHouse.MsTest)