mirror of
				https://github.com/nsnail/FreeSql.git
				synced 2025-11-04 09:15:27 +08:00 
			
		
		
		
	- add Oracle ToSqlBatchIdentityColumn
This commit is contained in:
		@@ -130,6 +130,13 @@
 | 
				
			|||||||
            清空状态数据
 | 
					            清空状态数据
 | 
				
			||||||
            </summary>
 | 
					            </summary>
 | 
				
			||||||
        </member>
 | 
					        </member>
 | 
				
			||||||
 | 
					        <member name="M:FreeSql.DbSet`1.RemoveAsync(System.Linq.Expressions.Expression{System.Func{`0,System.Boolean}})">
 | 
				
			||||||
 | 
					            <summary>
 | 
				
			||||||
 | 
					            根据 lambda 条件删除数据
 | 
				
			||||||
 | 
					            </summary>
 | 
				
			||||||
 | 
					            <param name="predicate"></param>
 | 
				
			||||||
 | 
					            <returns></returns>
 | 
				
			||||||
 | 
					        </member>
 | 
				
			||||||
        <member name="M:FreeSql.DbSet`1.Add(`0)">
 | 
					        <member name="M:FreeSql.DbSet`1.Add(`0)">
 | 
				
			||||||
            <summary>
 | 
					            <summary>
 | 
				
			||||||
            添加
 | 
					            添加
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -131,7 +131,7 @@ public static partial class FreeSqlGlobalExtensions
 | 
				
			|||||||
        if (that == null) return null;
 | 
					        if (that == null) return null;
 | 
				
			||||||
        if (that == typeof(string)) return default(string);
 | 
					        if (that == typeof(string)) return default(string);
 | 
				
			||||||
        if (that == typeof(Guid)) return default(Guid);
 | 
					        if (that == typeof(Guid)) return default(Guid);
 | 
				
			||||||
        if (that.IsArray) return Array.CreateInstance(that, 0);
 | 
					        if (that.IsArray) return Array.CreateInstance(that.GetElementType(), 0);
 | 
				
			||||||
        if (that.IsInterface || that.IsAbstract) return null;
 | 
					        if (that.IsInterface || that.IsAbstract) return null;
 | 
				
			||||||
        var ctorParms = that.InternalGetTypeConstructor0OrFirst(false)?.GetParameters();
 | 
					        var ctorParms = that.InternalGetTypeConstructor0OrFirst(false)?.GetParameters();
 | 
				
			||||||
        if (ctorParms == null || ctorParms.Any() == false) return Activator.CreateInstance(that, true);
 | 
					        if (ctorParms == null || ctorParms.Any() == false) return Activator.CreateInstance(that, true);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -4514,190 +4514,3 @@
 | 
				
			|||||||
        </member>
 | 
					        </member>
 | 
				
			||||||
    </members>
 | 
					    </members>
 | 
				
			||||||
</doc>
 | 
					</doc>
 | 
				
			||||||
