var connstr = "Data Source=127.0.0.1;Port=3306;User ID=root;Password=root;" +
"Initial Catalog=cccddd;Charset=utf8;SslMode=none;Max pool size=10"; IFreeSql
fsql = new FreeSql.FreeSqlBuilder()
.UseConnectionString(FreeSql.DataType.MySql, connstr)
.UseAutoSyncStructure(true) //自動(dòng)同步實(shí)體結(jié)構(gòu)到數(shù)據(jù)庫(kù) .Build(); [Table(Name = "tb_topic")]
class Topic { [Column(IsIdentity = true, IsPrimary = true)] public int Id {
get; set; } public int Clicks { get; set; } public string Title { get; set; }
public DateTime CreateTime { get; set; } }
批量插入
var items = new List<Topic>(); for (var a = 0; a < 10; a++) items.Add(new
Topic { Id = a + 1, Title = $"newtitle{a}", Clicks = a * 100 });
fsql.Insert<Topic>(items).ExecuteAffrows();
執(zhí)行SQL如下:
INSERT INTO `tb_topic`(`Clicks`, `Title`, `CreateTime`) VALUES(?Clicks0,
?Title0, ?CreateTime0), (?Clicks1, ?Title1, ?CreateTime1), (?Clicks2, ?Title2,
?CreateTime2), (?Clicks3, ?Title3, ?CreateTime3), (?Clicks4, ?Title4,
?CreateTime4), (?Clicks5, ?Title5, ?CreateTime5), (?Clicks6, ?Title6,
?CreateTime6), (?Clicks7, ?Title7, ?CreateTime7), (?Clicks8, ?Title8,
?CreateTime8), (?Clicks9, ?Title9, ?CreateTime9)
內(nèi)部設(shè)計(jì)
當(dāng)插入大批量數(shù)據(jù)時(shí),內(nèi)部采用分割分批執(zhí)行的邏輯進(jìn)行。分割規(guī)則如下:
數(shù)量 參數(shù)量
MySql 5000 3000
PostgreSQL 5000 3000
SqlServer 1000 2100
Oracle 500 999
Sqlite 5000 999
數(shù)據(jù):為每批分割的大小,如批量插入 10000 條數(shù)據(jù),在 mysql 執(zhí)行時(shí)會(huì)分割為兩批。
參數(shù)量:為每批分割的參數(shù)量大小,如批量插入 10000 條數(shù)據(jù),每行需要使用 5 個(gè)參數(shù)化,在 mysql 執(zhí)行時(shí)會(huì)分割為每批 3000 / 5。
分割執(zhí)行后,當(dāng)外部未提供事務(wù)時(shí),內(nèi)部自開(kāi)事務(wù),實(shí)現(xiàn)插入完整性。
FreeSql 適配了每一種數(shù)據(jù)類(lèi)型參數(shù)化,和不參數(shù)化的使用。批量插入建議關(guān)閉參數(shù)化功能,使用 .NonoParameter() 進(jìn)行執(zhí)行(有關(guān)
NoneParameter 在后續(xù)文章介紹)。
性能參考
API
方法 返回值 參數(shù) 描述
AppendData <this> T1 | IEnumerable 追加準(zhǔn)備插入的實(shí)體
ToSql string 返回即將執(zhí)行的SQL語(yǔ)句
ExecuteAffrows long 執(zhí)行SQL語(yǔ)句,返回影響的行數(shù)
ExecuteIdentity long 執(zhí)行SQL語(yǔ)句,返回自增值
ExecuteInserted List<T1> 執(zhí)行SQL語(yǔ)句,返回插入后的記錄
系列文章導(dǎo)航
*
(一)入門(mén) <https://www.cnblogs.com/FreeSql/p/11531300.html>
*
(二)自動(dòng)遷移實(shí)體 <https://www.cnblogs.com/FreeSql/p/11531301.html>
*
(三)實(shí)體特性 <https://www.cnblogs.com/FreeSql/p/11531302.html>
*
(四)實(shí)體特性 Fluent Api <https://www.cnblogs.com/FreeSql/p/11531304.html>
*
(五)插入數(shù)據(jù) <https://www.cnblogs.com/FreeSql/p/11531306.html>
*
(六)批量插入數(shù)據(jù)
*
(七)插入數(shù)據(jù)時(shí)忽略列 <https://www.cnblogs.com/FreeSql/p/11531316.html>
*
(八)插入數(shù)據(jù)時(shí)指定列 <https://www.cnblogs.com/FreeSql/p/11531318.html>
*
(九)刪除數(shù)據(jù) <https://www.cnblogs.com/FreeSql/p/11531320.html>
*
(十)更新數(shù)據(jù) <https://www.cnblogs.com/FreeSql/p/11531321.html>
*
(十一)更新數(shù)據(jù) Where <https://www.cnblogs.com/FreeSql/p/11531324.html>
*
(十二)更新數(shù)據(jù)時(shí)指定列 <https://www.cnblogs.com/FreeSql/p/11531327.html>
*
(十三)更新數(shù)據(jù)時(shí)忽略列 <https://www.cnblogs.com/FreeSql/p/11531334.html>
*
(十四)批量更新數(shù)據(jù) <https://www.cnblogs.com/FreeSql/p/11531335.html>
*
(十五)查詢(xún)數(shù)據(jù) <https://www.cnblogs.com/FreeSql/p/11531339.html>
*
(十六)分頁(yè)查詢(xún) <https://www.cnblogs.com/FreeSql/p/11531341.html>
*
(十七)聯(lián)表查詢(xún) <https://www.cnblogs.com/FreeSql/p/11531346.html>
*
(十八)導(dǎo)航屬性 <https://www.cnblogs.com/FreeSql/p/11531352.html>
*
(十九)多表查詢(xún) <https://www.cnblogs.com/FreeSql/p/11531362.html>
*
(二十)多表查詢(xún) WhereCascade <https://www.cnblogs.com/FreeSql/p/11531372.html>
*
(二十一)查詢(xún)返回?cái)?shù)據(jù) <https://www.cnblogs.com/FreeSql/p/11531376.html>
*
(二十二)Dto 映射查詢(xún) <https://www.cnblogs.com/FreeSql/p/11531381.html>
*
(二十三)分組、聚合 <https://www.cnblogs.com/FreeSql/p/11531384.html>
*
(二十四)Linq To Sql 語(yǔ)法使用介紹 <https://www.cnblogs.com/FreeSql/p/11531392.html>
*
(二十五)延時(shí)加載 <https://www.cnblogs.com/FreeSql/p/11531395.html>
*
(二十六)貪婪加載 Include、IncludeMany、Dto、ToList
<https://www.cnblogs.com/FreeSql/p/11531404.html>
*
(二十七)將已寫(xiě)好的 SQL 語(yǔ)句,與實(shí)體類(lèi)映射進(jìn)行二次查詢(xún)
<https://www.cnblogs.com/FreeSql/p/11531416.html>
*
(二十八)事務(wù) <https://www.cnblogs.com/FreeSql/p/11531423.html>
*
(二十九)Lambda 表達(dá)式 <https://www.cnblogs.com/FreeSql/p/11531425.html>
*
(三十)讀寫(xiě)分離 <https://www.cnblogs.com/FreeSql/p/11531430.html>
*
(三十一)分區(qū)分表 <https://www.cnblogs.com/FreeSql/p/11531435.html>
*
(三十二)Aop <https://www.cnblogs.com/FreeSql/p/11531471.html>
*
(三十三)CodeFirst 類(lèi)型映射 <https://www.cnblogs.com/FreeSql/p/11531543.html>
*
(三十四)CodeFirst 遷移說(shuō)明 <https://www.cnblogs.com/FreeSql/p/11531550.html>
*
(三十五)CodeFirst 自定義特性 <https://www.cnblogs.com/FreeSql/p/11531576.html>
熱門(mén)工具 換一換
