FreeSql是一個功能強大的 .NET ORM 功能庫,支持 .NetFramework 4.0+、.NetCore 2.1+、Xamarin 等支持 NetStandard 全部運行平臺。html
以 MIT 開源協議託管於 github:https://github.com/2881099/FreeSqlgit
FreeSql 插入數據的方式有多種,這篇文章教你用最優的方案作數據插入功能。github
static IFreeSql fsql = new FreeSql.FreeSqlBuilder() .UseConnectionString(FreeSql.DataType.Sqlite, "Data Source=db1.db") .UseAutoSyncStructure(true) //自動同步實體結構到數據庫 .Build(); //請務一定義成 Singleton 單例模式 public class Blog { [Column(IsIdentity = true, IsPrimary = true)] public int BlogId { get; set; } public string Url { get; set; } public int Rating { get; set; } } var blog = new Blog { Url = "https://github.com/2881099/FreeSql", Rating = 5 };
若是表有自增列,插入數據後應該要返回 id。sql
方法1:(原始)數據庫
long id = fsql.Insert(blog).ExecuteIdentity(); blog.Id = id;
方法2:(依賴 FreeSql.Repository)ide
var repo = fsql.GetRepository<Blog>(); repo.Insert(blog);
將插入後的自增值,填充給 blog.Id函數
方法3:(依賴 FreeSql.DbContext)性能
using (var ctx = fsql.CreateDbContext()) { ctx.Add(blog); ctx.SaveChanges(); }
將插入後的自增值,填充給 blog.Id學習
var items = new List<Topic>(); for (var a = 0; a < 10; a++) { items.Add(new Blog { Url = "https://github.com/2881099/FreeSql", Rating = 5 }); }
方法1:(原始)ui
fsql.Insert(items).ExecuteAffrows();
沒法返回 items 全部 id 值
方法2:(依賴 FreeSql.Repository)
var repo = fsql.GetRepository<Blog>(); repo.Insert(items);
將插入後的自增值,填充給全部 items.Id
當操做的是 SqlServer/PostgreSql 數據庫,此方法爲一次執行,返回全部 id
當操做的是其餘數據庫,此方法爲循環屢次執行,返回全部 id(注意性能問題)
針對 SqlServer/PostgreSQL/MySql 數據庫,目前能在如下實現使用:
fsql.Insert(items).ExecuteSqlBulkCopy(); fsql.Insert(items).ExecutePgCopy(); fsql.Insert(items).ExecuteMySqlBulkCopy();
另外 IInsert 方法提供了 ToDataTable() 方法返回 DataTable 對象,讓使用者本身封裝 BulkCopy 操做。
DataTable dt = fsql.Insert(items) .InsertIdentity() //開啓自增 id 插入 .ToDataTable();
注意:InsertIdentity() 的功能是生成 SQL 的時候有值,而不是調用 SET IDENTITY ON;
《新人學習指引》 | 《Select》 | 《Update》 | 《Insert》 | 《Delete》 | |
《表達式函數》 | 《CodeFirst》 | 《DbFirst》 | 《BaseEntity》 | |
《Repository》 | 《UnitOfWork》 | 《過濾器》 | 《樂觀鎖》 | 《DbContext》 | |
《讀寫分離》 | 《分區分表》 | 《租戶》 | 《AOP》 | 《黑科技》 | 更新日誌 |