You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
130 lines
5.4 KiB
130 lines
5.4 KiB
using System;
|
|
using System.Linq;
|
|
using System.Text;
|
|
|
|
namespace SqlSugar
|
|
{
|
|
public class OracleInsertBuilder : InsertBuilder
|
|
{
|
|
public override string SqlTemplate
|
|
{
|
|
get
|
|
{
|
|
return @"INSERT INTO {0}
|
|
({1})
|
|
VALUES
|
|
({2}) ";
|
|
|
|
}
|
|
}
|
|
public override string SqlTemplateBatch
|
|
{
|
|
get
|
|
{
|
|
return "INSERT INTO {0} ({1})";
|
|
}
|
|
}
|
|
public override string ToSqlString()
|
|
{
|
|
var identities = this.EntityInfo.Columns.Where(it => it.OracleSequenceName.HasValue()).ToList();
|
|
if (IsNoInsertNull)
|
|
{
|
|
DbColumnInfoList = DbColumnInfoList.Where(it => it.Value != null).ToList();
|
|
}
|
|
var groupList = DbColumnInfoList.GroupBy(it => it.TableId).ToList();
|
|
var isSingle = groupList.Count() == 1;
|
|
var columnsString = string.Join(",", groupList.First().Select(it => Builder.GetTranslationColumnName(it.DbColumnName)));
|
|
if (isSingle)
|
|
{
|
|
var columnParametersString = string.Join(",", this.DbColumnInfoList.Select(it => Builder.SqlParameterKeyWord + it.DbColumnName));
|
|
if (identities.HasValue())
|
|
{
|
|
columnsString = columnsString.TrimEnd(',') + "," + string.Join(",", identities.Select(it => Builder.GetTranslationColumnName(it.DbColumnName)));
|
|
columnParametersString = columnParametersString.TrimEnd(',') + "," + string.Join(",", identities.Select(it => it.OracleSequenceName + ".nextval"));
|
|
}
|
|
return string.Format(SqlTemplate, GetTableNameString, columnsString, columnParametersString);
|
|
}
|
|
else
|
|
{
|
|
var batchInsetrSql = new StringBuilder();
|
|
var pageSize = 200;
|
|
var pageIndex = 1;
|
|
var totalRecord = groupList.Count;
|
|
var pageCount = (totalRecord + pageSize - 1) / pageSize;
|
|
if (identities.HasValue())
|
|
{
|
|
columnsString = columnsString.TrimEnd(',') + "," + string.Join(",", identities.Select(it => Builder.GetTranslationColumnName(it.DbColumnName)));
|
|
}
|
|
while (pageCount >= pageIndex)
|
|
{
|
|
batchInsetrSql.AppendFormat(SqlTemplateBatch, GetTableNameString, columnsString);
|
|
var i = 0;
|
|
foreach (var columns in groupList.Skip((pageIndex - 1) * pageSize).Take(pageSize).ToList())
|
|
{
|
|
var isFirst = i == 0;
|
|
if (!isFirst)
|
|
{
|
|
batchInsetrSql.Append(SqlTemplateBatchUnion);
|
|
}
|
|
var insertColumns = string.Join(",", columns.Select(it => string.Format(SqlTemplateBatchSelect, FormatValue(it.Value), Builder.GetTranslationColumnName(it.DbColumnName))));
|
|
if (identities.HasValue())
|
|
{
|
|
insertColumns = insertColumns.TrimEnd(',') + "," + string.Join(",", identities.Select(it =>
|
|
{
|
|
var seqValue = this.OracleSeqInfoList[it.OracleSequenceName];
|
|
this.OracleSeqInfoList[it.OracleSequenceName] = this.OracleSeqInfoList[it.OracleSequenceName] + 1;
|
|
return seqValue + 1+" AS "+it.DbColumnName;
|
|
}));
|
|
}
|
|
batchInsetrSql.Append("\r\n SELECT " + insertColumns + " FROM DUAL ");
|
|
++i;
|
|
}
|
|
pageIndex++;
|
|
batchInsetrSql.Append("\r\n;\r\n");
|
|
}
|
|
return "BEGIN\r\n"+ batchInsetrSql.ToString()+"\r\nEND;";
|
|
}
|
|
}
|
|
public override object FormatValue(object value)
|
|
{
|
|
if (value == null)
|
|
{
|
|
return "NULL";
|
|
}
|
|
else
|
|
{
|
|
var type = value.GetType();
|
|
if (type == UtilConstants.DateType)
|
|
{
|
|
var date = value.ObjToDate();
|
|
if (date < Convert.ToDateTime("1900-1-1"))
|
|
{
|
|
date = Convert.ToDateTime("1900-1-1");
|
|
}
|
|
return "to_date('"+ date.ToString("yyyy-MM-dd HH:mm:ss") + "', 'YYYY-MM-DD HH24:MI:SS') ";
|
|
}
|
|
else if (type.IsEnum())
|
|
{
|
|
return Convert.ToInt64(value);
|
|
}
|
|
else if (type == UtilConstants.ByteArrayType)
|
|
{
|
|
var bytesString = "0x" + BitConverter.ToString((byte[])value);
|
|
return bytesString;
|
|
}
|
|
else if (type == UtilConstants.BoolType)
|
|
{
|
|
return value.ObjToBool() ? "1" : "0";
|
|
}
|
|
else if (type == UtilConstants.StringType || type == UtilConstants.ObjType)
|
|
{
|
|
return "N'" + value.ToString().ToSqlFilter() + "'";
|
|
}
|
|
else
|
|
{
|
|
return "N'" + value.ToString() + "'";
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|