Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
da8cd519
R
rails
项目概览
张重言
/
rails
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
rails
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
da8cd519
编写于
9月 23, 2016
作者:
A
Aaron Patterson
提交者:
GitHub
9月 23, 2016
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #25670 from tdtran/fix-nil-json
Serialize JSON attribute value nil as SQL NULL, not JSON 'null'
上级
0bc19651
21675fdc
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
41 addition
and
1 deletion
+41
-1
activerecord/CHANGELOG.md
activerecord/CHANGELOG.md
+4
-0
activerecord/lib/active_record/type/internal/abstract_json.rb
...verecord/lib/active_record/type/internal/abstract_json.rb
+5
-1
activerecord/test/cases/adapters/mysql2/json_test.rb
activerecord/test/cases/adapters/mysql2/json_test.rb
+16
-0
activerecord/test/cases/adapters/postgresql/json_test.rb
activerecord/test/cases/adapters/postgresql/json_test.rb
+16
-0
未找到文件。
activerecord/CHANGELOG.md
浏览文件 @
da8cd519
*
Serialize JSON attribute value
`nil`
as SQL
`NULL`
, not JSON
`null`
*Trung Duc Tran*
*
Return
`true`
from
`update_attribute`
when the value of the attribute
to be updated is unchanged.
...
...
activerecord/lib/active_record/type/internal/abstract_json.rb
浏览文件 @
da8cd519
...
...
@@ -17,7 +17,11 @@ def deserialize(value)
end
def
serialize
(
value
)
::
ActiveSupport
::
JSON
.
encode
(
value
)
if
value
.
nil?
nil
else
::
ActiveSupport
::
JSON
.
encode
(
value
)
end
end
def
accessor
...
...
activerecord/test/cases/adapters/mysql2/json_test.rb
浏览文件 @
da8cd519
...
...
@@ -102,6 +102,22 @@ def test_select_array_json_value
assert_equal
([
"v0"
,
{
"k1"
=>
"v1"
}],
x
.
payload
)
end
def
test_select_nil_json_after_create
json
=
JsonDataType
.
create
(
payload:
nil
)
x
=
JsonDataType
.
where
(
payload
:nil
).
first
assert_equal
(
json
,
x
)
end
def
test_select_nil_json_after_update
json
=
JsonDataType
.
create
(
payload:
"foo"
)
x
=
JsonDataType
.
where
(
payload
:nil
).
first
assert_equal
(
nil
,
x
)
json
.
update_attributes
payload:
nil
x
=
JsonDataType
.
where
(
payload
:nil
).
first
assert_equal
(
json
.
reload
,
x
)
end
def
test_rewrite_array_json_value
@connection
.
execute
%q|insert into json_data_type (payload) VALUES ('["v0",{"k1":"v1"}]')|
x
=
JsonDataType
.
first
...
...
activerecord/test/cases/adapters/postgresql/json_test.rb
浏览文件 @
da8cd519
...
...
@@ -113,6 +113,22 @@ def test_null_json
assert_equal
(
nil
,
x
.
payload
)
end
def
test_select_nil_json_after_create
json
=
JsonDataType
.
create
(
payload:
nil
)
x
=
JsonDataType
.
where
(
payload
:nil
).
first
assert_equal
(
json
,
x
)
end
def
test_select_nil_json_after_update
json
=
JsonDataType
.
create
(
payload:
"foo"
)
x
=
JsonDataType
.
where
(
payload
:nil
).
first
assert_equal
(
nil
,
x
)
json
.
update_attributes
payload:
nil
x
=
JsonDataType
.
where
(
payload
:nil
).
first
assert_equal
(
json
.
reload
,
x
)
end
def
test_select_array_json_value
@connection
.
execute
%q|insert into json_data_type (payload) VALUES ('["v0",{"k1":"v1"}]')|
x
=
JsonDataType
.
first
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录