mirror of
https://gitee.com/dotnetchina/SqlSugar.git
synced 2025-08-24 07:22:57 +08:00
!58 feat: support sqlite json index and change for jsonfield method
Merge pull request !58 from Jane/master
This commit is contained in:
commit
792f2639f7
@ -4,8 +4,9 @@ namespace SqlSugar
|
|||||||
{
|
{
|
||||||
public class SqliteExpressionContext : ExpressionContext, ILambdaExpressions
|
public class SqliteExpressionContext : ExpressionContext, ILambdaExpressions
|
||||||
{
|
{
|
||||||
public override ExpressionContextCase Case { get; set; } = new ExpressionContextCase() {
|
public override ExpressionContextCase Case { get; set; } = new ExpressionContextCase()
|
||||||
IsDateString= true,
|
{
|
||||||
|
IsDateString = true,
|
||||||
};
|
};
|
||||||
public SqlSugarProvider Context { get; set; }
|
public SqlSugarProvider Context { get; set; }
|
||||||
public SqliteExpressionContext()
|
public SqliteExpressionContext()
|
||||||
@ -24,17 +25,27 @@ namespace SqlSugar
|
|||||||
}
|
}
|
||||||
public override string Equals(MethodCallExpressionModel model)
|
public override string Equals(MethodCallExpressionModel model)
|
||||||
{
|
{
|
||||||
var result= base.Equals(model);
|
var result = base.Equals(model);
|
||||||
if (model.Args.Count == 3&& result.Trim().Last()==')')
|
if (model.Args.Count == 3 && result.Trim().Last() == ')')
|
||||||
{
|
{
|
||||||
result = (" "+result.Trim().TrimEnd(')') + " COLLATE NOCASE ) ");
|
result = (" " + result.Trim().TrimEnd(')') + " COLLATE NOCASE ) ");
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
public override string JsonIndex(MethodCallExpressionModel model)
|
||||||
|
{
|
||||||
|
var parameter = model.Args[0];
|
||||||
|
var parameter1 = model.Args[1];
|
||||||
|
return $"json_extract({parameter.MemberName}, '$[{parameter1.MemberValue}]')";
|
||||||
|
}
|
||||||
public override string JsonField(MethodCallExpressionModel model)
|
public override string JsonField(MethodCallExpressionModel model)
|
||||||
{
|
{
|
||||||
model.Parameters.RemoveAll(item=>item.ParameterName== model.Args[1].MemberName+"");
|
var hasPrefix = model.Args[1].MemberValue is string v ? v[0] == '$' : false;
|
||||||
return " json_extract("+ model.Args[0].MemberName + ",'$." + model.Args[1].MemberValue + "') ";
|
model.Parameters.RemoveAll(item => item.ParameterName == model.Args[1].MemberName + "");
|
||||||
|
return string.Format("json_extract({0},'{1}{2}')",
|
||||||
|
model.Args[0].MemberName,
|
||||||
|
hasPrefix ? string.Empty : string.Intern("$."),
|
||||||
|
model.Args[1].MemberValue);
|
||||||
}
|
}
|
||||||
public override string GetStringJoinSelector(string result, string separator)
|
public override string GetStringJoinSelector(string result, string separator)
|
||||||
{
|
{
|
||||||
@ -262,7 +273,7 @@ namespace SqlSugar
|
|||||||
|
|
||||||
public override string MergeString(params string[] strings)
|
public override string MergeString(params string[] strings)
|
||||||
{
|
{
|
||||||
return string.Join("||", strings).Replace("+","");
|
return string.Join("||", strings).Replace("+", "");
|
||||||
}
|
}
|
||||||
|
|
||||||
public override string IsNull(MethodCallExpressionModel model)
|
public override string IsNull(MethodCallExpressionModel model)
|
||||||
@ -308,7 +319,7 @@ namespace SqlSugar
|
|||||||
var parameterNameA = mode.Args[0].MemberName;
|
var parameterNameA = mode.Args[0].MemberName;
|
||||||
var parameterNameB = mode.Args[1].MemberName;
|
var parameterNameB = mode.Args[1].MemberName;
|
||||||
var parameterNameC = mode.Args[2].MemberName;
|
var parameterNameC = mode.Args[2].MemberName;
|
||||||
var value = new string[mode.Args[1].MemberValue.ObjToInt()].Select(it=> parameterNameC);
|
var value = new string[mode.Args[1].MemberValue.ObjToInt()].Select(it => parameterNameC);
|
||||||
return $"substr({string.Join("||", value)} || {parameterNameA}, {parameterNameB}*-1) ";
|
return $"substr({string.Join("||", value)} || {parameterNameA}, {parameterNameB}*-1) ";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user