!58 feat: support sqlite json index and change for jsonfield method

Merge pull request !58 from Jane/master
This commit is contained in:
阿妮亚 2024-05-21 03:37:08 +00:00 committed by Gitee
commit 792f2639f7
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F

View File

@ -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) ";
} }