From a809dd251732baeb2772b699063a1e0c33fe19df Mon Sep 17 00:00:00 2001 From: 2881099 <2881099@qq.com> Date: Mon, 11 Sep 2023 12:40:02 +0800 Subject: [PATCH] =?UTF-8?q?-=20=E4=BF=AE=E5=A4=8D=20IUpdateJoin=20+=20?= =?UTF-8?q?=E5=85=A8=E5=B1=80=E8=BF=87=E6=BB=A4=E5=99=A8=20+=20=E4=BB=8E?= =?UTF-8?q?=E8=A1=A8=E4=B8=8D=E7=94=9F=E6=95=88=E9=97=AE=E9=A2=98=EF=BC=9B?= =?UTF-8?q?#1612?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Examples/base_entity/Program.cs | 7 ++ FreeSql.DbContext/FreeSql.DbContext.xml | 18 ++++ FreeSql/FreeSql.xml | 98 +++++++++++++++++++ .../CommonProvider/UpdateJoinProvider.cs | 11 +++ 4 files changed, 134 insertions(+) diff --git a/Examples/base_entity/Program.cs b/Examples/base_entity/Program.cs index 53ac123a..2a288c0d 100644 --- a/Examples/base_entity/Program.cs +++ b/Examples/base_entity/Program.cs @@ -600,6 +600,13 @@ namespace base_entity BaseEntity.Initialization(fsql, () => _asyncUow.Value); #endregion + fsql.GlobalFilter.Apply("test01", a => a.IsDeleted == false); + + var updatejoin031sql = fsql.Update() + .Join((a, b) => a.GroupId == b.Id) + .Set((a, b) => b.GroupName == a.Username + "b.groupname") + .ToSql(); + fsql.UseJsonMap(); fsql.Select().Where(a => a.FormLocking == null).Count(); diff --git a/FreeSql.DbContext/FreeSql.DbContext.xml b/FreeSql.DbContext/FreeSql.DbContext.xml index 594fbad3..26522f10 100644 --- a/FreeSql.DbContext/FreeSql.DbContext.xml +++ b/FreeSql.DbContext/FreeSql.DbContext.xml @@ -733,6 +733,15 @@ + + + 根据Assembly扫描所有继承IEntityTypeConfiguration<T>的配置类 + + + + + + 创建普通数据上下文档对象 @@ -791,5 +800,14 @@ + + + 批量注入 Repository,可以参考代码自行调整 + + + + + + diff --git a/FreeSql/FreeSql.xml b/FreeSql/FreeSql.xml index 9e33336b..368317df 100644 --- a/FreeSql/FreeSql.xml +++ b/FreeSql/FreeSql.xml @@ -1084,6 +1084,82 @@ + + + 动态创建实体类型 + + + + + 配置Class + + 类名 + 类标记的特性[Table(Name = "xxx")] [Index(xxxx)] + + + + + 配置属性 + + 属性名称 + 属性类型 + 属性标记的特性-支持多个 + + + + + 配置属性 + + 属性名称 + 属性类型 + 该属性是否重写父类属性 + 属性标记的特性-支持多个 + + + + + 配置属性 + + 属性名称 + 属性类型 + 该属性是否重写父类属性 + 属性默认值 + 属性标记的特性-支持多个 + + + + + 配置父类 + + 父类类型 + + + + + Override属性 + + + + + + Emit动态创建出Class - Type + + + + + + 首字母小写 + + + + + + + 首字母大写 + + + + 获取实体的主键值,以 "*|_,[,_|*" 分割,当任意一个主键属性无值时,返回 null @@ -5748,6 +5824,28 @@ 请使用 fsql.InsertDict(dict) 方法插入字典数据 + + + 动态构建Class Type + + + + + + 根据字典,创建 table 对应的实体对象 + + + + + + + + 根据实体对象,创建 table 对应的字典 + + + + + C#: that >= between && that <= and diff --git a/FreeSql/Internal/CommonProvider/UpdateJoinProvider.cs b/FreeSql/Internal/CommonProvider/UpdateJoinProvider.cs index b8c5360f..ce7e9241 100644 --- a/FreeSql/Internal/CommonProvider/UpdateJoinProvider.cs +++ b/FreeSql/Internal/CommonProvider/UpdateJoinProvider.cs @@ -45,9 +45,20 @@ namespace FreeSql.Internal.CommonProvider _query2Provider = _query2 as Select2Provider; _query2Provider._where.Clear(); + + var t2globalFilterBefore = _commonExpression.GetWhereCascadeSql(_query2Provider._tables[1], _updateProvider._whereGlobalFilter.Where(a => a.Before == true), true); + if (string.IsNullOrWhiteSpace(t2globalFilterBefore) == false) + _query2Provider._where.Append(" AND ").Append(t2globalFilterBefore); + _query2.Where(on); + + var t2globalFilter = _commonExpression.GetWhereCascadeSql(_query2Provider._tables[1], _updateProvider._whereGlobalFilter.Where(a => a.Before == false), true); + if (string.IsNullOrWhiteSpace(t2globalFilter) == false) + _query2Provider._where.Append(" AND ").Append(t2globalFilter); + _joinOn = _query2Provider._where.ToString(); if (_joinOn.StartsWith(" AND ")) _joinOn = _joinOn.Substring(5); + _query2Provider._where.Clear(); _updateProvider.Where("1=1"); }