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
be785cd8
Commit
be785cd8
authored
Apr 11, 2014
by
unknown
Browse files
Options
Browse Files
Download
Plain Diff
Merge MDEV-6067 from 5.3 to 5.5.
parents
16d90e5a
65f80d40
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
76 additions
and
21 deletions
+76
-21
mysql-test/suite/parts/r/partition_mdev6067.result
mysql-test/suite/parts/r/partition_mdev6067.result
+38
-0
mysql-test/suite/parts/t/partition_mdev6067.test
mysql-test/suite/parts/t/partition_mdev6067.test
+32
-0
sql/handler.cc
sql/handler.cc
+2
-5
sql/handler.h
sql/handler.h
+3
-15
sql/table.cc
sql/table.cc
+1
-1
No files found.
mysql-test/suite/parts/r/partition_mdev6067.result
0 → 100644
View file @
be785cd8
CREATE TABLE t1 (a INT PRIMARY KEY, b INT) ENGINE=InnoDB
PARTITION BY KEY (a) PARTITIONS 2;
INSERT INTO t1 VALUES (1,1);
INSERT INTO t1 VALUES (2,2), (3,8);
INSERT INTO t1 VALUES (4,16);
show binlog events in 'master-bin.000001' from <binlog_start>;
Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 # Query # # BEGIN
master-bin.000001 # Query # # use `test`; INSERT INTO t1 VALUES (1,1)
master-bin.000001 # Xid # # COMMIT /* XID */
master-bin.000001 # Query # # BEGIN
master-bin.000001 # Query # # use `test`; INSERT INTO t1 VALUES (2,2), (3,8)
master-bin.000001 # Xid # # COMMIT /* XID */
master-bin.000001 # Query # # BEGIN
master-bin.000001 # Query # # use `test`; INSERT INTO t1 VALUES (4,16)
master-bin.000001 # Xid # # COMMIT /* XID */
DROP TABLE t1;
SET binlog_format='row';
CREATE TABLE t1 (a INT PRIMARY KEY, b INT) ENGINE=InnoDB
PARTITION BY KEY (a) PARTITIONS 2;
INSERT INTO t1 VALUES (1,1);
INSERT INTO t1 VALUES (2,2), (3,8);
INSERT INTO t1 VALUES (4,16);
show binlog events in 'master-bin.000001' from <binlog_start>;
Log_name Pos Event_type Server_id End_log_pos Info
master-bin.000001 # Query # # BEGIN
master-bin.000001 # Table_map # # table_id: # (test.t1)
master-bin.000001 # Write_rows # # table_id: # flags: STMT_END_F
master-bin.000001 # Xid # # COMMIT /* XID */
master-bin.000001 # Query # # BEGIN
master-bin.000001 # Table_map # # table_id: # (test.t1)
master-bin.000001 # Write_rows # # table_id: # flags: STMT_END_F
master-bin.000001 # Xid # # COMMIT /* XID */
master-bin.000001 # Query # # BEGIN
master-bin.000001 # Table_map # # table_id: # (test.t1)
master-bin.000001 # Write_rows # # table_id: # flags: STMT_END_F
master-bin.000001 # Xid # # COMMIT /* XID */
DROP TABLE t1;
mysql-test/suite/parts/t/partition_mdev6067.test
0 → 100644
View file @
be785cd8
--
source
include
/
have_innodb
.
inc
--
source
include
/
have_partition
.
inc
--
source
include
/
have_binlog_format_statement
.
inc
# Test binlogging of some transactions on a partitioned InnoDB table.
# The bug was seen as one of the inserts being logged with a COMMIT query
# event instead of the correct XID event.
CREATE
TABLE
t1
(
a
INT
PRIMARY
KEY
,
b
INT
)
ENGINE
=
InnoDB
PARTITION
BY
KEY
(
a
)
PARTITIONS
2
;
--
let
$binlog_file
=
query_get_value
(
SHOW
MASTER
STATUS
,
File
,
1
)
--
let
$binlog_start
=
query_get_value
(
SHOW
MASTER
STATUS
,
Position
,
1
)
INSERT
INTO
t1
VALUES
(
1
,
1
);
INSERT
INTO
t1
VALUES
(
2
,
2
),
(
3
,
8
);
INSERT
INTO
t1
VALUES
(
4
,
16
);
--
source
include
/
show_binlog_events
.
inc
# Same thing in row mode.
DROP
TABLE
t1
;
SET
binlog_format
=
'row'
;
CREATE
TABLE
t1
(
a
INT
PRIMARY
KEY
,
b
INT
)
ENGINE
=
InnoDB
PARTITION
BY
KEY
(
a
)
PARTITIONS
2
;
--
let
$binlog_file
=
query_get_value
(
SHOW
MASTER
STATUS
,
File
,
1
)
--
let
$binlog_start
=
query_get_value
(
SHOW
MASTER
STATUS
,
Position
,
1
)
INSERT
INTO
t1
VALUES
(
1
,
1
);
INSERT
INTO
t1
VALUES
(
2
,
2
),
(
3
,
8
);
INSERT
INTO
t1
VALUES
(
4
,
16
);
--
source
include
/
show_binlog_events
.
inc
DROP
TABLE
t1
;
sql/handler.cc
View file @
be785cd8
...
...
@@ -3474,14 +3474,11 @@ int handler::ha_check(THD *thd, HA_CHECK_OPT *check_opt)
if it is started.
*/
inline
void
handler
::
mark_trx_read_write
_part2
()
handler
::
mark_trx_read_write
()
{
Ha_trx_info
*
ha_info
=
&
ha_thd
()
->
ha_data
[
ht
->
slot
].
ha_info
[
0
];
/* Don't call this function again for this statement */
mark_trx_done
=
TRUE
;
/*
When a storage engine method is called, the transaction must
have been started, unless it's a DDL call, for which the
...
...
sql/handler.h
View file @
be785cd8
...
...
@@ -1757,7 +1757,6 @@ class handler :public Sql_alloc
enum
{
NONE
=
0
,
INDEX
,
RND
}
inited
;
bool
locked
;
bool
implicit_emptied
;
/* Can be !=0 only if HEAP */
bool
mark_trx_done
;
const
COND
*
pushed_cond
;
/**
next_insert_id is the next value which should be inserted into the
...
...
@@ -1820,7 +1819,7 @@ class handler :public Sql_alloc
in_range_check_pushed_down
(
FALSE
),
ref_length
(
sizeof
(
my_off_t
)),
ft_handler
(
0
),
inited
(
NONE
),
locked
(
FALSE
),
implicit_emptied
(
0
),
mark_trx_done
(
FALSE
),
locked
(
FALSE
),
implicit_emptied
(
0
),
pushed_cond
(
0
),
next_insert_id
(
0
),
insert_id_for_cur_row
(
0
),
pushed_idx_cond
(
NULL
),
pushed_idx_cond_keyno
(
MAX_KEY
),
...
...
@@ -1898,13 +1897,6 @@ class handler :public Sql_alloc
}
int
ha_rnd_init_with_error
(
bool
scan
)
__attribute__
((
warn_unused_result
));
int
ha_reset
();
/* Tell handler (not storage engine) this is start of a new statement */
void
ha_start_of_new_statement
()
{
ft_handler
=
0
;
mark_trx_done
=
FALSE
;
}
/* this is necessary in many places, e.g. in HANDLER command */
int
ha_index_or_rnd_end
()
{
...
...
@@ -2773,12 +2765,8 @@ class handler :public Sql_alloc
private:
/* Private helpers */
void
mark_trx_read_write_part2
();
inline
void
mark_trx_read_write
()
{
if
(
!
mark_trx_done
)
mark_trx_read_write_part2
();
}
inline
void
mark_trx_read_write
();
private:
inline
void
increment_statistics
(
ulong
SSV
::*
offset
)
const
;
inline
void
decrement_statistics
(
ulong
SSV
::*
offset
)
const
;
...
...
sql/table.cc
View file @
be785cd8
...
...
@@ -3954,7 +3954,7 @@ void TABLE::init(THD *thd, TABLE_LIST *tl)
status
=
STATUS_NO_RECORD
;
insert_values
=
0
;
fulltext_searched
=
0
;
file
->
ha_start_of_new_statement
()
;
file
->
ft_handler
=
0
;
reginfo
.
impossible_range
=
0
;
created
=
TRUE
;
...
...
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