sqlsugar/Src/OracleUS7ASCII/SqlSugar/Realization/Dm/SqlBuilder/DmInsertBuilder.cs

104 lines
3.8 KiB
C#
Raw Normal View History

2025-05-11 16:20:50 +08:00
using System;
using System.Linq;
using System.Text;
namespace SqlSugar
{
public class DmInsertBuilder : InsertBuilder
{
public override string SqlTemplate
{
get
{
if (IsReturnIdentity)
{
return @"INSERT INTO {0}
({1})
VALUES
({2}) ;select @@identity";
}
else
{
return @"INSERT INTO {0}
({1})
VALUES
({2}) ;";
}
}
}
public override string SqlTemplateBatchUnion
{
get
{
return "\t\r\nUNION ALL ";
}
}
public override string SqlTemplateBatch => "INSERT INTO {0} ({1})";
public override string SqlTemplateBatchSelect => " {0} ";
public override string ToSqlString()
{
return base.ToSqlString();
}
//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 => 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 =>
// {
// 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();
// }
//}
}
}