mirror of
https://gitee.com/dotnetchina/SqlSugar.git
synced 2025-08-24 16:18:47 +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,7 +4,8 @@ namespace SqlSugar
|
||||
{
|
||||
public class SqliteExpressionContext : ExpressionContext, ILambdaExpressions
|
||||
{
|
||||
public override ExpressionContextCase Case { get; set; } = new ExpressionContextCase() {
|
||||
public override ExpressionContextCase Case { get; set; } = new ExpressionContextCase()
|
||||
{
|
||||
IsDateString = true,
|
||||
};
|
||||
public SqlSugarProvider Context { get; set; }
|
||||
@ -31,10 +32,20 @@ namespace SqlSugar
|
||||
}
|
||||
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)
|
||||
{
|
||||
var hasPrefix = model.Args[1].MemberValue is string v ? v[0] == '$' : false;
|
||||
model.Parameters.RemoveAll(item => item.ParameterName == model.Args[1].MemberName + "");
|
||||
return " json_extract("+ model.Args[0].MemberName + ",'$." + model.Args[1].MemberValue + "') ";
|
||||
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)
|
||||
{
|
||||
|
Loading…
Reference in New Issue
Block a user