| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- using System;
- using System.Linq;
- using System.Text;
- namespace SqlSugar
- {
- public class OscarInsertBuilder : InsertBuilder
- {
- public override string SqlTemplate
- {
- get
- {
- if (IsReturnIdentity)
- {
- return @"INSERT INTO {0}
- ({1})
- VALUES
- ({2}) returning $PrimaryKey";
- }
- else
- {
- return @"INSERT INTO {0}
- ({1})
- VALUES
- ({2}) ;";
- }
- }
- }
- public override string SqlTemplateBatch => "INSERT INTO {0} ({1})";
- public override string SqlTemplateBatchUnion => " VALUES ";
- public override string SqlTemplateBatchSelect => " {0} ";
- public override string ToSqlString()
- {
- if (IsNoInsertNull)
- {
- DbColumnInfoList = DbColumnInfoList.Where(it => it.Value != null).ToList();
- }
- var groupList = DbColumnInfoList.GroupBy(it => it.TableId).ToList();
- var isSingle = groupList.Count() == 1;
- string columnsString = string.Join(",", groupList.First().Select(it =>base.GetDbColumn(it, Builder.GetTranslationColumnName(it.DbColumnName))));
- if (isSingle)
- {
- string columnParametersString = string.Join(",", this.DbColumnInfoList.Select(it => Builder.SqlParameterKeyWord + it.DbColumnName));
- return string.Format(SqlTemplate, GetTableNameString, columnsString, columnParametersString);
- }
- else
- {
- StringBuilder batchInsetrSql = new StringBuilder();
- int pageSize = 200;
- int pageIndex = 1;
- int totalRecord = groupList.Count;
- int pageCount = (totalRecord + pageSize - 1) / pageSize;
- while (pageCount >= pageIndex)
- {
- batchInsetrSql.AppendFormat(SqlTemplateBatch, GetTableNameString, columnsString);
- int i = 0;
- foreach (var columns in groupList.Skip((pageIndex - 1) * pageSize).Take(pageSize).ToList())
- {
- var isFirst = i == 0;
- if (isFirst)
- {
- batchInsetrSql.Append(SqlTemplateBatchUnion);
- }
- batchInsetrSql.Append("\r\n ( " + string.Join(",", columns.Select(it =>
- {
- if (it.InsertServerTime || it.InsertSql.HasValue())
- {
- return GetDbColumn(it, null);
- }
- object value = null;
- if (it.Value is DateTime)
- {
- value = ((DateTime)it.Value).ToString("O");
- }
- else
- {
- value = it.Value;
- }
- if (value == null||value==DBNull.Value)
- {
- return string.Format(SqlTemplateBatchSelect, "NULL");
- }
- return string.Format(SqlTemplateBatchSelect, "'" + value.ObjToString().ToSqlFilter() + "'");
- })) + "),");
- ++i;
- }
- pageIndex++;
- batchInsetrSql.Remove(batchInsetrSql.Length - 1,1).Append("\r\n;\r\n");
- }
- return batchInsetrSql.ToString();
- }
- }
- }
- }
|