Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
8521cdf0
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,发现更多精彩内容 >>
提交
8521cdf0
编写于
7月 12, 2010
作者:
A
Aaron Patterson
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
PostgreSQLAdapter#select_raw fields and results are empty even if ntuples is 0
上级
c9710a43
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
21 addition
and
25 deletion
+21
-25
activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb
...b/active_record/connection_adapters/postgresql_adapter.rb
+21
-25
未找到文件。
activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb
浏览文件 @
8521cdf0
...
...
@@ -949,34 +949,30 @@ def select(sql, name = nil)
def
select_raw
(
sql
,
name
=
nil
)
res
=
execute
(
sql
,
name
)
results
=
result_as_array
(
res
)
fields
=
[]
rows
=
[]
if
res
.
ntuples
>
0
fields
=
res
.
fields
results
.
each
do
|
row
|
hashed_row
=
{}
row
.
each_index
do
|
cell_index
|
# If this is a money type column and there are any currency symbols,
# then strip them off. Indeed it would be prettier to do this in
# PostgreSQLColumn.string_to_decimal but would break form input
# fields that call value_before_type_cast.
if
res
.
ftype
(
cell_index
)
==
MONEY_COLUMN_TYPE_OID
# Because money output is formatted according to the locale, there are two
# cases to consider (note the decimal separators):
# (1) $12,345,678.12
# (2) $12.345.678,12
case
column
=
row
[
cell_index
]
when
/^-?\D+[\d,]+\.\d{2}$/
# (1)
row
[
cell_index
]
=
column
.
gsub
(
/[^-\d\.]/
,
''
)
when
/^-?\D+[\d\.]+,\d{2}$/
# (2)
row
[
cell_index
]
=
column
.
gsub
(
/[^-\d,]/
,
''
).
sub
(
/,/
,
'.'
)
end
fields
=
res
.
fields
rows
=
results
.
map
do
|
row
|
hashed_row
=
{}
row
.
each_index
do
|
cell_index
|
# If this is a money type column and there are any currency symbols,
# then strip them off. Indeed it would be prettier to do this in
# PostgreSQLColumn.string_to_decimal but would break form input
# fields that call value_before_type_cast.
if
res
.
ftype
(
cell_index
)
==
MONEY_COLUMN_TYPE_OID
# Because money output is formatted according to the locale, there are two
# cases to consider (note the decimal separators):
# (1) $12,345,678.12
# (2) $12.345.678,12
case
column
=
row
[
cell_index
]
when
/^-?\D+[\d,]+\.\d{2}$/
# (1)
row
[
cell_index
]
=
column
.
gsub
(
/[^-\d\.]/
,
''
)
when
/^-?\D+[\d\.]+,\d{2}$/
# (2)
row
[
cell_index
]
=
column
.
gsub
(
/[^-\d,]/
,
''
).
sub
(
/,/
,
'.'
)
end
hashed_row
[
fields
[
cell_index
]]
=
column
end
rows
<<
row
hashed_row
[
fields
[
cell_index
]]
=
column
end
row
end
res
.
clear
return
fields
,
rows
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录