Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
2dot5
ClickHouse
提交
5fc6a697
C
ClickHouse
项目概览
2dot5
/
ClickHouse
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
C
ClickHouse
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
5fc6a697
编写于
6月 13, 2019
作者:
D
dmitry kuzmin
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
float to decimal overflow fix
上级
87557d21
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
15 addition
and
10 deletion
+15
-10
dbms/src/DataTypes/DataTypesDecimal.h
dbms/src/DataTypes/DataTypesDecimal.h
+11
-10
dbms/tests/queries/0_stateless/00700_decimal_casts.sql
dbms/tests/queries/0_stateless/00700_decimal_casts.sql
+4
-0
未找到文件。
dbms/src/DataTypes/DataTypesDecimal.h
浏览文件 @
5fc6a697
...
...
@@ -324,22 +324,23 @@ convertToDecimal(const typename FromDataType::FieldType & value, UInt32 scale)
if
constexpr
(
std
::
is_floating_point_v
<
FromFieldType
>
)
{
ToNativeType
min_value
;
ToNativeType
max_value
;
if
(
!
std
::
isfinite
(
value
))
throw
Exception
(
"Decimal convert overflow. Cannot convert infinity or NaN to decimal"
,
ErrorCodes
::
DECIMAL_OVERFLOW
);
auto
out
=
value
*
ToDataType
::
getScaleMultiplier
(
scale
);
if
constexpr
(
std
::
is_same_v
<
ToNativeType
,
Int128
>
)
{
min_value
=
__int128
(
0x8000000000000000ll
)
<<
64
;
// min __int128
max_value
=
(
__int128
(
0x7fffffffffffffffll
)
<<
64
)
+
0xffffffffffffffffll
;
// max __int128
static
constexpr
__int128
min_int128
=
__int128
(
0x8000000000000000ll
)
<<
64
;
static
constexpr
__int128
max_int128
=
(
__int128
(
0x7fffffffffffffffll
)
<<
64
)
+
0xffffffffffffffffll
;
if
(
out
<
min_int128
||
out
>
max_int128
)
throw
Exception
(
"Decimal convert overflow. Float is out of Decimal range"
,
ErrorCodes
::
DECIMAL_OVERFLOW
);
}
else
{
min_value
=
std
::
numeric_limits
<
ToNativeType
>::
min
();
max_value
=
std
::
numeric_limits
<
ToNativeType
>::
max
(
);
if
(
out
<
std
::
numeric_limits
<
ToNativeType
>::
min
()
||
out
>
std
::
numeric_limits
<
ToNativeType
>::
max
())
throw
Exception
(
"Decimal convert overflow. Float is out of Decimal range"
,
ErrorCodes
::
DECIMAL_OVERFLOW
);
}
ToNativeType
converted_value
=
static_cast
<
ToNativeType
>
(
value
*
ToDataType
::
getScaleMultiplier
(
scale
));
if
(
converted_value
==
min_value
||
converted_value
==
max_value
)
throw
Exception
(
"Decimal convert overflow"
,
ErrorCodes
::
DECIMAL_OVERFLOW
);
return
converted_value
;
return
out
;
}
else
{
...
...
dbms/tests/queries/0_stateless/00700_decimal_casts.sql
浏览文件 @
5fc6a697
...
...
@@ -254,3 +254,7 @@ SELECT CAST(0/0, 'Decimal(38, 5)'); -- { serverError 407 }
select
toDecimal32
(
10000
.
1
,
6
);
-- { serverError 407 }
select
toDecimal64
(
10000
.
1
,
18
);
-- { serverError 407 }
select
toDecimal128
(
1000000000000000000000
.
1
,
18
);
-- { serverError 407 }
select
toDecimal32
(
-
10000
.
1
,
6
);
-- { serverError 407 }
select
toDecimal64
(
-
10000
.
1
,
18
);
-- { serverError 407 }
select
toDecimal128
(
-
1000000000000000000000
.
1
,
18
);
-- { serverError 407 }
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录