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
a3cd2e2d
Commit
a3cd2e2d
authored
Jul 31, 2008
by
Georgi Kodinov
Browse files
Options
Browse Files
Download
Plain Diff
merged 34159 and 37662 5.0-bugteam->5.1-bugteam
parents
686ced53
b1915525
Changes
8
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
144 additions
and
17 deletions
+144
-17
mysql-test/r/func_if.result
mysql-test/r/func_if.result
+46
-0
mysql-test/r/subselect.result
mysql-test/r/subselect.result
+12
-1
mysql-test/t/func_if.test
mysql-test/t/func_if.test
+43
-0
mysql-test/t/subselect.test
mysql-test/t/subselect.test
+13
-1
sql/item.cc
sql/item.cc
+8
-4
sql/item_cmpfunc.cc
sql/item_cmpfunc.cc
+8
-4
sql/item_func.cc
sql/item_func.cc
+8
-7
sql/sql_select.cc
sql/sql_select.cc
+6
-0
No files found.
mysql-test/r/func_if.result
View file @
a3cd2e2d
...
@@ -131,3 +131,49 @@ drop table t1;
...
@@ -131,3 +131,49 @@ drop table t1;
select if(0, 18446744073709551610, 18446744073709551610);
select if(0, 18446744073709551610, 18446744073709551610);
if(0, 18446744073709551610, 18446744073709551610)
if(0, 18446744073709551610, 18446744073709551610)
18446744073709551610
18446744073709551610
CREATE TABLE t1(a DECIMAL(10,3));
SELECT t1.a,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,0)))))))))))))))))))))))))))))) + 1
FROM t1;
a IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((ROUND(t1.a,2)=1), 2,
IF((R
DROP TABLE t1;
End of 5.0 tests
mysql-test/r/subselect.result
View file @
a3cd2e2d
...
@@ -4398,4 +4398,15 @@ INSERT INTO t1 VALUES (1), (3);
...
@@ -4398,4 +4398,15 @@ INSERT INTO t1 VALUES (1), (3);
SELECT * FROM t2 WHERE b NOT IN (SELECT max(t.c) FROM t1, t1 t WHERE t.c>10);
SELECT * FROM t2 WHERE b NOT IN (SELECT max(t.c) FROM t1, t1 t WHERE t.c>10);
a b
a b
DROP TABLE t1,t2;
DROP TABLE t1,t2;
End of 5.0 tests.
CREATE TABLE t1(pk int PRIMARY KEY, a int, INDEX idx(a));
INSERT INTO t1 VALUES (1, 10), (3, 30), (2, 20);
CREATE TABLE t2(pk int PRIMARY KEY, a int, b int, INDEX idxa(a));
INSERT INTO t2 VALUES (2, 20, 700), (1, 10, 200), (4, 10, 100);
SELECT * FROM t1
WHERE EXISTS (SELECT DISTINCT a FROM t2 WHERE t1.a < t2.a ORDER BY b);
pk a
1 10
3 30
2 20
DROP TABLE t1,t2;
End of 5.1 tests.
mysql-test/t/func_if.test
View file @
a3cd2e2d
...
@@ -108,3 +108,46 @@ drop table t1;
...
@@ -108,3 +108,46 @@ drop table t1;
select
if
(
0
,
18446744073709551610
,
18446744073709551610
);
select
if
(
0
,
18446744073709551610
,
18446744073709551610
);
#
# Bug #37662: nested if() inside sum() is parsed in exponential time
#
CREATE
TABLE
t1
(
a
DECIMAL
(
10
,
3
));
# check : should be fast. more than few secs means failure.
SELECT
t1
.
a
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
IF
((
ROUND
(
t1
.
a
,
2
)
=
1
),
2
,
0
))))))))))))))))))))))))))))))
+
1
FROM
t1
;
DROP
TABLE
t1
;
--
echo
End
of
5.0
tests
mysql-test/t/subselect.test
View file @
a3cd2e2d
...
@@ -3299,4 +3299,16 @@ SELECT * FROM t2 WHERE b NOT IN (SELECT max(t.c) FROM t1, t1 t WHERE t.c>10);
...
@@ -3299,4 +3299,16 @@ SELECT * FROM t2 WHERE b NOT IN (SELECT max(t.c) FROM t1, t1 t WHERE t.c>10);
DROP
TABLE
t1
,
t2
;
DROP
TABLE
t1
,
t2
;
--
echo
End
of
5.0
tests
.
#
# Bug #38191: Server crash with subquery containing DISTINCT and ORDER BY
#
CREATE
TABLE
t1
(
pk
int
PRIMARY
KEY
,
a
int
,
INDEX
idx
(
a
));
INSERT
INTO
t1
VALUES
(
1
,
10
),
(
3
,
30
),
(
2
,
20
);
CREATE
TABLE
t2
(
pk
int
PRIMARY
KEY
,
a
int
,
b
int
,
INDEX
idxa
(
a
));
INSERT
INTO
t2
VALUES
(
2
,
20
,
700
),
(
1
,
10
,
200
),
(
4
,
10
,
100
);
SELECT
*
FROM
t1
WHERE
EXISTS
(
SELECT
DISTINCT
a
FROM
t2
WHERE
t1
.
a
<
t2
.
a
ORDER
BY
b
);
DROP
TABLE
t1
,
t2
;
--
echo
End
of
5.1
tests
.
sql/item.cc
View file @
a3cd2e2d
...
@@ -437,8 +437,11 @@ uint Item::decimal_precision() const
...
@@ -437,8 +437,11 @@ uint Item::decimal_precision() const
Item_result
restype
=
result_type
();
Item_result
restype
=
result_type
();
if
((
restype
==
DECIMAL_RESULT
)
||
(
restype
==
INT_RESULT
))
if
((
restype
==
DECIMAL_RESULT
)
||
(
restype
==
INT_RESULT
))
return
min
(
my_decimal_length_to_precision
(
max_length
,
decimals
,
unsigned_flag
),
{
DECIMAL_MAX_PRECISION
);
uint
prec
=
my_decimal_length_to_precision
(
max_length
,
decimals
,
unsigned_flag
);
return
min
(
prec
,
DECIMAL_MAX_PRECISION
);
}
return
min
(
max_length
,
DECIMAL_MAX_PRECISION
);
return
min
(
max_length
,
DECIMAL_MAX_PRECISION
);
}
}
...
@@ -6995,8 +6998,9 @@ bool Item_type_holder::join_types(THD *thd, Item *item)
...
@@ -6995,8 +6998,9 @@ bool Item_type_holder::join_types(THD *thd, Item *item)
if
(
Field
::
result_merge_type
(
fld_type
)
==
DECIMAL_RESULT
)
if
(
Field
::
result_merge_type
(
fld_type
)
==
DECIMAL_RESULT
)
{
{
decimals
=
min
(
max
(
decimals
,
item
->
decimals
),
DECIMAL_MAX_SCALE
);
decimals
=
min
(
max
(
decimals
,
item
->
decimals
),
DECIMAL_MAX_SCALE
);
int
precision
=
min
(
max
(
prev_decimal_int_part
,
item
->
decimal_int_part
())
int
item_int_part
=
item
->
decimal_int_part
();
+
decimals
,
DECIMAL_MAX_PRECISION
);
int
item_prec
=
max
(
prev_decimal_int_part
,
item_int_part
)
+
decimals
;
int
precision
=
min
(
item_prec
,
DECIMAL_MAX_PRECISION
);
unsigned_flag
&=
item
->
unsigned_flag
;
unsigned_flag
&=
item
->
unsigned_flag
;
max_length
=
my_decimal_precision_to_length
(
precision
,
decimals
,
max_length
=
my_decimal_precision_to_length
(
precision
,
decimals
,
unsigned_flag
);
unsigned_flag
);
...
...
sql/item_cmpfunc.cc
View file @
a3cd2e2d
...
@@ -2163,8 +2163,11 @@ Item_func_ifnull::fix_length_and_dec()
...
@@ -2163,8 +2163,11 @@ Item_func_ifnull::fix_length_and_dec()
uint
Item_func_ifnull
::
decimal_precision
()
const
uint
Item_func_ifnull
::
decimal_precision
()
const
{
{
int
max_int_part
=
max
(
args
[
0
]
->
decimal_int_part
(),
args
[
1
]
->
decimal_int_part
());
int
arg0_int_part
=
args
[
0
]
->
decimal_int_part
();
return
min
(
max_int_part
+
decimals
,
DECIMAL_MAX_PRECISION
);
int
arg1_int_part
=
args
[
1
]
->
decimal_int_part
();
int
max_int_part
=
max
(
arg0_int_part
,
arg1_int_part
);
int
precision
=
max_int_part
+
decimals
;
return
min
(
precision
,
DECIMAL_MAX_PRECISION
);
}
}
...
@@ -2345,8 +2348,9 @@ Item_func_if::fix_length_and_dec()
...
@@ -2345,8 +2348,9 @@ Item_func_if::fix_length_and_dec()
uint
Item_func_if
::
decimal_precision
()
const
uint
Item_func_if
::
decimal_precision
()
const
{
{
int
precision
=
(
max
(
args
[
1
]
->
decimal_int_part
(),
args
[
2
]
->
decimal_int_part
())
+
int
arg1_prec
=
args
[
1
]
->
decimal_int_part
();
decimals
);
int
arg2_prec
=
args
[
2
]
->
decimal_int_part
();
int
precision
=
max
(
arg1_prec
,
arg2_prec
)
+
decimals
;
return
min
(
precision
,
DECIMAL_MAX_PRECISION
);
return
min
(
precision
,
DECIMAL_MAX_PRECISION
);
}
}
...
...
sql/item_func.cc
View file @
a3cd2e2d
...
@@ -1139,9 +1139,10 @@ my_decimal *Item_func_plus::decimal_op(my_decimal *decimal_value)
...
@@ -1139,9 +1139,10 @@ my_decimal *Item_func_plus::decimal_op(my_decimal *decimal_value)
void
Item_func_additive_op
::
result_precision
()
void
Item_func_additive_op
::
result_precision
()
{
{
decimals
=
max
(
args
[
0
]
->
decimals
,
args
[
1
]
->
decimals
);
decimals
=
max
(
args
[
0
]
->
decimals
,
args
[
1
]
->
decimals
);
int
max_int_part
=
max
(
args
[
0
]
->
decimal_precision
()
-
args
[
0
]
->
decimals
,
int
arg1_int
=
args
[
0
]
->
decimal_precision
()
-
args
[
0
]
->
decimals
;
args
[
1
]
->
decimal_precision
()
-
args
[
1
]
->
decimals
);
int
arg2_int
=
args
[
1
]
->
decimal_precision
()
-
args
[
1
]
->
decimals
;
int
precision
=
min
(
max_int_part
+
1
+
decimals
,
DECIMAL_MAX_PRECISION
);
int
est_prec
=
max
(
arg1_int
,
arg2_int
)
+
1
+
decimals
;
int
precision
=
min
(
est_prec
,
DECIMAL_MAX_PRECISION
);
/* Integer operations keep unsigned_flag if one of arguments is unsigned */
/* Integer operations keep unsigned_flag if one of arguments is unsigned */
if
(
result_type
()
==
INT_RESULT
)
if
(
result_type
()
==
INT_RESULT
)
...
@@ -1252,8 +1253,8 @@ void Item_func_mul::result_precision()
...
@@ -1252,8 +1253,8 @@ void Item_func_mul::result_precision()
else
else
unsigned_flag
=
args
[
0
]
->
unsigned_flag
&
args
[
1
]
->
unsigned_flag
;
unsigned_flag
=
args
[
0
]
->
unsigned_flag
&
args
[
1
]
->
unsigned_flag
;
decimals
=
min
(
args
[
0
]
->
decimals
+
args
[
1
]
->
decimals
,
DECIMAL_MAX_SCALE
);
decimals
=
min
(
args
[
0
]
->
decimals
+
args
[
1
]
->
decimals
,
DECIMAL_MAX_SCALE
);
int
precision
=
min
(
args
[
0
]
->
decimal_precision
()
+
args
[
1
]
->
decimal_precision
(),
uint
est_prec
=
args
[
0
]
->
decimal_precision
()
+
args
[
1
]
->
decimal_precision
();
DECIMAL_MAX_PRECISION
);
uint
precision
=
min
(
est_prec
,
DECIMAL_MAX_PRECISION
);
max_length
=
my_decimal_precision_to_length
(
precision
,
decimals
,
unsigned_flag
);
max_length
=
my_decimal_precision_to_length
(
precision
,
decimals
,
unsigned_flag
);
}
}
...
@@ -1300,8 +1301,8 @@ my_decimal *Item_func_div::decimal_op(my_decimal *decimal_value)
...
@@ -1300,8 +1301,8 @@ my_decimal *Item_func_div::decimal_op(my_decimal *decimal_value)
void
Item_func_div
::
result_precision
()
void
Item_func_div
::
result_precision
()
{
{
uint
precision
=
min
(
args
[
0
]
->
decimal_precision
()
+
prec_increment
,
uint
arg_prec
=
args
[
0
]
->
decimal_precision
()
+
prec_increment
;
DECIMAL_MAX_PRECISION
);
uint
precision
=
min
(
arg_prec
,
DECIMAL_MAX_PRECISION
);
/* Integer operations keep unsigned_flag if one of arguments is unsigned */
/* Integer operations keep unsigned_flag if one of arguments is unsigned */
if
(
result_type
()
==
INT_RESULT
)
if
(
result_type
()
==
INT_RESULT
)
unsigned_flag
=
args
[
0
]
->
unsigned_flag
|
args
[
1
]
->
unsigned_flag
;
unsigned_flag
=
args
[
0
]
->
unsigned_flag
|
args
[
1
]
->
unsigned_flag
;
...
...
sql/sql_select.cc
View file @
a3cd2e2d
...
@@ -6754,6 +6754,12 @@ void JOIN::cleanup(bool full)
...
@@ -6754,6 +6754,12 @@ void JOIN::cleanup(bool full)
if
(
tmp_join
)
if
(
tmp_join
)
tmp_table_param
.
copy_field
=
0
;
tmp_table_param
.
copy_field
=
0
;
group_fields
.
delete_elements
();
group_fields
.
delete_elements
();
/*
Ensure that the above delete_elements() would not be called
twice for the same list.
*/
if
(
tmp_join
&&
tmp_join
!=
this
)
tmp_join
->
group_fields
=
group_fields
;
/*
/*
We can't call delete_elements() on copy_funcs as this will cause
We can't call delete_elements() on copy_funcs as this will cause
problems in free_elements() as some of the elements are then deleted.
problems in free_elements() as some of the elements are then deleted.
...
...
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