essions.Expression{System.Func{``0,``1,``2,``3,``4,System.Boolean}},System.Linq.Expressions.Expression{System.Func{``0,``1,``2,``3,``4,System.Boolean}})">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            使用 and 拼接两个 lambda 表达式
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:System.Linq.Expressions.LambadaExpressionExtensions.And``5(System.Linq.Expressions.Expression{System.Func{``0,``1,``2,``3,``4,System.Boolean}},System.Boolean,System.Linq.Expressions.Expression{System.Func{``0,``1,``2,``3,``4,System.Boolean}})">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            使用 and 拼接两个 lambda 表达式
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <param name="exp1"></param>
 | 
					 | 
				
			||||||
            <param name="condition">true 时生效</param>
 | 
					 | 
				
			||||||
            <param name="exp2"></param>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:System.Linq.Expressions.LambadaExpressionExtensions.Or``5(System.Linq.Expressions.Expression{System.Func{``0,``1,``2,``3,``4,System.Boolean}},System.Linq.Expressions.Expression{System.Func{``0,``1,``2,``3,``4,System.Boolean}})">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            使用 or 拼接两个 lambda 表达式
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:System.Linq.Expressions.LambadaExpressionExtensions.Or``5(System.Linq.Expressions.Expression{System.Func{``0,``1,``2,``3,``4,System.Boolean}},System.Boolean,System.Linq.Expressions.Expression{System.Func{``0,``1,``2,``3,``4,System.Boolean}})">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            使用 or 拼接两个 lambda 表达式
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <param name="exp1"></param>
 | 
					 | 
				
			||||||
            <param name="condition">true 时生效</param>
 | 
					 | 
				
			||||||
            <param name="exp2"></param>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:System.Linq.Expressions.LambadaExpressionExtensions.Not``5(System.Linq.Expressions.Expression{System.Func{``0,``1,``2,``3,``4,System.Boolean}},System.Boolean)">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            将 lambda 表达式取反
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <param name="exp"></param>
 | 
					 | 
				
			||||||
            <param name="condition">true 时生效</param>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:FreeUtil.NewMongodbId">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            生成类似Mongodb的ObjectId有序、不重复Guid
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:IFreeSql.Insert``1">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            插入数据
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <typeparam name="T1"></typeparam>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:IFreeSql.Insert``1(``0)">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            插入数据,传入实体
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <typeparam name="T1"></typeparam>
 | 
					 | 
				
			||||||
            <param name="source"></param>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:IFreeSql.Insert``1(``0[])">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            插入数据,传入实体数组
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <typeparam name="T1"></typeparam>
 | 
					 | 
				
			||||||
            <param name="source"></param>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:IFreeSql.Insert``1(System.Collections.Generic.List{``0})">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            插入数据,传入实体集合
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <typeparam name="T1"></typeparam>
 | 
					 | 
				
			||||||
            <param name="source"></param>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:IFreeSql.Insert``1(System.Collections.Generic.IEnumerable{``0})">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            插入数据,传入实体集合
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <typeparam name="T1"></typeparam>
 | 
					 | 
				
			||||||
            <param name="source"></param>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:IFreeSql.InsertOrUpdate``1">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            插入或更新数据,此功能依赖数据库特性(低版本可能不支持),参考如下:<para></para>
 | 
					 | 
				
			||||||
            MySql 5.6+: on duplicate key update<para></para>
 | 
					 | 
				
			||||||
            PostgreSQL 9.4+: on conflict do update<para></para>
 | 
					 | 
				
			||||||
            SqlServer 2008+: merge into<para></para>
 | 
					 | 
				
			||||||
            Oracle 11+: merge into<para></para>
 | 
					 | 
				
			||||||
            Sqlite: replace into<para></para>
 | 
					 | 
				
			||||||
            达梦: merge into<para></para>
 | 
					 | 
				
			||||||
            人大金仓:on conflict do update<para></para>
 | 
					 | 
				
			||||||
            神通:merge into<para></para>
 | 
					 | 
				
			||||||
            MsAccess:不支持<para></para>
 | 
					 | 
				
			||||||
            注意区别:FreeSql.Repository 仓储也有 InsertOrUpdate 方法(不依赖数据库特性)
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <typeparam name="T1"></typeparam>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:IFreeSql.Update``1">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            修改数据
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <typeparam name="T1"></typeparam>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:IFreeSql.Update``1(System.Object)">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            修改数据,传入动态条件,如:主键值 | new[]{主键值1,主键值2} | TEntity1 | new[]{TEntity1,TEntity2} | new{id=1}
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <typeparam name="T1"></typeparam>
 | 
					 | 
				
			||||||
            <param name="dywhere">主键值、主键值集合、实体、实体集合、匿名对象、匿名对象集合</param>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:IFreeSql.Select``1">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            查询数据
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <typeparam name="T1"></typeparam>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:IFreeSql.Select``1(System.Object)">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            查询数据,传入动态条件,如:主键值 | new[]{主键值1,主键值2} | TEntity1 | new[]{TEntity1,TEntity2} | new{id=1}
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <typeparam name="T1"></typeparam>
 | 
					 | 
				
			||||||
            <param name="dywhere">主键值、主键值集合、实体、实体集合、匿名对象、匿名对象集合</param>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:IFreeSql.Delete``1">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            删除数据
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <typeparam name="T1"></typeparam>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:IFreeSql.Delete``1(System.Object)">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            删除数据,传入动态条件,如:主键值 | new[]{主键值1,主键值2} | TEntity1 | new[]{TEntity1,TEntity2} | new{id=1}
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <typeparam name="T1"></typeparam>
 | 
					 | 
				
			||||||
            <param name="dywhere">主键值、主键值集合、实体、实体集合、匿名对象、匿名对象集合</param>
 | 
					 | 
				
			||||||
            <returns></returns>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:IFreeSql.Transaction(System.Action)">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            开启事务(不支持异步)<para></para>
 | 
					 | 
				
			||||||
            v1.5.0 关闭了线程事务超时自动提交的机制
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <param name="handler">事务体 () => {}</param>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="M:IFreeSql.Transaction(System.Data.IsolationLevel,System.Action)">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            开启事务(不支持异步)<para></para>
 | 
					 | 
				
			||||||
            v1.5.0 关闭了线程事务超时自动提交的机制
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
            <param name="isolationLevel"></param>
 | 
					 | 
				
			||||||
            <param name="handler">事务体 () => {}</param>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="P:IFreeSql.Ado">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            数据库访问对象
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="P:IFreeSql.Aop">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            所有拦截方法都在这里
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="P:IFreeSql.CodeFirst">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            CodeFirst 模式开发相关方法
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="P:IFreeSql.DbFirst">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            DbFirst 模式开发相关方法
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
        <member name="P:IFreeSql.GlobalFilter">
 | 
					 | 
				
			||||||
            <summary>
 | 
					 | 
				
			||||||
            全局过滤设置,可默认附加为 Select/Update/Delete 条件
 | 
					 | 
				
			||||||
            </summary>
 | 
					 | 
				
			||||||
        </member>
 | 
					 | 
				
			||||||
    </members>
 | 
					 | 
				
			||||||
