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
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
5a7bee5c
Commit
5a7bee5c
authored
Feb 11, 2013
by
unknown
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
MDEV-4123 fix.
Missed update_used_tables() call for multi-update values.
parent
12bd3ddf
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
111 additions
and
1 deletion
+111
-1
mysql-test/r/multi_update.result
mysql-test/r/multi_update.result
+51
-0
mysql-test/t/multi_update.test
mysql-test/t/multi_update.test
+47
-0
sql/sql_class.h
sql/sql_class.h
+2
-0
sql/sql_lex.cc
sql/sql_lex.cc
+2
-1
sql/sql_update.cc
sql/sql_update.cc
+9
-0
No files found.
mysql-test/r/multi_update.result
View file @
5a7bee5c
...
@@ -675,4 +675,55 @@ Warning 1292 Incorrect datetime value: '1'
...
@@ -675,4 +675,55 @@ Warning 1292 Incorrect datetime value: '1'
DROP VIEW v1;
DROP VIEW v1;
DROP FUNCTION f1;
DROP FUNCTION f1;
DROP TABLE t1;
DROP TABLE t1;
#
# MDEV-4123: Incorrect results after multi-table update or
# assertion `!table || (!table->read_set ||
# bitmap_is_set(table->read_set, field_index))' failure
#
DROP TABLE IF EXISTS t1;
Warnings:
Note 1051 Unknown table 't1'
CREATE TABLE t1 (
id int(10) unsigned NOT NULL,
level tinyint(3) unsigned NOT NULL,
PRIMARY KEY (id)
);
INSERT INTO t1 VALUES (2519583,1);
DROP TABLE IF EXISTS t2;
Warnings:
Note 1051 Unknown table 't2'
CREATE TABLE t2 (
club_id int(11) NOT NULL DEFAULT '0',
profile_id int(11) NOT NULL DEFAULT '0',
member_level_id int(11) NOT NULL DEFAULT '0',
PRIMARY KEY (profile_id,club_id)
);
INSERT INTO t2 VALUES (2,2519583,12);
DROP TABLE IF EXISTS t3;
Warnings:
Note 1051 Unknown table 't3'
CREATE TABLE t3 (
member_level_id int(11) unsigned NOT NULL DEFAULT '0',
map_level int(11) unsigned NOT NULL DEFAULT '0',
map_status int(11) unsigned NOT NULL DEFAULT '0',
PRIMARY KEY (member_level_id)
);
INSERT INTO t3 VALUES (12,12,1);
CREATE
VIEW v1 AS
select club_id,profile_id,
map_level AS member_level_id,map_status AS member_status
from (t2 tc join t3 map
on(((tc.member_level_id = map.member_level_id) and
(club_id = 2))));
select level, count(*) as cnt from t1 group by level;
level cnt
1 1
UPDATE t1 c LEFT JOIN v1 t ON (c.id = t.profile_id AND t.club_id = 2)
SET c.level = IF (t.member_status IS NULL, 1, IF (t.member_status = 1, 2,3));
select level, count(*) as cnt from t1 group by level;
level cnt
2 1
drop view v1;
drop table t1,t2,t3;
end of tests
end of tests
mysql-test/t/multi_update.test
View file @
5a7bee5c
...
@@ -691,4 +691,51 @@ DROP VIEW v1;
...
@@ -691,4 +691,51 @@ DROP VIEW v1;
DROP
FUNCTION
f1
;
DROP
FUNCTION
f1
;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
--
echo
#
--
echo
# MDEV-4123: Incorrect results after multi-table update or
--
echo
# assertion `!table || (!table->read_set ||
--
echo
# bitmap_is_set(table->read_set, field_index))' failure
--
echo
#
DROP
TABLE
IF
EXISTS
t1
;
CREATE
TABLE
t1
(
id
int
(
10
)
unsigned
NOT
NULL
,
level
tinyint
(
3
)
unsigned
NOT
NULL
,
PRIMARY
KEY
(
id
)
);
INSERT
INTO
t1
VALUES
(
2519583
,
1
);
DROP
TABLE
IF
EXISTS
t2
;
CREATE
TABLE
t2
(
club_id
int
(
11
)
NOT
NULL
DEFAULT
'0'
,
profile_id
int
(
11
)
NOT
NULL
DEFAULT
'0'
,
member_level_id
int
(
11
)
NOT
NULL
DEFAULT
'0'
,
PRIMARY
KEY
(
profile_id
,
club_id
)
);
INSERT
INTO
t2
VALUES
(
2
,
2519583
,
12
);
DROP
TABLE
IF
EXISTS
t3
;
CREATE
TABLE
t3
(
member_level_id
int
(
11
)
unsigned
NOT
NULL
DEFAULT
'0'
,
map_level
int
(
11
)
unsigned
NOT
NULL
DEFAULT
'0'
,
map_status
int
(
11
)
unsigned
NOT
NULL
DEFAULT
'0'
,
PRIMARY
KEY
(
member_level_id
)
);
INSERT
INTO
t3
VALUES
(
12
,
12
,
1
);
CREATE
VIEW
v1
AS
select
club_id
,
profile_id
,
map_level
AS
member_level_id
,
map_status
AS
member_status
from
(
t2
tc
join
t3
map
on
(((
tc
.
member_level_id
=
map
.
member_level_id
)
and
(
club_id
=
2
))));
select
level
,
count
(
*
)
as
cnt
from
t1
group
by
level
;
UPDATE
t1
c
LEFT
JOIN
v1
t
ON
(
c
.
id
=
t
.
profile_id
AND
t
.
club_id
=
2
)
SET
c
.
level
=
IF
(
t
.
member_status
IS
NULL
,
1
,
IF
(
t
.
member_status
=
1
,
2
,
3
));
select
level
,
count
(
*
)
as
cnt
from
t1
group
by
level
;
drop
view
v1
;
drop
table
t1
,
t2
,
t3
;
--
echo
end
of
tests
--
echo
end
of
tests
sql/sql_class.h
View file @
5a7bee5c
...
@@ -2833,6 +2833,7 @@ class select_result :public Sql_alloc {
...
@@ -2833,6 +2833,7 @@ class select_result :public Sql_alloc {
#else
#else
void
begin_dataset
()
{}
void
begin_dataset
()
{}
#endif
#endif
virtual
void
update_used_tables
()
{}
};
};
...
@@ -3578,6 +3579,7 @@ class multi_update :public select_result_interceptor
...
@@ -3578,6 +3579,7 @@ class multi_update :public select_result_interceptor
int
do_updates
();
int
do_updates
();
bool
send_eof
();
bool
send_eof
();
virtual
void
abort
();
virtual
void
abort
();
void
update_used_tables
();
};
};
class
my_var
:
public
Sql_alloc
{
class
my_var
:
public
Sql_alloc
{
...
...
sql/sql_lex.cc
View file @
5a7bee5c
...
@@ -3541,6 +3541,7 @@ void SELECT_LEX::update_used_tables()
...
@@ -3541,6 +3541,7 @@ void SELECT_LEX::update_used_tables()
for
(
ORDER
*
order
=
order_list
.
first
;
order
;
order
=
order
->
next
)
for
(
ORDER
*
order
=
order_list
.
first
;
order
;
order
=
order
->
next
)
(
*
order
->
item
)
->
update_used_tables
();
(
*
order
->
item
)
->
update_used_tables
();
}
}
join
->
result
->
update_used_tables
();
}
}
...
...
sql/sql_update.cc
View file @
5a7bee5c
...
@@ -1473,6 +1473,15 @@ int multi_update::prepare(List<Item> ¬_used_values,
...
@@ -1473,6 +1473,15 @@ int multi_update::prepare(List<Item> ¬_used_values,
DBUG_RETURN
(
thd
->
is_fatal_error
!=
0
);
DBUG_RETURN
(
thd
->
is_fatal_error
!=
0
);
}
}
void
multi_update
::
update_used_tables
()
{
Item
*
item
;
List_iterator_fast
<
Item
>
it
(
*
values
);
while
((
item
=
it
++
))
{
item
->
update_used_tables
();
}
}
/*
/*
Check if table is safe to update on fly
Check if table is safe to update on fly
...
...
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