Add SqlFunc.MergeString

This commit is contained in:
sunkaixuan
2017-11-07 16:13:22 +08:00
parent 00907fcd06
commit 183bc4d94e
8 changed files with 21 additions and 7 deletions

View File

@@ -333,6 +333,7 @@ namespace OrmTest.Demo
var db = GetInstance(); var db = GetInstance();
var t1 = db.Queryable<Student>().Where(it => SqlFunc.ToLower(it.Name) == SqlFunc.ToLower("JACK")).ToList(); var t1 = db.Queryable<Student>().Where(it => SqlFunc.ToLower(it.Name) == SqlFunc.ToLower("JACK")).ToList();
var t2 = db.Queryable<Student>().Where(it => SqlFunc.IsNull(it.Name, "nullvalue") == "nullvalue").ToList(); var t2 = db.Queryable<Student>().Where(it => SqlFunc.IsNull(it.Name, "nullvalue") == "nullvalue").ToList();
var t3 = db.Queryable<Student>().Where(it => SqlFunc.MergeString("a", it.Name) == "nullvalue").ToList();
//SELECT [Id],[SchoolId],[Name],[CreateTime] FROM [Student] WHERE ((LOWER([Name])) = (LOWER(@MethodConst0)) ) //SELECT [Id],[SchoolId],[Name],[CreateTime] FROM [Student] WHERE ((LOWER([Name])) = (LOWER(@MethodConst0)) )
/***More Functions***/ /***More Functions***/

View File

@@ -434,6 +434,7 @@ namespace OrmTest.Demo
var db = GetInstance(); var db = GetInstance();
var t1 = db.Queryable<Student>().Where(it => SqlFunc.ToLower(it.Name) == SqlFunc.ToLower("JACK")).ToList(); var t1 = db.Queryable<Student>().Where(it => SqlFunc.ToLower(it.Name) == SqlFunc.ToLower("JACK")).ToList();
var t2 = db.Queryable<Student>().Where(it => SqlFunc.IsNull(it.Name,"nullvalue")=="nullvalue").ToList(); var t2 = db.Queryable<Student>().Where(it => SqlFunc.IsNull(it.Name,"nullvalue")=="nullvalue").ToList();
var t3 = db.Queryable<Student>().Where(it => SqlFunc.MergeString("a",it.Name) == "nullvalue").ToList();
//SELECT [Id],[SchoolId],[Name],[CreateTime] FROM [Student] WHERE ((LOWER([Name])) = (LOWER(@MethodConst0)) ) //SELECT [Id],[SchoolId],[Name],[CreateTime] FROM [Student] WHERE ((LOWER([Name])) = (LOWER(@MethodConst0)) )
/***More Functions***/ /***More Functions***/

View File

@@ -302,7 +302,7 @@ namespace SqlSugar
public virtual string MergeString(params string[] strings) public virtual string MergeString(params string[] strings)
{ {
return string.Join("", strings); return string.Join("+", strings);
} }
public virtual string Pack(string sql) public virtual string Pack(string sql)

View File

@@ -68,6 +68,12 @@ namespace SqlSugar
public static bool Between(object value, object start, object end) { throw new NotSupportedException("Can only be used in expressions"); } public static bool Between(object value, object start, object end) { throw new NotSupportedException("Can only be used in expressions"); }
public static TResult IIF<TResult>(bool Expression, TResult thenValue, TResult elseValue) { throw new NotSupportedException("Can only be used in expressions"); } public static TResult IIF<TResult>(bool Expression, TResult thenValue, TResult elseValue) { throw new NotSupportedException("Can only be used in expressions"); }
public static TResult IsNull<TResult>(TResult thisValue, TResult ifNullValue) { throw new NotSupportedException("Can only be used in expressions"); } public static TResult IsNull<TResult>(TResult thisValue, TResult ifNullValue) { throw new NotSupportedException("Can only be used in expressions"); }
public static string MergeString(string value1,string value2) { throw new NotSupportedException("Can only be used in expressions"); }
public static string MergeString(string value1, string value2,string value3) { throw new NotSupportedException("Can only be used in expressions"); }
public static string MergeString(string value1, string value2,string value3,string value4) { throw new NotSupportedException("Can only be used in expressions"); }
public static string MergeString(string value1, string value2, string value3, string value4,string value5) { throw new NotSupportedException("Can only be used in expressions"); }
public static string MergeString(string value1, string value2, string value3, string value4, string value5,string value6) { throw new NotSupportedException("Can only be used in expressions"); }
public static string MergeString(string value1, string value2, string value3, string value4, string value5, string value6,string value7) { throw new NotSupportedException("Can only be used in expressions"); }
public static int ToInt32(object value) { return value.ObjToInt(); } public static int ToInt32(object value) { return value.ObjToInt(); }
public static long ToInt64(object value) { return Convert.ToInt64(value); } public static long ToInt64(object value) { return Convert.ToInt64(value); }
/// <summary> /// <summary>

View File

@@ -204,9 +204,9 @@ namespace SqlSugar
}; };
AppendMember(parameter, isLeft, GetToDate(this.Context.DbMehtods.MergeString( AppendMember(parameter, isLeft, GetToDate(this.Context.DbMehtods.MergeString(
this.GetDateValue(parameter.CommonTempData, DateType.Year), this.GetDateValue(parameter.CommonTempData, DateType.Year),
"+'-'+", "'-'",
this.GetDateValue(parameter.CommonTempData, DateType.Month), this.GetDateValue(parameter.CommonTempData, DateType.Month),
"+'-'+", "'-'",
this.GetDateValue(parameter.CommonTempData, DateType.Day)))); this.GetDateValue(parameter.CommonTempData, DateType.Day))));
} }
parameter.CommonTempData = oldCommonTempDate; parameter.CommonTempData = oldCommonTempDate;

View File

@@ -409,6 +409,8 @@ namespace SqlSugar
return mappingColumnResult; return mappingColumnResult;
case "IsNull": case "IsNull":
return this.Context.DbMehtods.IsNull(model); return this.Context.DbMehtods.IsNull(model);
case "MergeString":
return this.Context.DbMehtods.MergeString(model.Args.Select(it=>it.MemberName.ObjToString()).ToArray());
case "GetSelfAndAutoFill": case "GetSelfAndAutoFill":
this.Context.Parameters.RemoveAll(it => it.ParameterName == model.Args[0].MemberName.ObjToString()); this.Context.Parameters.RemoveAll(it => it.ParameterName == model.Args[0].MemberName.ObjToString());
return this.Context.DbMehtods.GetSelfAndAutoFill(model.Args[0].MemberValue.ObjToString(), this.Context.IsSingle); return this.Context.DbMehtods.GetSelfAndAutoFill(model.Args[0].MemberValue.ObjToString(), this.Context.IsSingle);

View File

@@ -164,5 +164,9 @@ namespace SqlSugar
return string.Format("NVL({0},{1})", parameter.MemberName, parameter1.MemberName); return string.Format("NVL({0},{1})", parameter.MemberName, parameter1.MemberName);
} }
public override string MergeString(params string[] strings)
{
return string.Join("||", strings).Replace("+", "");
}
} }
} }