Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
3f76925d
Commit
3f76925d
authored
Oct 15, 2005
by
hf@deer.(none)
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix for bug #13573 (wrong data inserted for too big decimals)
parent
a5c5b2c6
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
91 additions
and
26 deletions
+91
-26
mysql-test/r/type_newdecimal.result
mysql-test/r/type_newdecimal.result
+25
-3
mysql-test/t/type_newdecimal.test
mysql-test/t/type_newdecimal.test
+15
-0
sql/item_func.cc
sql/item_func.cc
+6
-6
sql/my_decimal.cc
sql/my_decimal.cc
+1
-1
sql/my_decimal.h
sql/my_decimal.h
+44
-16
No files found.
mysql-test/r/type_newdecimal.result
View file @
3f76925d
...
@@ -846,15 +846,14 @@ select 0/0;
...
@@ -846,15 +846,14 @@ select 0/0;
NULL
NULL
select 9999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999 as x;
select 9999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999 as x;
x
x
99999999999999999999999999999999999999999999999999999999999999999
9999999999999999
99999999999999999999999999999999999999999999999999999999999999999
Warnings:
Warnings:
Error 1292 Truncated incorrect DECIMAL value: ''
Error 1292 Truncated incorrect DECIMAL value: ''
select 9999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999 + 1 as x;
select 9999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999 + 1 as x;
x
x
NULL
100000000000000000000000000000000000000000000000000000000000000000
Warnings:
Warnings:
Error 1292 Truncated incorrect DECIMAL value: ''
Error 1292 Truncated incorrect DECIMAL value: ''
Error 1292 Truncated incorrect DECIMAL value: ''
select 0.190287977636363637 + 0.040372670 * 0 - 0;
select 0.190287977636363637 + 0.040372670 * 0 - 0;
0.190287977636363637 + 0.040372670 * 0 - 0
0.190287977636363637 + 0.040372670 * 0 - 0
0.190287977636363637
0.190287977636363637
...
@@ -1019,3 +1018,26 @@ drop procedure wg2;
...
@@ -1019,3 +1018,26 @@ drop procedure wg2;
select cast(@non_existing_user_var/2 as DECIMAL);
select cast(@non_existing_user_var/2 as DECIMAL);
cast(@non_existing_user_var/2 as DECIMAL)
cast(@non_existing_user_var/2 as DECIMAL)
NULL
NULL
create table t1 (c1 decimal(64));
insert into t1 values(
89000000000000000000000000000000000000000000000000000000000000000000000000000000000000000);
Warnings:
Error 1292 Truncated incorrect DECIMAL value: ''
Warning 1264 Out of range value adjusted for column 'c1' at row 1
insert into t1 values(
99999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999 *
99999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999);
Warnings:
Error 1292 Truncated incorrect DECIMAL value: ''
Error 1292 Truncated incorrect DECIMAL value: ''
Error 1292 Truncated incorrect DECIMAL value: ''
Warning 1264 Out of range value adjusted for column 'c1' at row 1
insert into t1 values(1e100);
Warnings:
Warning 1264 Out of range value adjusted for column 'c1' at row 1
select * from t1;
c1
9999999999999999999999999999999999999999999999999999999999999999
9999999999999999999999999999999999999999999999999999999999999999
9999999999999999999999999999999999999999999999999999999999999999
drop table t1;
mysql-test/t/type_newdecimal.test
View file @
3f76925d
...
@@ -1044,3 +1044,18 @@ drop procedure wg2;
...
@@ -1044,3 +1044,18 @@ drop procedure wg2;
#
#
select
cast
(
@
non_existing_user_var
/
2
as
DECIMAL
);
select
cast
(
@
non_existing_user_var
/
2
as
DECIMAL
);
#
# Bug #13573 (Wrong data inserted for too big values)
#
create
table
t1
(
c1
decimal
(
64
));
insert
into
t1
values
(
89000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
);
insert
into
t1
values
(
99999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999
*
99999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999
);
insert
into
t1
values
(
1
e100
);
select
*
from
t1
;
drop
table
t1
;
sql/item_func.cc
View file @
3f76925d
...
@@ -972,8 +972,8 @@ my_decimal *Item_func_plus::decimal_op(my_decimal *decimal_value)
...
@@ -972,8 +972,8 @@ my_decimal *Item_func_plus::decimal_op(my_decimal *decimal_value)
return
0
;
return
0
;
val2
=
args
[
1
]
->
val_decimal
(
&
value2
);
val2
=
args
[
1
]
->
val_decimal
(
&
value2
);
if
(
!
(
null_value
=
(
args
[
1
]
->
null_value
||
if
(
!
(
null_value
=
(
args
[
1
]
->
null_value
||
my_decimal_add
(
E_DEC_FATAL_ERROR
,
decimal_value
,
val1
,
(
my_decimal_add
(
E_DEC_FATAL_ERROR
,
decimal_value
,
val1
,
val2
)
>
1
)))
val2
)
>
3
)
)))
return
decimal_value
;
return
decimal_value
;
return
0
;
return
0
;
}
}
...
@@ -1045,8 +1045,8 @@ my_decimal *Item_func_minus::decimal_op(my_decimal *decimal_value)
...
@@ -1045,8 +1045,8 @@ my_decimal *Item_func_minus::decimal_op(my_decimal *decimal_value)
return
0
;
return
0
;
val2
=
args
[
1
]
->
val_decimal
(
&
value2
);
val2
=
args
[
1
]
->
val_decimal
(
&
value2
);
if
(
!
(
null_value
=
(
args
[
1
]
->
null_value
||
if
(
!
(
null_value
=
(
args
[
1
]
->
null_value
||
my_decimal_sub
(
E_DEC_FATAL_ERROR
,
decimal_value
,
val1
,
(
my_decimal_sub
(
E_DEC_FATAL_ERROR
,
decimal_value
,
val1
,
val2
)
>
1
)))
val2
)
>
3
)
)))
return
decimal_value
;
return
decimal_value
;
return
0
;
return
0
;
}
}
...
@@ -1083,8 +1083,8 @@ my_decimal *Item_func_mul::decimal_op(my_decimal *decimal_value)
...
@@ -1083,8 +1083,8 @@ my_decimal *Item_func_mul::decimal_op(my_decimal *decimal_value)
return
0
;
return
0
;
val2
=
args
[
1
]
->
val_decimal
(
&
value2
);
val2
=
args
[
1
]
->
val_decimal
(
&
value2
);
if
(
!
(
null_value
=
(
args
[
1
]
->
null_value
||
if
(
!
(
null_value
=
(
args
[
1
]
->
null_value
||
my_decimal_mul
(
E_DEC_FATAL_ERROR
,
decimal_value
,
val1
,
(
my_decimal_mul
(
E_DEC_FATAL_ERROR
,
decimal_value
,
val1
,
val2
)
>
1
)))
val2
)
>
3
)
)))
return
decimal_value
;
return
decimal_value
;
return
0
;
return
0
;
}
}
...
...
sql/my_decimal.cc
View file @
3f76925d
...
@@ -185,7 +185,7 @@ int str2my_decimal(uint mask, const char *from, uint length,
...
@@ -185,7 +185,7 @@ int str2my_decimal(uint mask, const char *from, uint length,
}
}
}
}
}
}
check_result
(
mask
,
err
);
check_result
_and_overflow
(
mask
,
err
,
decimal_value
);
return
err
;
return
err
;
}
}
...
...
sql/my_decimal.h
View file @
3f76925d
...
@@ -126,6 +126,19 @@ inline int decimal_operation_results(int result)
...
@@ -126,6 +126,19 @@ inline int decimal_operation_results(int result)
}
}
#endif
/*MYSQL_CLIENT*/
#endif
/*MYSQL_CLIENT*/
inline
void
max_my_decimal
(
my_decimal
*
to
,
int
precision
,
int
frac
)
{
DBUG_ASSERT
((
precision
<=
DECIMAL_MAX_PRECISION
)
&&
(
frac
<=
DECIMAL_MAX_SCALE
));
max_decimal
(
precision
,
frac
,
(
decimal_t
*
)
to
);
}
inline
void
max_internal_decimal
(
my_decimal
*
to
)
{
max_my_decimal
(
to
,
DECIMAL_MAX_PRECISION
,
0
);
}
inline
int
check_result
(
uint
mask
,
int
result
)
inline
int
check_result
(
uint
mask
,
int
result
)
{
{
if
(
result
&
mask
)
if
(
result
&
mask
)
...
@@ -133,6 +146,18 @@ inline int check_result(uint mask, int result)
...
@@ -133,6 +146,18 @@ inline int check_result(uint mask, int result)
return
result
;
return
result
;
}
}
inline
int
check_result_and_overflow
(
uint
mask
,
int
result
,
my_decimal
*
val
)
{
if
(
check_result
(
mask
,
result
)
&
E_DEC_OVERFLOW
)
{
bool
sign
=
val
->
sign
();
val
->
fix_buffer_pointer
();
max_internal_decimal
(
val
);
val
->
sign
(
sign
);
}
return
result
;
}
inline
uint
my_decimal_length_to_precision
(
uint
length
,
uint
scale
,
inline
uint
my_decimal_length_to_precision
(
uint
length
,
uint
scale
,
bool
unsigned_flag
)
bool
unsigned_flag
)
{
{
...
@@ -256,7 +281,8 @@ int my_decimal2double(uint mask, const my_decimal *d, double *result)
...
@@ -256,7 +281,8 @@ int my_decimal2double(uint mask, const my_decimal *d, double *result)
inline
inline
int
str2my_decimal
(
uint
mask
,
const
char
*
str
,
my_decimal
*
d
,
char
**
end
)
int
str2my_decimal
(
uint
mask
,
const
char
*
str
,
my_decimal
*
d
,
char
**
end
)
{
{
return
check_result
(
mask
,
string2decimal
(
str
,
(
decimal_t
*
)
d
,
end
));
return
check_result_and_overflow
(
mask
,
string2decimal
(
str
,(
decimal_t
*
)
d
,
end
),
d
);
}
}
...
@@ -274,7 +300,7 @@ int string2my_decimal(uint mask, const String *str, my_decimal *d)
...
@@ -274,7 +300,7 @@ int string2my_decimal(uint mask, const String *str, my_decimal *d)
inline
inline
int
double2my_decimal
(
uint
mask
,
double
val
,
my_decimal
*
d
)
int
double2my_decimal
(
uint
mask
,
double
val
,
my_decimal
*
d
)
{
{
return
check_result
(
mask
,
double2decimal
(
val
,
(
decimal_t
*
)
d
)
);
return
check_result
_and_overflow
(
mask
,
double2decimal
(
val
,
(
decimal_t
*
)
d
),
d
);
}
}
...
@@ -303,7 +329,9 @@ inline
...
@@ -303,7 +329,9 @@ inline
int
my_decimal_add
(
uint
mask
,
my_decimal
*
res
,
const
my_decimal
*
a
,
int
my_decimal_add
(
uint
mask
,
my_decimal
*
res
,
const
my_decimal
*
a
,
const
my_decimal
*
b
)
const
my_decimal
*
b
)
{
{
return
check_result
(
mask
,
decimal_add
((
decimal_t
*
)
a
,
(
decimal_t
*
)
b
,
res
));
return
check_result_and_overflow
(
mask
,
decimal_add
((
decimal_t
*
)
a
,(
decimal_t
*
)
b
,
res
),
res
);
}
}
...
@@ -311,7 +339,9 @@ inline
...
@@ -311,7 +339,9 @@ inline
int
my_decimal_sub
(
uint
mask
,
my_decimal
*
res
,
const
my_decimal
*
a
,
int
my_decimal_sub
(
uint
mask
,
my_decimal
*
res
,
const
my_decimal
*
a
,
const
my_decimal
*
b
)
const
my_decimal
*
b
)
{
{
return
check_result
(
mask
,
decimal_sub
((
decimal_t
*
)
a
,
(
decimal_t
*
)
b
,
res
));
return
check_result_and_overflow
(
mask
,
decimal_sub
((
decimal_t
*
)
a
,(
decimal_t
*
)
b
,
res
),
res
);
}
}
...
@@ -319,7 +349,9 @@ inline
...
@@ -319,7 +349,9 @@ inline
int
my_decimal_mul
(
uint
mask
,
my_decimal
*
res
,
const
my_decimal
*
a
,
int
my_decimal_mul
(
uint
mask
,
my_decimal
*
res
,
const
my_decimal
*
a
,
const
my_decimal
*
b
)
const
my_decimal
*
b
)
{
{
return
check_result
(
mask
,
decimal_mul
((
decimal_t
*
)
a
,
(
decimal_t
*
)
b
,
res
));
return
check_result_and_overflow
(
mask
,
decimal_mul
((
decimal_t
*
)
a
,(
decimal_t
*
)
b
,
res
),
res
);
}
}
...
@@ -327,8 +359,10 @@ inline
...
@@ -327,8 +359,10 @@ inline
int
my_decimal_div
(
uint
mask
,
my_decimal
*
res
,
const
my_decimal
*
a
,
int
my_decimal_div
(
uint
mask
,
my_decimal
*
res
,
const
my_decimal
*
a
,
const
my_decimal
*
b
,
int
div_scale_inc
)
const
my_decimal
*
b
,
int
div_scale_inc
)
{
{
return
check_result
(
mask
,
decimal_div
((
decimal_t
*
)
a
,
(
decimal_t
*
)
b
,
res
,
return
check_result_and_overflow
(
mask
,
div_scale_inc
));
decimal_div
((
decimal_t
*
)
a
,(
decimal_t
*
)
b
,
res
,
div_scale_inc
),
res
);
}
}
...
@@ -336,7 +370,9 @@ inline
...
@@ -336,7 +370,9 @@ inline
int
my_decimal_mod
(
uint
mask
,
my_decimal
*
res
,
const
my_decimal
*
a
,
int
my_decimal_mod
(
uint
mask
,
my_decimal
*
res
,
const
my_decimal
*
a
,
const
my_decimal
*
b
)
const
my_decimal
*
b
)
{
{
return
check_result
(
mask
,
decimal_mod
((
decimal_t
*
)
a
,
(
decimal_t
*
)
b
,
res
));
return
check_result_and_overflow
(
mask
,
decimal_mod
((
decimal_t
*
)
a
,(
decimal_t
*
)
b
,
res
),
res
);
}
}
...
@@ -347,13 +383,5 @@ int my_decimal_cmp(const my_decimal *a, const my_decimal *b)
...
@@ -347,13 +383,5 @@ int my_decimal_cmp(const my_decimal *a, const my_decimal *b)
return
decimal_cmp
((
decimal_t
*
)
a
,
(
decimal_t
*
)
b
);
return
decimal_cmp
((
decimal_t
*
)
a
,
(
decimal_t
*
)
b
);
}
}
inline
void
max_my_decimal
(
my_decimal
*
to
,
int
precision
,
int
frac
)
{
DBUG_ASSERT
((
precision
<=
DECIMAL_MAX_PRECISION
)
&&
(
frac
<=
DECIMAL_MAX_SCALE
));
max_decimal
(
precision
,
frac
,
(
decimal_t
*
)
to
);
}
#endif
/*my_decimal_h*/
#endif
/*my_decimal_h*/
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment