SqlSugar/README.md

252 lines
9.9 KiB
Markdown
Raw Permalink Normal View History

2021-10-10 22:00:50 +08:00
<p align="center">
<span>English</span> |
2021-10-11 19:08:28 +08:00
<a href="https://www.donet5.com/Home/Doc"><font color="red">中文</font></a>
2021-10-10 22:00:50 +08:00
</p>
2021-10-10 22:06:05 +08:00
2023-08-02 08:52:44 +08:00
## SqlSugar ORM
2024-03-13 16:57:20 +08:00
SqlSugar is .NET open source ORM framework, maintained and updated by Fructose Big Data Technology team, the most easy-to-use ORM out of the box
2024-03-13 16:44:30 +08:00
2024-03-13 16:51:41 +08:00
Advantages: [Low code] [High performance] [Super simple] [Comprehensive features] [ Multi-database compatible] [Suitable products]
2024-03-13 16:44:30 +08:00
2024-03-13 16:58:15 +08:00
## Support .NET
.net framework.net core3.1.ne5.net6.net7.net8 .net9 .net10
2023-11-18 22:20:23 +08:00
2023-08-02 08:53:07 +08:00
## Support database
2023-08-02 08:51:55 +08:00
MySql、SqlServer、Sqlite、Oracle 、 postgresql、达梦、
人大金仓(国产推荐)、神通数据库、瀚高、Access 、OceanBase
2023-08-02 08:54:06 +08:00
TDengine QuestDb Clickhouse MySqlConnector、华为 GaussDB
南大通用 GBase、MariaDB、Tidb、Odbc、Percona Server,
Amazon Aurora、Azure Database for MySQL、
2023-08-02 08:51:55 +08:00
Google Cloud SQL for MySQL、custom database
2021-10-10 22:06:05 +08:00
2021-10-10 23:20:24 +08:00
## Description
2024-03-13 16:42:17 +08:00
1. Truly achieve zero SQL ORM table building, index and CRUD all support
2. Support.NET millions of big data write, update, subtable and has billions of query statistics mature solutions
3. Support SAAS complete application: cross-database query, audit, tenant sub-database, tenant sub-table and tenant data isolation
4. Support low code + workflow (dynamic class building, dynamic table building, non-entity multi-library compatible with CRUD, JSON TO SQL, custom XML, etc.)
5. Support ValueObject, discriminator, repository, UnitOfWork, DbContext, AOP
2021-10-10 22:00:50 +08:00
2021-10-10 22:32:28 +08:00
## Documentation
2021-10-11 08:53:42 +08:00
|Other |Select | Insert | Update | Delete|
2021-10-10 22:55:50 +08:00
| ----- | --------- | ----------- | ------- |------- |
2024-07-21 09:26:59 +08:00
<a target="_blank" href="https://github.com/donet5/SqlSugar/wiki/NUGET">Nuget</a>| <a href="https://github.com/DotNetNext/SqlSugar/wiki/1.1--QuerySimple">Query</a> | <a target="_blank" href="https://github.com/DotNetNext/SqlSugar/wiki/3.Insert"> Insert </a> |<a target="_blank" href="https://github.com/DotNetNext/SqlSugar/wiki/2.Update">Update</a>| <a target="_blank" href="https://github.com/DotNetNext/SqlSugar/wiki/4.1-Delete">Delete</a> |
2024-07-21 15:05:09 +08:00
<a target="_blank" href="https://github.com/donet5/SqlSugar/wiki"> Start guide</a> | <a target="_bank" href="https://github.com/DotNetNext/SqlSugar/wiki/1.2-Query%E2%80%90Join">Join query </a> |<a href="https://github.com/DotNetNext/SqlSugar/wiki/3.2-Dynamic-Insert">Insert without entity </a> | <a href="https://github.com/DotNetNext/SqlSugar/wiki/2.2-Dynamic-Update">Update without entity</a> | <a href="https://github.com/DotNetNext/SqlSugar/wiki/4.2-Dynamic-Delete"> Delete without entity </a> | |
2024-06-30 16:25:26 +08:00
|<a href="https://www.donet5.com/Home/Doc?typeId=2246">Multiple databases</a> | <a target="_bank" href="https://github.com/DotNetNext/SqlSugar/wiki/1.6-Query%E2%80%90Include">Include query</a>|<a target="_bank" href="https://www.donet5.com/Home/Doc?typeId=2430">Include Insert</a>| <a target="_bank" href="https://www.donet5.com/Home/Doc?typeId=2432">Include Update</a>| <a target="_bank" href="https://www.donet5.com/Home/Doc?typeId=2431">Include Delete</a>
2022-10-25 16:23:22 +08:00
|<a href="https://www.donet5.com/Home/Doc"><font color="red">中文文档</font></a>|<a href="https://www.donet5.com/Home/Doc?typeId=2244">Cross database query</a>|<a href="https://www.donet5.com/Home/Doc?typeId=2420">Insert by json</a>|<a href="https://www.donet5.com/Home/Doc?typeId=2420">Update by json</a>|<a href="https://www.donet5.com/Home/Doc?typeId=2420">Delete by json</a>|
2022-07-29 09:09:58 +08:00
2021-10-10 22:32:28 +08:00
## Feature characteristic
2021-10-10 22:40:00 +08:00
### Feature1 : Join query
2021-10-10 22:00:50 +08:00
Super simple query syntax
```cs
2022-04-15 15:03:21 +08:00
var query = db.Queryable<Order>()
2021-10-10 22:00:50 +08:00
.LeftJoin<Custom> ((o, cus) => o.CustomId == cus.Id)
.LeftJoin<OrderItem> ((o, cus, oritem ) => o.Id == oritem.OrderId)
.LeftJoin<OrderItem> ((o, cus, oritem , oritem2) => o.Id == oritem2.OrderId)
.Where(o => o.Id == 1)
.Select((o, cus) => new ViewOrder { Id = o.Id, CustomName = cus.Name })
.ToList();
```
```sql
SELECT
[o].[Id] AS [Id],
[cus].[Name] AS [CustomName]
FROM
[Order] o
Left JOIN [Custom] cus ON ([o].[CustomId] = [cus].[Id])
Left JOIN [OrderDetail] oritem ON ([o].[Id] = [oritem].[OrderId])
Left JOIN [OrderDetail] oritem2 ON ([o].[Id] = [oritem2].[OrderId])
WHERE
([o].[Id] = @Id0)
2019-04-29 15:46:54 +08:00
```
2022-07-17 14:19:19 +08:00
### Feature2 :Include Query、Insert、Delete and Update
2024-03-13 17:04:57 +08:00
```cs
//Includes
2022-04-15 15:06:16 +08:00
var list=db.Queryable<Test>()
2022-07-17 14:19:19 +08:00
.Includes(x => x.Provinces,x=>x.Citys ,x=>x.Street) //multi-level
2022-04-15 15:06:16 +08:00
.Includes(x => x.ClassInfo)
.ToList();
2024-03-13 17:04:57 +08:00
2024-03-13 17:03:09 +08:00
//Includes+left join
2024-03-13 17:02:21 +08:00
var list5= db.Queryable<Student_004>()
.Includes(x => x.school_001, x => x.rooms)
.Includes(x => x.books)
.LeftJoin<Order>((x, y) => x.Id==y.sid)
.Select((x,y) => new Student_004DTO
{
SchoolId = x.SchoolId,
books = x.books,
school_001 = x.school_001,
Name=y.Name
})
.ToList();
2022-04-15 15:06:16 +08:00
```
### Feature3 : Page query
2021-10-10 22:11:27 +08:00
```cs
int pageIndex = 1;
int pageSize = 20;
int totalCount=0;
var page = db.Queryable<Student>().ToPageList(pageIndex, pageSize, ref totalCount);
```
2019-05-03 20:54:32 +08:00
2022-04-15 15:06:16 +08:00
### Feature4 : Dynamic expression
2021-10-10 22:16:20 +08:00
```cs
var names= new string [] { "a","b"};
Expressionable<Order> exp = new Expressionable<Order>();
foreach (var item in names)
{
exp.Or(it => it.Name.Contains(item.ToString()));
}
var list= db.Queryable<Order>().Where(exp.ToExpression()).ToList();
```
```sql
SELECT [Id],[Name],[Price],[CreateTime],[CustomId]
FROM [Order] WHERE (
([Name] like '%'+ CAST(@MethodConst0 AS NVARCHAR(MAX))+'%') OR
([Name] like '%'+ CAST(@MethodConst1 AS NVARCHAR(MAX))+'%')
)
```
2022-04-15 15:06:16 +08:00
### Feature5 : Multi-tenant transaction
2021-10-10 22:23:22 +08:00
```cs
//Creaate database object
SqlSugarClient db = new SqlSugarClient(new List<ConnectionConfig>()
{
new ConnectionConfig(){ ConfigId="0", DbType=DbType.SqlServer, ConnectionString=Config.ConnectionString, IsAutoCloseConnection=true },
new ConnectionConfig(){ ConfigId="1", DbType=DbType.MySql, ConnectionString=Config.ConnectionString4 ,IsAutoCloseConnection=true}
});
var mysqldb = db.GetConnection("1");//mysql db
var sqlServerdb = db.GetConnection("0");// sqlserver db
db.BeginTran();
mysqldb.Insertable(new Order()
{
CreateTime = DateTime.Now,
CustomId = 1,
Name = "a",
Price = 1
}).ExecuteCommand();
mysqldb.Queryable<Order>().ToList();
sqlServerdb.Queryable<Order>().ToList();
db.CommitTran();
```
2022-04-15 15:06:16 +08:00
### Feature6 : Singleton Pattern
2021-10-10 22:37:27 +08:00
Implement transactions across methods
```CS
public static SqlSugarScope Db = new SqlSugarScope(new ConnectionConfig()
{
DbType = SqlSugar.DbType.SqlServer,
ConnectionString = Config.ConnectionString,
IsAutoCloseConnection = true
},
db=> {
db.Aop.OnLogExecuting = (s, p) =>
{
Console.WriteLine(s);
};
});
using (var tran = Db.UseTran())
{
2021-10-11 08:43:12 +08:00
2021-10-10 22:37:27 +08:00
new Test2().Insert(XX);
new Test1().Insert(XX);
2021-10-11 08:43:12 +08:00
.....
2021-10-10 22:37:27 +08:00
....
2021-10-11 08:43:12 +08:00
tran.CommitTran();
2021-10-10 22:37:27 +08:00
}
```
2022-04-15 15:06:16 +08:00
### Feature7 : Query filter
2021-10-10 23:24:14 +08:00
```cs
2021-10-11 08:43:12 +08:00
//set filter
2021-10-10 23:25:48 +08:00
db.QueryFilter.Add(new TableFilterItem<Order>(it => it.Name.Contains("a")));
2021-10-10 23:24:14 +08:00
db.Queryable<Order>().ToList();
2021-10-10 23:25:48 +08:00
//SELECT [Id],[Name],[Price],[CreateTime],[CustomId] FROM [Order] WHERE ([Name] like '%'+@MethodConst0+'%')
2021-10-10 23:24:14 +08:00
db.Queryable<OrderItem, Order>((i, o) => i.OrderId == o.Id)
.Where(i => i.OrderId != 0)
.Select("i.*").ToList();
//SELECT i.* FROM [OrderDetail] i ,[Order] o WHERE ( [i].[OrderId] = [o].[Id] ) AND
//( [i].[OrderId] <> @OrderId0 ) AND ([o].[Name] like '%'+@MethodConst1+'%')
```
2021-10-10 23:28:04 +08:00
2022-04-15 15:06:16 +08:00
### Feature8 : Insert or update
2021-10-10 23:29:57 +08:00
insert or update
2021-10-10 23:28:04 +08:00
```cs
2024-03-13 17:00:51 +08:00
Db.Storageable(list2).ExecuteCommand();
Db.Storageable(list2).PageSize(1000).ExecuteCommand();
Db.Storageable(list2).PageSize(1000,exrows=> { }).ExecuteCommand();
2021-10-10 23:29:57 +08:00
```
2021-10-10 23:28:04 +08:00
### Feature9 : Auto split table
2021-11-09 02:54:19 +08:00
Split entity
2021-11-09 02:50:47 +08:00
```cs
2021-11-09 02:52:20 +08:00
[SplitTable(SplitType.Year)]//Table by year (the table supports year, quarter, month, week and day)
[SugarTable("SplitTestTable_{year}{month}{day}")]
2021-11-09 02:50:47 +08:00
public class SplitTestTable
{
[SugarColumn(IsPrimaryKey =true)]
public long Id { get; set; }
public string Name { get; set; }
2021-11-09 02:54:19 +08:00
2021-11-09 02:52:20 +08:00
//When the sub-table field is inserted, which table will be inserted according to this field.
//When it is updated and deleted, it can also be convenient to use this field to
//find out the related table
2021-11-09 02:54:19 +08:00
[SplitField]
2021-11-09 02:50:47 +08:00
public DateTime CreateTime { get; set; }
}
2021-11-09 02:54:19 +08:00
```
Split query
```cs
2021-11-09 02:50:47 +08:00
var lis2t = db.Queryable<OrderSpliteTest>()
.SplitTable(DateTime.Now.Date.AddYears(-1), DateTime.Now)
.ToPageList(1,2); 
2021-11-09 02:54:19 +08:00
```
2021-11-24 09:45:56 +08:00
### Feature10 : Big data insert or update
2021-11-24 09:45:56 +08:00
```cs
2024-03-13 16:50:12 +08:00
10.1 BulkCopy
2024-03-13 16:49:20 +08:00
db.Fastest<Order>().BulkCopy(lstData);//insert
db.Fastest<Order>().PageSize(100000).BulkCopy(insertObjs);
db.Fastest<System.Data.DataTable>().AS("order").BulkCopy(dataTable);
2021-11-24 09:45:56 +08:00
2024-03-13 16:50:12 +08:00
10.2 BulkUpdate
2024-03-13 16:49:20 +08:00
db.Fastest<Order>().BulkUpdate(GetList())//update
db.Fastest<Order>().PageSize(100000).BulkUpdate(GetList())
db.Fastest<Order>().BulkUpdate(GetList(),new string[] { "Id"});//no primary key
db.Fastest<Order>().BulkUpdate(GetList(), new string[]{"id"},
new string[]{"name","time"})//Set the updated column
//DataTable
db.Fastest<System.Data.DataTable>().AS("Order").BulkUpdate(dataTable,"Id");//Id is primary key
db.Fastest<System.Data.DataTable>().AS("Order").BulkUpdate(dataTable,"Id",Set the updated column);
2024-03-13 16:50:12 +08:00
10.3 BulkMerge 5.1.4.109
2024-03-13 16:49:20 +08:00
db.Fastest<Order>().BulkMerge(List);
db.Fastest<Order>().PageSize(100000).BulkMerge(List);
2021-11-24 09:45:56 +08:00
2024-03-13 16:49:20 +08:00
2024-03-13 16:50:12 +08:00
10.4 BulkQuery
2024-03-13 16:49:20 +08:00
db.Queryable<Order>().ToList();//Slightly faster than Dapper
//Suitable for big data export
List<Order> order = new List<Order>();
db.Queryable<Order>().ForEach(it=> { order.Add(it); } ,2000);
2024-03-13 16:50:12 +08:00
10.5 BulkDelete
2024-03-13 16:49:20 +08:00
db.Deleteable<Order>(list).PageSize(1000).ExecuteCommand();
2021-11-24 09:45:56 +08:00
```