Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
jobily
Efcore.Pg
提交
5962ad15
E
Efcore.Pg
项目概览
jobily
/
Efcore.Pg
11 个月 前同步成功
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
E
Efcore.Pg
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
5962ad15
编写于
11月 25, 2019
作者:
S
Shay Rojansky
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix type mappings for JSON containment functions
Fixes #1139
上级
5b356c72
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
40 addition
and
4 deletion
+40
-4
src/EFCore.PG/Query/ExpressionTranslators/Internal/NpgsqlJsonDbFunctionsTranslator.cs
...onTranslators/Internal/NpgsqlJsonDbFunctionsTranslator.cs
+2
-2
test/EFCore.PG.FunctionalTests/Query/JsonPocoQueryTest.cs
test/EFCore.PG.FunctionalTests/Query/JsonPocoQueryTest.cs
+38
-2
未找到文件。
src/EFCore.PG/Query/ExpressionTranslators/Internal/NpgsqlJsonDbFunctionsTranslator.cs
浏览文件 @
5962ad15
...
...
@@ -65,13 +65,13 @@ public SqlExpression Translate(SqlExpression instance, MethodInfo method, IReadO
{
nameof
(
NpgsqlJsonDbFunctionsExtensions
.
JsonContains
)
=>
new
SqlCustomBinaryExpression
(
_sqlExpressionFactory
.
ApplyTypeMapping
(
args
[
0
],
_jsonbTypeMapping
),
_sqlExpressionFactory
.
Apply
DefaultTypeMapping
(
args
[
1
]
),
_sqlExpressionFactory
.
Apply
TypeMapping
(
args
[
1
],
_jsonbTypeMapping
),
"@>"
,
typeof
(
bool
),
_boolTypeMapping
),
nameof
(
NpgsqlJsonDbFunctionsExtensions
.
JsonContained
)
=>
new
SqlCustomBinaryExpression
(
_sqlExpressionFactory
.
Apply
DefaultTypeMapping
(
args
[
0
]
),
_sqlExpressionFactory
.
Apply
TypeMapping
(
args
[
0
],
_jsonbTypeMapping
),
_sqlExpressionFactory
.
ApplyTypeMapping
(
args
[
1
],
_jsonbTypeMapping
),
"<@"
,
typeof
(
bool
),
...
...
test/EFCore.PG.FunctionalTests/Query/JsonPocoQueryTest.cs
浏览文件 @
5962ad15
...
...
@@ -347,7 +347,7 @@ public void JsonContains_with_json_element()
}
[
Fact
]
public
void
JsonContains_with_string
()
public
void
JsonContains_with_string
_literal
()
{
using
var
ctx
=
CreateContext
();
var
count
=
ctx
.
JsonbEntities
.
Count
(
e
=>
...
...
@@ -360,6 +360,24 @@ public void JsonContains_with_string()
WHERE (j.""Customer"" @> '{""Name"": ""Joe"", ""Age"": 25}')"
);
}
[
Fact
]
public
void
JsonContains_with_string_parameter
()
{
using
var
ctx
=
CreateContext
();
var
someJson
=
@"{""Name"": ""Joe"", ""Age"": 25}"
;
var
count
=
ctx
.
JsonbEntities
.
Count
(
e
=>
EF
.
Functions
.
JsonContains
(
e
.
Customer
,
someJson
));
Assert
.
Equal
(
1
,
count
);
AssertSql
(
@"@__someJson_1='{""Name"": ""Joe""
""Age"": 25}' (DbType = Object)
SELECT COUNT(*)::INT
FROM ""JsonbEntities"" AS j
WHERE (j.""Customer"" @> @__someJson_1)"
);
}
[
Fact
]
public
void
JsonContained_with_json_element
()
{
...
...
@@ -379,7 +397,7 @@ public void JsonContained_with_json_element()
}
[
Fact
]
public
void
JsonContained_with_string
()
public
void
JsonContained_with_string
_literal
()
{
using
var
ctx
=
CreateContext
();
var
count
=
ctx
.
JsonbEntities
.
Count
(
e
=>
...
...
@@ -392,6 +410,24 @@ public void JsonContained_with_string()
WHERE ('{""Name"": ""Joe"", ""Age"": 25}' <@ j.""Customer"")"
);
}
[
Fact
]
public
void
JsonContained_with_string_parameter
()
{
using
var
ctx
=
CreateContext
();
var
someJson
=
@"{""Name"": ""Joe"", ""Age"": 25}"
;
var
count
=
ctx
.
JsonbEntities
.
Count
(
e
=>
EF
.
Functions
.
JsonContained
(
someJson
,
e
.
Customer
));
Assert
.
Equal
(
1
,
count
);
AssertSql
(
@"@__someJson_1='{""Name"": ""Joe""
""Age"": 25}' (DbType = Object)
SELECT COUNT(*)::INT
FROM ""JsonbEntities"" AS j
WHERE (@__someJson_1 <@ j.""Customer"")"
);
}
[
Fact
]
public
void
JsonExists
()
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录