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
6d38c87d
Commit
6d38c87d
authored
Apr 24, 2007
by
unknown
Browse files
Options
Browse Files
Download
Plain Diff
Merge mysql.com:/home/ram/work/mysql-4.1-maint
into mysql.com:/home/ram/work/b27515/b27515.4.1
parents
b9b1da75
31b48d64
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
180 additions
and
8 deletions
+180
-8
mysql-test/r/row.result
mysql-test/r/row.result
+98
-1
mysql-test/r/subselect.result
mysql-test/r/subselect.result
+2
-2
mysql-test/t/row.test
mysql-test/t/row.test
+45
-0
sql/item_cmpfunc.cc
sql/item_cmpfunc.cc
+32
-4
sql/item_cmpfunc.h
sql/item_cmpfunc.h
+3
-1
No files found.
mysql-test/r/row.result
View file @
6d38c87d
...
@@ -53,7 +53,7 @@ SELECT (1,2,3)=(1,NULL,3);
...
@@ -53,7 +53,7 @@ SELECT (1,2,3)=(1,NULL,3);
NULL
NULL
SELECT (1,2,3)=(1,NULL,0);
SELECT (1,2,3)=(1,NULL,0);
(1,2,3)=(1,NULL,0)
(1,2,3)=(1,NULL,0)
NULL
0
SELECT ROW(1,2,3)=ROW(1,2,3);
SELECT ROW(1,2,3)=ROW(1,2,3);
ROW(1,2,3)=ROW(1,2,3)
ROW(1,2,3)=ROW(1,2,3)
1
1
...
@@ -188,3 +188,100 @@ SELECT ROW(2,1) IN (ROW(21,2),ROW(ROW(1,1,3),0));
...
@@ -188,3 +188,100 @@ SELECT ROW(2,1) IN (ROW(21,2),ROW(ROW(1,1,3),0));
ERROR 21000: Operand should contain 1 column(s)
ERROR 21000: Operand should contain 1 column(s)
SELECT ROW(2,1) IN (ROW(ROW(1,1,3),0),ROW(21,2));
SELECT ROW(2,1) IN (ROW(ROW(1,1,3),0),ROW(21,2));
ERROR 21000: Operand should contain 1 column(s)
ERROR 21000: Operand should contain 1 column(s)
CREATE TABLE t1(a int, b int, c int);
INSERT INTO t1 VALUES (1, 2, 3),
(NULL, 2, 3 ), (1, NULL, 3 ), (1, 2, NULL),
(NULL, 2, 3+1), (1, NULL, 3+1), (1, 2+1, NULL),
(NULL, 2, 3-1), (1, NULL, 3-1), (1, 2-1, NULL);
SELECT (1,2,3) = (1, NULL, 3);
(1,2,3) = (1, NULL, 3)
NULL
SELECT (1,2,3) = (1+1, NULL, 3);
(1,2,3) = (1+1, NULL, 3)
0
SELECT (1,2,3) = (1, NULL, 3+1);
(1,2,3) = (1, NULL, 3+1)
0
SELECT * FROM t1 WHERE (a,b,c) = (1,2,3);
a b c
1 2 3
SELECT (1,2,3) <> (1, NULL, 3);
(1,2,3) <> (1, NULL, 3)
NULL
SELECT (1,2,3) <> (1+1, NULL, 3);
(1,2,3) <> (1+1, NULL, 3)
1
SELECT (1,2,3) <> (1, NULL, 3+1);
(1,2,3) <> (1, NULL, 3+1)
1
SELECT * FROM t1 WHERE (a,b,c) <> (1,2,3);
a b c
NULL 2 4
1 NULL 4
1 3 NULL
NULL 2 2
1 NULL 2
1 1 NULL
SELECT (1,2,3) < (NULL, 2, 3);
(1,2,3) < (NULL, 2, 3)
NULL
SELECT (1,2,3) < (1, NULL, 3);
(1,2,3) < (1, NULL, 3)
NULL
SELECT (1,2,3) < (1-1, NULL, 3);
(1,2,3) < (1-1, NULL, 3)
0
SELECT (1,2,3) < (1+1, NULL, 3);
(1,2,3) < (1+1, NULL, 3)
1
SELECT * FROM t1 WHERE (a,b,c) < (1,2,3);
a b c
1 1 NULL
SELECT (1,2,3) <= (NULL, 2, 3);
(1,2,3) <= (NULL, 2, 3)
NULL
SELECT (1,2,3) <= (1, NULL, 3);
(1,2,3) <= (1, NULL, 3)
NULL
SELECT (1,2,3) <= (1-1, NULL, 3);
(1,2,3) <= (1-1, NULL, 3)
0
SELECT (1,2,3) <= (1+1, NULL, 3);
(1,2,3) <= (1+1, NULL, 3)
1
SELECT * FROM t1 WHERE (a,b,c) <= (1,2,3);
a b c
1 2 3
1 1 NULL
SELECT (1,2,3) > (NULL, 2, 3);
(1,2,3) > (NULL, 2, 3)
NULL
SELECT (1,2,3) > (1, NULL, 3);
(1,2,3) > (1, NULL, 3)
NULL
SELECT (1,2,3) > (1-1, NULL, 3);
(1,2,3) > (1-1, NULL, 3)
1
SELECT (1,2,3) > (1+1, NULL, 3);
(1,2,3) > (1+1, NULL, 3)
0
SELECT * FROM t1 WHERE (a,b,c) > (1,2,3);
a b c
1 3 NULL
SELECT (1,2,3) >= (NULL, 2, 3);
(1,2,3) >= (NULL, 2, 3)
NULL
SELECT (1,2,3) >= (1, NULL, 3);
(1,2,3) >= (1, NULL, 3)
NULL
SELECT (1,2,3) >= (1-1, NULL, 3);
(1,2,3) >= (1-1, NULL, 3)
1
SELECT (1,2,3) >= (1+1, NULL, 3);
(1,2,3) >= (1+1, NULL, 3)
0
SELECT * FROM t1 WHERE (a,b,c) >= (1,2,3);
a b c
1 2 3
1 3 NULL
DROP TABLE t1;
mysql-test/r/subselect.result
View file @
6d38c87d
...
@@ -913,7 +913,7 @@ select a, (select a,b,c from t1 where t1.a=t2.a) = ROW(a,2,'a'),(select c from t
...
@@ -913,7 +913,7 @@ select a, (select a,b,c from t1 where t1.a=t2.a) = ROW(a,2,'a'),(select c from t
a (select a,b,c from t1 where t1.a=t2.a) = ROW(a,2,'a') (select c from t1 where a=t2.a)
a (select a,b,c from t1 where t1.a=t2.a) = ROW(a,2,'a') (select c from t1 where a=t2.a)
1 1 a
1 1 a
2 0 b
2 0 b
NULL
NULL
NULL
NULL
0
NULL
select a, (select a,b,c from t1 where t1.a=t2.a) = ROW(a,3,'b'),(select c from t1 where a=t2.a) from t2;
select a, (select a,b,c from t1 where t1.a=t2.a) = ROW(a,3,'b'),(select c from t1 where a=t2.a) from t2;
a (select a,b,c from t1 where t1.a=t2.a) = ROW(a,3,'b') (select c from t1 where a=t2.a)
a (select a,b,c from t1 where t1.a=t2.a) = ROW(a,3,'b') (select c from t1 where a=t2.a)
1 0 a
1 0 a
...
@@ -923,7 +923,7 @@ select a, (select a,b,c from t1 where t1.a=t2.a) = ROW(a,4,'c'),(select c from t
...
@@ -923,7 +923,7 @@ select a, (select a,b,c from t1 where t1.a=t2.a) = ROW(a,4,'c'),(select c from t
a (select a,b,c from t1 where t1.a=t2.a) = ROW(a,4,'c') (select c from t1 where a=t2.a)
a (select a,b,c from t1 where t1.a=t2.a) = ROW(a,4,'c') (select c from t1 where a=t2.a)
1 0 a
1 0 a
2 0 b
2 0 b
NULL
NULL
NULL
NULL
0
NULL
drop table t1,t2;
drop table t1,t2;
create table t1 (a int, b real, c varchar(10));
create table t1 (a int, b real, c varchar(10));
insert into t1 values (1, 1, 'a'), (2,2,'b'), (NULL, 2, 'b');
insert into t1 values (1, 1, 'a'), (2,2,'b'), (NULL, 2, 'b');
...
...
mysql-test/t/row.test
View file @
6d38c87d
...
@@ -108,4 +108,49 @@ SELECT ROW(2,1) IN (ROW(21,2),ROW(ROW(1,1,3),0));
...
@@ -108,4 +108,49 @@ SELECT ROW(2,1) IN (ROW(21,2),ROW(ROW(1,1,3),0));
--
error
1241
--
error
1241
SELECT
ROW
(
2
,
1
)
IN
(
ROW
(
ROW
(
1
,
1
,
3
),
0
),
ROW
(
21
,
2
));
SELECT
ROW
(
2
,
1
)
IN
(
ROW
(
ROW
(
1
,
1
,
3
),
0
),
ROW
(
21
,
2
));
#
# Bug#27704: erroneous comparison of rows with NULL components
#
CREATE
TABLE
t1
(
a
int
,
b
int
,
c
int
);
INSERT
INTO
t1
VALUES
(
1
,
2
,
3
),
(
NULL
,
2
,
3
),
(
1
,
NULL
,
3
),
(
1
,
2
,
NULL
),
(
NULL
,
2
,
3
+
1
),
(
1
,
NULL
,
3
+
1
),
(
1
,
2
+
1
,
NULL
),
(
NULL
,
2
,
3
-
1
),
(
1
,
NULL
,
3
-
1
),
(
1
,
2
-
1
,
NULL
);
SELECT
(
1
,
2
,
3
)
=
(
1
,
NULL
,
3
);
SELECT
(
1
,
2
,
3
)
=
(
1
+
1
,
NULL
,
3
);
SELECT
(
1
,
2
,
3
)
=
(
1
,
NULL
,
3
+
1
);
SELECT
*
FROM
t1
WHERE
(
a
,
b
,
c
)
=
(
1
,
2
,
3
);
SELECT
(
1
,
2
,
3
)
<>
(
1
,
NULL
,
3
);
SELECT
(
1
,
2
,
3
)
<>
(
1
+
1
,
NULL
,
3
);
SELECT
(
1
,
2
,
3
)
<>
(
1
,
NULL
,
3
+
1
);
SELECT
*
FROM
t1
WHERE
(
a
,
b
,
c
)
<>
(
1
,
2
,
3
);
SELECT
(
1
,
2
,
3
)
<
(
NULL
,
2
,
3
);
SELECT
(
1
,
2
,
3
)
<
(
1
,
NULL
,
3
);
SELECT
(
1
,
2
,
3
)
<
(
1
-
1
,
NULL
,
3
);
SELECT
(
1
,
2
,
3
)
<
(
1
+
1
,
NULL
,
3
);
SELECT
*
FROM
t1
WHERE
(
a
,
b
,
c
)
<
(
1
,
2
,
3
);
SELECT
(
1
,
2
,
3
)
<=
(
NULL
,
2
,
3
);
SELECT
(
1
,
2
,
3
)
<=
(
1
,
NULL
,
3
);
SELECT
(
1
,
2
,
3
)
<=
(
1
-
1
,
NULL
,
3
);
SELECT
(
1
,
2
,
3
)
<=
(
1
+
1
,
NULL
,
3
);
SELECT
*
FROM
t1
WHERE
(
a
,
b
,
c
)
<=
(
1
,
2
,
3
);
SELECT
(
1
,
2
,
3
)
>
(
NULL
,
2
,
3
);
SELECT
(
1
,
2
,
3
)
>
(
1
,
NULL
,
3
);
SELECT
(
1
,
2
,
3
)
>
(
1
-
1
,
NULL
,
3
);
SELECT
(
1
,
2
,
3
)
>
(
1
+
1
,
NULL
,
3
);
SELECT
*
FROM
t1
WHERE
(
a
,
b
,
c
)
>
(
1
,
2
,
3
);
SELECT
(
1
,
2
,
3
)
>=
(
NULL
,
2
,
3
);
SELECT
(
1
,
2
,
3
)
>=
(
1
,
NULL
,
3
);
SELECT
(
1
,
2
,
3
)
>=
(
1
-
1
,
NULL
,
3
);
SELECT
(
1
,
2
,
3
)
>=
(
1
+
1
,
NULL
,
3
);
SELECT
*
FROM
t1
WHERE
(
a
,
b
,
c
)
>=
(
1
,
2
,
3
);
DROP
TABLE
t1
;
# End of 4.1 tests
# End of 4.1 tests
sql/item_cmpfunc.cc
View file @
6d38c87d
...
@@ -680,17 +680,45 @@ int Arg_comparator::compare_e_int_diff_signedness()
...
@@ -680,17 +680,45 @@ int Arg_comparator::compare_e_int_diff_signedness()
int
Arg_comparator
::
compare_row
()
int
Arg_comparator
::
compare_row
()
{
{
int
res
=
0
;
int
res
=
0
;
bool
was_null
=
0
;
(
*
a
)
->
bring_value
();
(
*
a
)
->
bring_value
();
(
*
b
)
->
bring_value
();
(
*
b
)
->
bring_value
();
uint
n
=
(
*
a
)
->
cols
();
uint
n
=
(
*
a
)
->
cols
();
for
(
uint
i
=
0
;
i
<
n
;
i
++
)
for
(
uint
i
=
0
;
i
<
n
;
i
++
)
{
{
if
((
res
=
comparators
[
i
].
compare
()))
res
=
comparators
[
i
].
compare
();
return
res
;
if
(
owner
->
null_value
)
if
(
owner
->
null_value
)
return
-
1
;
{
// NULL was compared
switch
(
owner
->
functype
())
{
case
Item_func
:
:
NE_FUNC
:
break
;
// NE never aborts on NULL even if abort_on_null is set
case
Item_func
:
:
LT_FUNC
:
case
Item_func
:
:
LE_FUNC
:
case
Item_func
:
:
GT_FUNC
:
case
Item_func
:
:
GE_FUNC
:
return
-
1
;
// <, <=, > and >= always fail on NULL
default:
// EQ_FUNC
if
(
owner
->
abort_on_null
)
return
-
1
;
// We do not need correct NULL returning
}
was_null
=
1
;
owner
->
null_value
=
0
;
res
=
0
;
// continue comparison (maybe we will meet explicit difference)
}
else
if
(
res
)
return
res
;
}
}
return
res
;
if
(
was_null
)
{
/*
There was NULL(s) in comparison in some parts, but there was no
explicit difference in other parts, so we have to return NULL.
*/
owner
->
null_value
=
1
;
return
-
1
;
}
return
0
;
}
}
int
Arg_comparator
::
compare_e_row
()
int
Arg_comparator
::
compare_e_row
()
...
...
sql/item_cmpfunc.h
View file @
6d38c87d
...
@@ -206,10 +206,11 @@ class Item_bool_func2 :public Item_int_func
...
@@ -206,10 +206,11 @@ class Item_bool_func2 :public Item_int_func
protected:
protected:
Arg_comparator
cmp
;
Arg_comparator
cmp
;
String
tmp_value1
,
tmp_value2
;
String
tmp_value1
,
tmp_value2
;
bool
abort_on_null
;
public:
public:
Item_bool_func2
(
Item
*
a
,
Item
*
b
)
Item_bool_func2
(
Item
*
a
,
Item
*
b
)
:
Item_int_func
(
a
,
b
),
cmp
(
tmp_arg
,
tmp_arg
+
1
)
{}
:
Item_int_func
(
a
,
b
),
cmp
(
tmp_arg
,
tmp_arg
+
1
)
,
abort_on_null
(
FALSE
)
{}
void
fix_length_and_dec
();
void
fix_length_and_dec
();
void
set_cmp_func
()
void
set_cmp_func
()
{
{
...
@@ -222,6 +223,7 @@ public:
...
@@ -222,6 +223,7 @@ public:
bool
is_null
()
{
return
test
(
args
[
0
]
->
is_null
()
||
args
[
1
]
->
is_null
());
}
bool
is_null
()
{
return
test
(
args
[
0
]
->
is_null
()
||
args
[
1
]
->
is_null
());
}
bool
is_bool_func
()
{
return
1
;
}
bool
is_bool_func
()
{
return
1
;
}
CHARSET_INFO
*
compare_collation
()
{
return
cmp
.
cmp_collation
.
collation
;
}
CHARSET_INFO
*
compare_collation
()
{
return
cmp
.
cmp_collation
.
collation
;
}
void
top_level_item
()
{
abort_on_null
=
TRUE
;
}
friend
class
Arg_comparator
;
friend
class
Arg_comparator
;
};
};
...
...
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