</doc>
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
@@ -23,6 +23,78 @@ namespace FreeSql.Oracle.Curd
 | 
				
			|||||||
        public override long ExecuteIdentity() => base.SplitExecuteIdentity(_batchValuesLimit > 0 ? _batchValuesLimit : 500, _batchParameterLimit > 0 ? _batchParameterLimit : 999);
 | 
					        public override long ExecuteIdentity() => base.SplitExecuteIdentity(_batchValuesLimit > 0 ? _batchValuesLimit : 500, _batchParameterLimit > 0 ? _batchParameterLimit : 999);
 | 
				
			||||||
        public override List<T1> ExecuteInserted() => base.SplitExecuteInserted(_batchValuesLimit > 0 ? _batchValuesLimit : 500, _batchParameterLimit > 0 ? _batchParameterLimit : 999);
 | 
					        public override List<T1> ExecuteInserted() => base.SplitExecuteInserted(_batchValuesLimit > 0 ? _batchValuesLimit : 500, _batchParameterLimit > 0 ? _batchParameterLimit : 999);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        /// <summary>
 | 
				
			||||||
 | 
					        /// 批量插入时,如果有序列 + DbInsertValue 设置,则用这个
 | 
				
			||||||
 | 
					        /// </summary>
 | 
				
			||||||
 | 
					        /// <returns></returns>
 | 
				
			||||||
 | 
					        public string ToSqlBatchIdentityColumn()
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					            if (_source == null || _source.Any() == false) return null;
 | 
				
			||||||
 | 
					            var cols = new List<ColumnInfo>();
 | 
				
			||||||
 | 
					            foreach (var col in _table.Columns.Values)
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                if (col.Attribute.IsIdentity && _insertIdentity == false && string.IsNullOrEmpty(col.DbInsertValue)) continue;
 | 
				
			||||||
 | 
					                if (col.Attribute.IsIdentity == false && _ignore.ContainsKey(col.Attribute.Name)) continue;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                cols.Add(col);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            _identCol = null;
 | 
				
			||||||
 | 
					            var sb = new StringBuilder();
 | 
				
			||||||
 | 
					            var tmpsb = new StringBuilder();
 | 
				
			||||||
 | 
					            sb.Append("INSERT INTO ").Append(_commonUtils.QuoteSqlName(TableRuleInvoke())).Append("(");
 | 
				
			||||||
 | 
					            var colidx = 0;
 | 
				
			||||||
 | 
					            foreach (var col in cols)
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                if (col.Attribute.IsIdentity) _identCol = col;
 | 
				
			||||||
 | 
					                if (colidx > 0)
 | 
				
			||||||
 | 
					                {
 | 
				
			||||||
 | 
					                    sb.Append(", ");
 | 
				
			||||||
 | 
					                    tmpsb.Append(", ");
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					                var colname = _commonUtils.QuoteSqlName(col.Attribute.Name);
 | 
				
			||||||
 | 
					                sb.Append(colname);
 | 
				
			||||||
 | 
					                tmpsb.Append(col.Attribute.IsIdentity && !string.IsNullOrEmpty(col.DbInsertValue) ? col.DbInsertValue : colname);
 | 
				
			||||||
 | 
					                ++colidx;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            sb.Append(") ").Append("\r\nSELECT ").Append(tmpsb.ToString()).Append(" FROM \r\n(\r\n");
 | 
				
			||||||
 | 
					            tmpsb.Clear();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            _params = _noneParameter ? new DbParameter[0] : new DbParameter[colidx * _source.Count];
 | 
				
			||||||
 | 
					            var specialParams = new List<DbParameter>();
 | 
				
			||||||
 | 
					            var didx = 0;
 | 
				
			||||||
 | 
					            foreach (var d in _source)
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                if (_source.Count > 1) sb.Append("\r\n  UNION ALL\r\n ");
 | 
				
			||||||
 | 
					                sb.Append("  SELECT ");
 | 
				
			||||||
 | 
					                var colidx2 = 0;
 | 
				
			||||||
 | 
					                foreach (var col in cols)
 | 
				
			||||||
 | 
					                {
 | 
				
			||||||
 | 
					                    if (colidx2 > 0) sb.Append(", ");
 | 
				
			||||||
 | 
					                    if (string.IsNullOrEmpty(col.DbInsertValue) == false)
 | 
				
			||||||
 | 
					                        sb.Append(col.DbInsertValue);
 | 
				
			||||||
 | 
					                    else
 | 
				
			||||||
 | 
					                    {
 | 
				
			||||||
 | 
					                        object val = col.GetDbValue(d);
 | 
				
			||||||
 | 
					                        if (val == null && col.Attribute.IsNullable == false) val = col.CsType == typeof(string) ? "" : Utils.GetDataReaderValue(col.CsType.NullableTypeOrThis(), null);//#384
 | 
				
			||||||
 | 
					                        if (_noneParameter)
 | 
				
			||||||
 | 
					                            sb.Append(_commonUtils.GetNoneParamaterSqlValue(specialParams, _noneParameterFlag, col.Attribute.MapType, val));
 | 
				
			||||||
 | 
					                        else
 | 
				
			||||||
 | 
					                        {
 | 
				
			||||||
 | 
					                            sb.Append(_commonUtils.QuoteWriteParamter(col.Attribute.MapType, _commonUtils.QuoteParamterName($"{col.CsName}_{didx}")));
 | 
				
			||||||
 | 
					                            _params[didx * colidx + colidx2] = _commonUtils.AppendParamter(null, $"{col.CsName}_{didx}", col, col.Attribute.MapType, val);
 | 
				
			||||||
 | 
					                        }
 | 
				
			||||||
 | 
					                    }
 | 
				
			||||||
 | 
					                    if (didx == 0) sb.Append(" as ").Append(col.Attribute.Name);
 | 
				
			||||||
 | 
					                    ++colidx2;
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					                sb.Append(" FROM dual ");
 | 
				
			||||||
 | 
					                ++didx;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            sb.Append(")");
 | 
				
			||||||
 | 
					            if (_noneParameter && specialParams.Any()) _params = specialParams.ToArray();
 | 
				
			||||||
 | 
					            return sb.ToString();
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        public override string ToSql()
 | 
					        public override string ToSql()
 | 
				
			||||||
        {
 | 
					        {
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user