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
0f298415
Commit
0f298415
authored
Jul 31, 2009
by
V Narayanan
Browse files
Options
Browse Files
Download
Plain Diff
merging with mysql-5.1-bugteam
parents
a90bcde0
0d61bd9d
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
115 additions
and
2 deletions
+115
-2
include/myisammrg.h
include/myisammrg.h
+1
-0
mysql-test/r/merge.result
mysql-test/r/merge.result
+46
-0
mysql-test/t/merge.test
mysql-test/t/merge.test
+43
-0
storage/myisammrg/ha_myisammrg.cc
storage/myisammrg/ha_myisammrg.cc
+5
-1
storage/myisammrg/ha_myisammrg.h
storage/myisammrg/ha_myisammrg.h
+2
-1
storage/myisammrg/myrg_info.c
storage/myisammrg/myrg_info.c
+18
-0
No files found.
include/myisammrg.h
View file @
0f298415
...
...
@@ -47,6 +47,7 @@ typedef struct st_mymerge_info /* Struct from h_info */
ulonglong
deleted
;
/* Deleted records in database */
ulonglong
recpos
;
/* Pos for last used record */
ulonglong
data_file_length
;
ulonglong
dupp_key_pos
;
/* Offset of the Duplicate key in the merge table */
uint
reclength
;
/* Recordlength */
int
errkey
;
/* With key was dupplicated on err */
uint
options
;
/* HA_OPTION_... used */
...
...
mysql-test/r/merge.result
View file @
0f298415
...
...
@@ -2115,6 +2115,52 @@ insert into m1 (col1) values (1);
insert into m1 (col1) values (1);
ERROR 23000: Duplicate entry '' for key '*UNKNOWN*'
drop table m1, t1;
#
# Bug#45800 crash when replacing into a merge table and there is a duplicate
#
# Replace duplicate value in child table when merge table doesn't have key
CREATE TABLE t1 (c1 INT PRIMARY KEY) ENGINE=MyISAM;
CREATE TABLE m1 (c1 INT NOT NULL) ENGINE=MRG_MyISAM INSERT_METHOD=LAST UNION=(t1);
INSERT INTO m1 VALUES (666);
SELECT * FROM m1;
c1
666
# insert the duplicate value into the merge table
REPLACE INTO m1 VALUES (666);
SELECT * FROM m1;
c1
666
DROP TABLE m1, t1;
# Insert... on duplicate key update (with duplicate values in the table)
CREATE TABLE t1 (c1 INT PRIMARY KEY) ENGINE=MyISAM;
CREATE TABLE m1 (c1 INT NOT NULL) ENGINE=MRG_MyISAM INSERT_METHOD=LAST UNION=(t1);
INSERT INTO m1 VALUES (666);
SELECT * FROM m1;
c1
666
# insert the duplicate value into the merge table
INSERT INTO m1 VALUES (666) ON DUPLICATE KEY UPDATE c1=c1+1;
SELECT * FROM m1;
c1
667
DROP TABLE m1, t1;
# Insert duplicate value on MERGE table, where, MERGE has a key but MyISAM has more keys
CREATE TABLE t1 (c1 INT, c2 INT, UNIQUE (c1), UNIQUE (c2));
CREATE TABLE m1 (c1 INT, c2 INT, UNIQUE (c1)) ENGINE=MRG_MyISAM INSERT_METHOD=LAST UNION=(t1);
INSERT INTO m1 VALUES (1,2);
# insert the duplicate value into the merge table
INSERT INTO m1 VALUES (3,2);
ERROR 23000: Duplicate entry '' for key '*UNKNOWN*'
DROP TABLE m1,t1;
# Try to define MERGE and MyISAM with keys on different columns
CREATE TABLE t1 (c1 INT, c2 INT, UNIQUE (c1));
CREATE TABLE m1 (c1 INT, c2 INT, UNIQUE (c2)) ENGINE=MRG_MyISAM INSERT_METHOD=LAST UNION=(t1);
# Try accessing the merge table for inserts (error occurs)
INSERT INTO m1 VALUES (1,2);
ERROR HY000: Unable to open underlying table which is differently defined or of non-MyISAM type or doesn't exist
INSERT INTO m1 VALUES (1,4);
ERROR HY000: Unable to open underlying table which is differently defined or of non-MyISAM type or doesn't exist
DROP TABLE m1,t1;
CREATE TABLE t1 (
col1 INT(10)
) ENGINE=MyISAM DEFAULT CHARSET=latin1;
...
...
mysql-test/t/merge.test
View file @
0f298415
...
...
@@ -1515,6 +1515,49 @@ insert into m1 (col1) values (1);
drop
table
m1
,
t1
;
--
echo
#
--
echo
# Bug#45800 crash when replacing into a merge table and there is a duplicate
--
echo
#
--
echo
# Replace duplicate value in child table when merge table doesn't have key
CREATE
TABLE
t1
(
c1
INT
PRIMARY
KEY
)
ENGINE
=
MyISAM
;
CREATE
TABLE
m1
(
c1
INT
NOT
NULL
)
ENGINE
=
MRG_MyISAM
INSERT_METHOD
=
LAST
UNION
=
(
t1
);
INSERT
INTO
m1
VALUES
(
666
);
SELECT
*
FROM
m1
;
--
echo
# insert the duplicate value into the merge table
REPLACE
INTO
m1
VALUES
(
666
);
SELECT
*
FROM
m1
;
DROP
TABLE
m1
,
t1
;
--
echo
# Insert... on duplicate key update (with duplicate values in the table)
CREATE
TABLE
t1
(
c1
INT
PRIMARY
KEY
)
ENGINE
=
MyISAM
;
CREATE
TABLE
m1
(
c1
INT
NOT
NULL
)
ENGINE
=
MRG_MyISAM
INSERT_METHOD
=
LAST
UNION
=
(
t1
);
INSERT
INTO
m1
VALUES
(
666
);
SELECT
*
FROM
m1
;
--
echo
# insert the duplicate value into the merge table
INSERT
INTO
m1
VALUES
(
666
)
ON
DUPLICATE
KEY
UPDATE
c1
=
c1
+
1
;
SELECT
*
FROM
m1
;
DROP
TABLE
m1
,
t1
;
--
echo
# Insert duplicate value on MERGE table, where, MERGE has a key but MyISAM has more keys
CREATE
TABLE
t1
(
c1
INT
,
c2
INT
,
UNIQUE
(
c1
),
UNIQUE
(
c2
));
CREATE
TABLE
m1
(
c1
INT
,
c2
INT
,
UNIQUE
(
c1
))
ENGINE
=
MRG_MyISAM
INSERT_METHOD
=
LAST
UNION
=
(
t1
);
INSERT
INTO
m1
VALUES
(
1
,
2
);
--
echo
# insert the duplicate value into the merge table
--
error
ER_DUP_ENTRY
INSERT
INTO
m1
VALUES
(
3
,
2
);
DROP
TABLE
m1
,
t1
;
--
echo
# Try to define MERGE and MyISAM with keys on different columns
CREATE
TABLE
t1
(
c1
INT
,
c2
INT
,
UNIQUE
(
c1
));
CREATE
TABLE
m1
(
c1
INT
,
c2
INT
,
UNIQUE
(
c2
))
ENGINE
=
MRG_MyISAM
INSERT_METHOD
=
LAST
UNION
=
(
t1
);
--
echo
# Try accessing the merge table for inserts (error occurs)
--
error
ER_WRONG_MRG_TABLE
INSERT
INTO
m1
VALUES
(
1
,
2
);
--
error
ER_WRONG_MRG_TABLE
INSERT
INTO
m1
VALUES
(
1
,
4
);
DROP
TABLE
m1
,
t1
;
#
#Bug #44040 MySQL allows creating a MERGE table upon VIEWs but crashes
#when using it
...
...
storage/myisammrg/ha_myisammrg.cc
View file @
0f298415
...
...
@@ -884,7 +884,6 @@ int ha_myisammrg::info(uint flag)
*/
mrg_info
.
errkey
=
MAX_KEY
;
}
errkey
=
mrg_info
.
errkey
;
table
->
s
->
keys_in_use
.
set_prefix
(
table
->
s
->
keys
);
stats
.
mean_rec_length
=
mrg_info
.
reclength
;
...
...
@@ -934,6 +933,11 @@ int ha_myisammrg::info(uint flag)
min
(
file
->
keys
,
table
->
s
->
key_parts
));
}
}
if
(
flag
&
HA_STATUS_ERRKEY
)
{
errkey
=
mrg_info
.
errkey
;
my_store_ptr
(
dup_ref
,
ref_length
,
mrg_info
.
dupp_key_pos
);
}
return
0
;
}
...
...
storage/myisammrg/ha_myisammrg.h
View file @
0f298415
...
...
@@ -44,7 +44,8 @@ class ha_myisammrg: public handler
HA_NULL_IN_KEY
|
HA_CAN_INDEX_BLOBS
|
HA_FILE_BASED
|
HA_ANY_INDEX_MAY_BE_UNIQUE
|
HA_CAN_BIT_FIELD
|
HA_HAS_RECORDS
|
HA_NO_COPY_ON_ALTER
);
HA_NO_COPY_ON_ALTER
|
HA_DUPLICATE_POS
);
}
ulong
index_flags
(
uint
inx
,
uint
part
,
bool
all_parts
)
const
{
...
...
storage/myisammrg/myrg_info.c
View file @
0f298415
...
...
@@ -58,9 +58,27 @@ int myrg_status(MYRG_INFO *info,register MYMERGE_INFO *x,int flag)
x
->
reclength
=
info
->
reclength
;
x
->
options
=
info
->
options
;
if
(
current_table
)
{
/*
errkey is set to the index number of the myisam tables. But
since the MERGE table can have less keys than the MyISAM
tables, errkey cannot be be used as an index into the key_info
on the server. This value will be overwritten with MAX_KEY by
the MERGE engine.
*/
x
->
errkey
=
current_table
->
table
->
errkey
;
/*
Calculate the position of the duplicate key to be the sum of the
offset of the myisam file and the offset into the file at which
the duplicate key is located.
*/
x
->
dupp_key_pos
=
current_table
->
file_offset
+
current_table
->
table
->
dupp_key_pos
;
}
else
{
x
->
errkey
=
0
;
x
->
dupp_key_pos
=
0
;
}
x
->
rec_per_key
=
info
->
rec_per_key_part
;
}
DBUG_RETURN
(
0
);
...
...
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