mirror of
https://gitee.com/dotnetchina/SqlSugar.git
synced 2025-09-20 10:38:09 +08:00
Update db.InsertNav
This commit is contained in:
@@ -81,12 +81,20 @@ namespace SqlSugar
|
|||||||
children = children.Distinct().ToList();
|
children = children.Distinct().ToList();
|
||||||
var x = this._Context.Storageable(children).WhereColumns(new string[] { pkColumn.PropertyName }).ToStorage();
|
var x = this._Context.Storageable(children).WhereColumns(new string[] { pkColumn.PropertyName }).ToStorage();
|
||||||
var insertData = children = x.InsertList.Select(it => it.Item).ToList();
|
var insertData = children = x.InsertList.Select(it => it.Item).ToList();
|
||||||
if (_NavigateType == NavigateType.OneToMany&&IsFirst==false)
|
var IsNoExistsNoInsert = _navOptions != null && _navOptions.OneToManyIfExistsNoInsert == true;
|
||||||
|
if (_NavigateType == NavigateType.OneToMany && IsFirst == false && IsNoExistsNoInsert == false)
|
||||||
{
|
{
|
||||||
var updateData = x.UpdateList.Select(it => it.Item).ToList();
|
var updateData = x.UpdateList.Select(it => it.Item).ToList();
|
||||||
ClearPk(updateData, pkColumn);
|
ClearPk(updateData, pkColumn);
|
||||||
insertData.AddRange(updateData);
|
insertData.AddRange(updateData);
|
||||||
}
|
}
|
||||||
|
else if (_NavigateType == NavigateType.OneToMany && IsNoExistsNoInsert == true)
|
||||||
|
{
|
||||||
|
children = new List<TChild>();
|
||||||
|
children.AddRange(x.InsertList.Select(it => it.Item).ToList());
|
||||||
|
var updateData = x.UpdateList.Select(it => it.Item).ToList();
|
||||||
|
children.AddRange(updateData);
|
||||||
|
}
|
||||||
Check.ExceptionEasy(pkColumn==null&&NavColumn==null,$"The entity is invalid",$"实体错误无法使用导航");
|
Check.ExceptionEasy(pkColumn==null&&NavColumn==null,$"The entity is invalid",$"实体错误无法使用导航");
|
||||||
InitData(pkColumn, insertData);
|
InitData(pkColumn, insertData);
|
||||||
this._ParentList = children.Cast<object>().ToList();
|
this._ParentList = children.Cast<object>().ToList();
|
||||||
|
Reference in New Issue
Block a user