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
44472d42
Commit
44472d42
authored
Sep 28, 2007
by
gni@dev3-221.dev.cn.tlan
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
BUG#29851 TRUNCATE causes error 4350 from cluster in INSERT... ON DUPLICATE KEY UPDATE
parent
2093858f
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
59 additions
and
1 deletion
+59
-1
mysql-test/r/ndb_alter_table2.result
mysql-test/r/ndb_alter_table2.result
+19
-0
mysql-test/t/ndb_alter_table2.test
mysql-test/t/ndb_alter_table2.test
+31
-0
sql/ha_ndbcluster.cc
sql/ha_ndbcluster.cc
+9
-1
No files found.
mysql-test/r/ndb_alter_table2.result
View file @
44472d42
...
@@ -40,3 +40,22 @@ a b c
...
@@ -40,3 +40,22 @@ a b c
select * from t1;
select * from t1;
a b c
a b c
drop table t1;
drop table t1;
DROP TABLE IF EXISTS truncate_test;
CREATE TABLE truncate_test (
i INT PRIMARY KEY,
a INT,
b VARCHAR(11),
UNIQUE KEY (a)
) ENGINE = NDB;
INSERT INTO truncate_test VALUES (1, 1, 'test') ON DUPLICATE KEY UPDATE b = 'new';
INSERT INTO truncate_test VALUES (1, 1, 'test') ON DUPLICATE KEY UPDATE b = 'new';
TRUNCATE truncate_test;
INSERT INTO truncate_test VALUES (1, 1, 'test') ON DUPLICATE KEY UPDATE b = 'new';
SELECT * FROM truncate_test;
i a b
1 1 test
INSERT INTO truncate_test VALUES (1, 1, 'test') ON DUPLICATE KEY UPDATE b = 'new';
SELECT * FROM truncate_test;
i a b
1 1 new
DROP TABLE truncate_test;
mysql-test/t/ndb_alter_table2.test
View file @
44472d42
...
@@ -81,3 +81,34 @@ select * from t1;
...
@@ -81,3 +81,34 @@ select * from t1;
select
*
from
t1
;
select
*
from
t1
;
drop
table
t1
;
drop
table
t1
;
#For BUG#29851 TRUNCATE causes error 4350 from cluster in INSERT... ON DUPLICATE KEY UPDATE
connection
con1
;
--
disable_warnings
DROP
TABLE
IF
EXISTS
truncate_test
;
--
enable_warnings
CREATE
TABLE
truncate_test
(
i
INT
PRIMARY
KEY
,
a
INT
,
b
VARCHAR
(
11
),
UNIQUE
KEY
(
a
)
)
ENGINE
=
NDB
;
INSERT
INTO
truncate_test
VALUES
(
1
,
1
,
'test'
)
ON
DUPLICATE
KEY
UPDATE
b
=
'new'
;
INSERT
INTO
truncate_test
VALUES
(
1
,
1
,
'test'
)
ON
DUPLICATE
KEY
UPDATE
b
=
'new'
;
connection
con2
;
TRUNCATE
truncate_test
;
connection
con1
;
INSERT
INTO
truncate_test
VALUES
(
1
,
1
,
'test'
)
ON
DUPLICATE
KEY
UPDATE
b
=
'new'
;
SELECT
*
FROM
truncate_test
;
connection
con2
;
INSERT
INTO
truncate_test
VALUES
(
1
,
1
,
'test'
)
ON
DUPLICATE
KEY
UPDATE
b
=
'new'
;
SELECT
*
FROM
truncate_test
;
DROP
TABLE
truncate_test
;
sql/ha_ndbcluster.cc
View file @
44472d42
...
@@ -439,7 +439,8 @@ void ha_ndbcluster::no_uncommitted_rows_reset(THD *thd)
...
@@ -439,7 +439,8 @@ void ha_ndbcluster::no_uncommitted_rows_reset(THD *thd)
void
ha_ndbcluster
::
invalidate_dictionary_cache
(
bool
global
)
void
ha_ndbcluster
::
invalidate_dictionary_cache
(
bool
global
)
{
{
NDBDICT
*
dict
=
get_ndb
()
->
getDictionary
();
Ndb
*
ndb
=
get_ndb
();
NDBDICT
*
dict
=
ndb
->
getDictionary
();
DBUG_ENTER
(
"invalidate_dictionary_cache"
);
DBUG_ENTER
(
"invalidate_dictionary_cache"
);
DBUG_PRINT
(
"info"
,
(
"invalidating %s"
,
m_tabname
));
DBUG_PRINT
(
"info"
,
(
"invalidating %s"
,
m_tabname
));
...
@@ -459,6 +460,7 @@ void ha_ndbcluster::invalidate_dictionary_cache(bool global)
...
@@ -459,6 +460,7 @@ void ha_ndbcluster::invalidate_dictionary_cache(bool global)
}
}
else
else
dict
->
removeCachedTable
(
m_tabname
);
dict
->
removeCachedTable
(
m_tabname
);
build_index_list
(
ndb
,
table
,
ILBP_OPEN
);
table
->
s
->
version
=
0L
;
/* Free when thread is ready */
table
->
s
->
version
=
0L
;
/* Free when thread is ready */
/* Invalidate indexes */
/* Invalidate indexes */
for
(
uint
i
=
0
;
i
<
table
->
s
->
keys
;
i
++
)
for
(
uint
i
=
0
;
i
<
table
->
s
->
keys
;
i
++
)
...
@@ -470,17 +472,23 @@ void ha_ndbcluster::invalidate_dictionary_cache(bool global)
...
@@ -470,17 +472,23 @@ void ha_ndbcluster::invalidate_dictionary_cache(bool global)
switch
(
idx_type
)
{
switch
(
idx_type
)
{
case
PRIMARY_KEY_ORDERED_INDEX
:
case
PRIMARY_KEY_ORDERED_INDEX
:
case
ORDERED_INDEX
:
case
ORDERED_INDEX
:
if
(
!
index
)
break
;
if
(
global
)
if
(
global
)
dict
->
invalidateIndex
(
index
->
getName
(),
m_tabname
);
dict
->
invalidateIndex
(
index
->
getName
(),
m_tabname
);
else
else
dict
->
removeCachedIndex
(
index
->
getName
(),
m_tabname
);
dict
->
removeCachedIndex
(
index
->
getName
(),
m_tabname
);
break
;
break
;
case
UNIQUE_ORDERED_INDEX
:
case
UNIQUE_ORDERED_INDEX
:
if
(
!
index
)
break
;
if
(
global
)
if
(
global
)
dict
->
invalidateIndex
(
index
->
getName
(),
m_tabname
);
dict
->
invalidateIndex
(
index
->
getName
(),
m_tabname
);
else
else
dict
->
removeCachedIndex
(
index
->
getName
(),
m_tabname
);
dict
->
removeCachedIndex
(
index
->
getName
(),
m_tabname
);
case
UNIQUE_INDEX
:
case
UNIQUE_INDEX
:
if
(
!
unique_index
)
break
;
if
(
global
)
if
(
global
)
dict
->
invalidateIndex
(
unique_index
->
getName
(),
m_tabname
);
dict
->
invalidateIndex
(
unique_index
->
getName
(),
m_tabname
);
else
else
...
...
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