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
16b79adf
Commit
16b79adf
authored
Nov 24, 2006
by
baker@bk-internal.mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge bk-internal.mysql.com:/data0/bk/mysql-5.1
into bk-internal.mysql.com:/data0/bk/mysql-5.1-arch
parents
098571df
333f794a
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
45 additions
and
29 deletions
+45
-29
sql/log_event.cc
sql/log_event.cc
+33
-29
sql/sql_binlog.cc
sql/sql_binlog.cc
+12
-0
No files found.
sql/log_event.cc
View file @
16b79adf
...
@@ -5467,14 +5467,13 @@ int Rows_log_event::do_add_row_data(byte *const row_data,
...
@@ -5467,14 +5467,13 @@ int Rows_log_event::do_add_row_data(byte *const row_data,
#if !defined(MYSQL_CLIENT) && defined(HAVE_REPLICATION)
#if !defined(MYSQL_CLIENT) && defined(HAVE_REPLICATION)
/*
/*
Unpack a row into
a record
.
Unpack a row into
table->record[0]
.
SYNOPSIS
SYNOPSIS
unpack_row()
unpack_row()
rli Relay log info
rli Relay log info
table Table to unpack into
table Table to unpack into
colcnt Number of columns to read from record
colcnt Number of columns to read from record
record Record where the data should be unpacked
row Packed row data
row Packed row data
cols Pointer to columns data to fill in
cols Pointer to columns data to fill in
row_end Pointer to variable that will hold the value of the
row_end Pointer to variable that will hold the value of the
...
@@ -5487,6 +5486,11 @@ int Rows_log_event::do_add_row_data(byte *const row_data,
...
@@ -5487,6 +5486,11 @@ int Rows_log_event::do_add_row_data(byte *const row_data,
DESCRIPTION
DESCRIPTION
The function will always unpack into the table->record[0]
record. This is because there are too many dependencies on
where the various member functions of Field and subclasses
expect to write.
The row is assumed to only consist of the fields for which the
The row is assumed to only consist of the fields for which the
bitset represented by 'arr' and 'bits'; the other parts of the
bitset represented by 'arr' and 'bits'; the other parts of the
record are left alone.
record are left alone.
...
@@ -5505,15 +5509,15 @@ int Rows_log_event::do_add_row_data(byte *const row_data,
...
@@ -5505,15 +5509,15 @@ int Rows_log_event::do_add_row_data(byte *const row_data,
*/
*/
static
int
static
int
unpack_row
(
RELAY_LOG_INFO
*
rli
,
unpack_row
(
RELAY_LOG_INFO
*
rli
,
TABLE
*
table
,
uint
const
colcnt
,
byte
*
record
,
TABLE
*
table
,
uint
const
colcnt
,
char
const
*
row
,
MY_BITMAP
const
*
cols
,
char
const
*
row
,
MY_BITMAP
const
*
cols
,
char
const
**
row_end
,
ulong
*
master_reclength
,
char
const
**
row_end
,
ulong
*
master_reclength
,
MY_BITMAP
*
const
rw_set
,
Log_event_type
const
event_type
)
MY_BITMAP
*
const
rw_set
,
Log_event_type
const
event_type
)
{
{
byte
*
const
record
=
table
->
record
[
0
];
DBUG_ENTER
(
"unpack_row"
);
DBUG_ENTER
(
"unpack_row"
);
DBUG_ASSERT
(
record
&&
row
);
DBUG_ASSERT
(
record
&&
row
);
DBUG_PRINT
(
"enter"
,
(
"row=0x%lx; record=0x%lx"
,
row
,
record
));
DBUG_PRINT
(
"enter"
,
(
"row=0x%lx; table->record[0]=0x%lx"
,
row
,
record
));
my_ptrdiff_t
const
offset
=
record
-
(
byte
*
)
table
->
record
[
0
];
my_size_t
master_null_bytes
=
table
->
s
->
null_bytes
;
my_size_t
master_null_bytes
=
table
->
s
->
null_bytes
;
if
(
colcnt
!=
table
->
s
->
fields
)
if
(
colcnt
!=
table
->
s
->
fields
)
...
@@ -5555,11 +5559,9 @@ unpack_row(RELAY_LOG_INFO *rli,
...
@@ -5555,11 +5559,9 @@ unpack_row(RELAY_LOG_INFO *rli,
{
{
DBUG_ASSERT
(
table
->
record
[
0
]
<=
f
->
ptr
);
DBUG_ASSERT
(
table
->
record
[
0
]
<=
f
->
ptr
);
DBUG_ASSERT
(
f
->
ptr
<
table
->
record
[
0
]
+
table
->
s
->
reclength
+
(
f
->
pack_length_in_rec
()
==
0
));
DBUG_ASSERT
(
f
->
ptr
<
table
->
record
[
0
]
+
table
->
s
->
reclength
+
(
f
->
pack_length_in_rec
()
==
0
));
f
->
move_field_offset
(
offset
);
DBUG_PRINT
(
"info"
,
(
"unpacking column '%s' to 0x%lx"
,
f
->
field_name
,
f
->
ptr
));
DBUG_PRINT
(
"info"
,
(
"unpacking column '%s' to 0x%lx"
,
f
->
field_name
,
f
->
ptr
));
ptr
=
f
->
unpack
(
f
->
ptr
,
ptr
);
ptr
=
f
->
unpack
(
f
->
ptr
,
ptr
);
f
->
move_field_offset
(
-
offset
);
/* Field...::unpack() cannot return 0 */
/* Field...::unpack() cannot return 0 */
DBUG_ASSERT
(
ptr
!=
NULL
);
DBUG_ASSERT
(
ptr
!=
NULL
);
}
}
...
@@ -5590,9 +5592,10 @@ unpack_row(RELAY_LOG_INFO *rli,
...
@@ -5590,9 +5592,10 @@ unpack_row(RELAY_LOG_INFO *rli,
for
(
;
*
field_ptr
;
++
field_ptr
)
for
(
;
*
field_ptr
;
++
field_ptr
)
{
{
uint32
const
mask
=
NOT_NULL_FLAG
|
NO_DEFAULT_VALUE_FLAG
;
uint32
const
mask
=
NOT_NULL_FLAG
|
NO_DEFAULT_VALUE_FLAG
;
Field
*
const
f
=
*
field_ptr
;
if
(
event_type
==
WRITE_ROWS_EVENT
&&
DBUG_PRINT
(
"info"
,
(
"processing column '%s' @ 0x%lx"
,
f
->
field_name
,
f
->
ptr
));
((
*
field_ptr
)
->
flags
&
mask
)
==
mask
)
if
(
event_type
==
WRITE_ROWS_EVENT
&&
(
f
->
flags
&
mask
)
==
mask
)
{
{
slave_print_msg
(
ERROR_LEVEL
,
rli
,
ER_NO_DEFAULT_FOR_FIELD
,
slave_print_msg
(
ERROR_LEVEL
,
rli
,
ER_NO_DEFAULT_FOR_FIELD
,
"Field `%s` of table `%s`.`%s` "
"Field `%s` of table `%s`.`%s` "
...
@@ -5602,7 +5605,7 @@ unpack_row(RELAY_LOG_INFO *rli,
...
@@ -5602,7 +5605,7 @@ unpack_row(RELAY_LOG_INFO *rli,
error
=
ER_NO_DEFAULT_FOR_FIELD
;
error
=
ER_NO_DEFAULT_FOR_FIELD
;
}
}
else
else
(
*
field_ptr
)
->
set_default
();
f
->
set_default
();
}
}
DBUG_RETURN
(
error
);
DBUG_RETURN
(
error
);
...
@@ -6458,10 +6461,8 @@ int Write_rows_log_event::do_prepare_row(THD *thd, RELAY_LOG_INFO *rli,
...
@@ -6458,10 +6461,8 @@ int Write_rows_log_event::do_prepare_row(THD *thd, RELAY_LOG_INFO *rli,
DBUG_ASSERT
(
row_start
&&
row_end
);
DBUG_ASSERT
(
row_start
&&
row_end
);
int
error
;
int
error
;
error
=
unpack_row
(
rli
,
error
=
unpack_row
(
rli
,
table
,
m_width
,
row_start
,
&
m_cols
,
row_end
,
table
,
m_width
,
table
->
record
[
0
],
&
m_master_reclength
,
table
->
write_set
,
WRITE_ROWS_EVENT
);
row_start
,
&
m_cols
,
row_end
,
&
m_master_reclength
,
table
->
write_set
,
WRITE_ROWS_EVENT
);
bitmap_copy
(
table
->
read_set
,
table
->
write_set
);
bitmap_copy
(
table
->
read_set
,
table
->
write_set
);
return
error
;
return
error
;
}
}
...
@@ -6682,7 +6683,7 @@ replace_record(THD *thd, TABLE *table,
...
@@ -6682,7 +6683,7 @@ replace_record(THD *thd, TABLE *table,
present on the master from table->record[1], if there are any.
present on the master from table->record[1], if there are any.
*/
*/
copy_extra_record_fields
(
table
,
master_reclength
,
master_fields
);
copy_extra_record_fields
(
table
,
master_reclength
,
master_fields
);
/*
/*
REPLACE is defined as either INSERT or DELETE + INSERT. If
REPLACE is defined as either INSERT or DELETE + INSERT. If
possible, we can replace it with an UPDATE, but that will not
possible, we can replace it with an UPDATE, but that will not
...
@@ -7063,10 +7064,8 @@ int Delete_rows_log_event::do_prepare_row(THD *thd, RELAY_LOG_INFO *rli,
...
@@ -7063,10 +7064,8 @@ int Delete_rows_log_event::do_prepare_row(THD *thd, RELAY_LOG_INFO *rli,
*/
*/
DBUG_ASSERT
(
table
->
s
->
fields
>=
m_width
);
DBUG_ASSERT
(
table
->
s
->
fields
>=
m_width
);
error
=
unpack_row
(
rli
,
error
=
unpack_row
(
rli
,
table
,
m_width
,
row_start
,
&
m_cols
,
row_end
,
table
,
m_width
,
table
->
record
[
0
],
&
m_master_reclength
,
table
->
read_set
,
DELETE_ROWS_EVENT
);
row_start
,
&
m_cols
,
row_end
,
&
m_master_reclength
,
table
->
read_set
,
DELETE_ROWS_EVENT
);
/*
/*
If we will access rows using the random access method, m_key will
If we will access rows using the random access method, m_key will
be set to NULL, so we do not need to make a key copy in that case.
be set to NULL, so we do not need to make a key copy in that case.
...
@@ -7200,25 +7199,30 @@ int Update_rows_log_event::do_prepare_row(THD *thd, RELAY_LOG_INFO *rli,
...
@@ -7200,25 +7199,30 @@ int Update_rows_log_event::do_prepare_row(THD *thd, RELAY_LOG_INFO *rli,
*/
*/
DBUG_ASSERT
(
table
->
s
->
fields
>=
m_width
);
DBUG_ASSERT
(
table
->
s
->
fields
>=
m_width
);
/*
We need to perform some juggling below since unpack_row() always
unpacks into table->record[0]. For more information, see the
comments for unpack_row().
*/
/* record[0] is the before image for the update */
/* record[0] is the before image for the update */
error
=
unpack_row
(
rli
,
error
=
unpack_row
(
rli
,
table
,
m_width
,
row_start
,
&
m_cols
,
row_end
,
table
,
m_width
,
table
->
record
[
0
],
&
m_master_reclength
,
table
->
read_set
,
UPDATE_ROWS_EVENT
);
row_start
,
&
m_cols
,
row_end
,
&
m_master_reclength
,
store_record
(
table
,
record
[
1
]);
table
->
read_set
,
UPDATE_ROWS_EVENT
);
char
const
*
next_start
=
*
row_end
;
char
const
*
next_start
=
*
row_end
;
/* m_after_image is the after image for the update */
/* m_after_image is the after image for the update */
error
=
unpack_row
(
rli
,
error
=
unpack_row
(
rli
,
table
,
m_width
,
next_start
,
&
m_cols
,
row_end
,
table
,
m_width
,
m_after_image
,
&
m_master_reclength
,
table
->
write_set
,
UPDATE_ROWS_EVENT
);
next_start
,
&
m_cols
,
row_end
,
&
m_master_reclength
,
bmove_align
(
m_after_image
,
table
->
record
[
0
],
table
->
s
->
reclength
);
table
->
write_set
,
UPDATE_ROWS_EVENT
);
restore_record
(
table
,
record
[
1
]
);
/*
/*
Don't print debug messages when running valgrind since they can
Don't print debug messages when running valgrind since they can
trigger false warnings.
trigger false warnings.
*/
*/
#ifndef HAVE_purify
#ifndef HAVE_purify
DBUG_DUMP
(
"record[0]"
,
(
const
char
*
)
table
->
record
[
0
],
m_master_
reclength
);
DBUG_DUMP
(
"record[0]"
,
(
const
char
*
)
table
->
record
[
0
],
table
->
s
->
reclength
);
DBUG_DUMP
(
"m_after_image"
,
(
const
char
*
)
m_after_image
,
m_master_
reclength
);
DBUG_DUMP
(
"m_after_image"
,
(
const
char
*
)
m_after_image
,
table
->
s
->
reclength
);
#endif
#endif
/*
/*
...
...
sql/sql_binlog.cc
View file @
16b79adf
...
@@ -79,9 +79,15 @@ void mysql_client_binlog_statement(THD* thd)
...
@@ -79,9 +79,15 @@ void mysql_client_binlog_statement(THD* thd)
char
const
*
endptr
=
0
;
char
const
*
endptr
=
0
;
int
bytes_decoded
=
base64_decode
(
strptr
,
coded_len
,
buf
,
&
endptr
);
int
bytes_decoded
=
base64_decode
(
strptr
,
coded_len
,
buf
,
&
endptr
);
#ifndef HAVE_purify
/*
This debug printout should not be used for valgrind builds
since it will read from unassigned memory.
*/
DBUG_PRINT
(
"info"
,
DBUG_PRINT
(
"info"
,
(
"bytes_decoded=%d; strptr=0x%lu; endptr=0x%lu ('%c':%d)"
,
(
"bytes_decoded=%d; strptr=0x%lu; endptr=0x%lu ('%c':%d)"
,
bytes_decoded
,
strptr
,
endptr
,
*
endptr
,
*
endptr
));
bytes_decoded
,
strptr
,
endptr
,
*
endptr
,
*
endptr
));
#endif
if
(
bytes_decoded
<
0
)
if
(
bytes_decoded
<
0
)
{
{
...
@@ -147,8 +153,14 @@ void mysql_client_binlog_statement(THD* thd)
...
@@ -147,8 +153,14 @@ void mysql_client_binlog_statement(THD* thd)
DBUG_PRINT
(
"info"
,(
"ev->get_type_code()=%d"
,
ev
->
get_type_code
()));
DBUG_PRINT
(
"info"
,(
"ev->get_type_code()=%d"
,
ev
->
get_type_code
()));
DBUG_PRINT
(
"info"
,(
"bufptr+EVENT_TYPE_OFFSET=0x%lx"
,
DBUG_PRINT
(
"info"
,(
"bufptr+EVENT_TYPE_OFFSET=0x%lx"
,
bufptr
+
EVENT_TYPE_OFFSET
));
bufptr
+
EVENT_TYPE_OFFSET
));
#ifndef HAVE_purify
/*
This debug printout should not be used for valgrind builds
since it will read from unassigned memory.
*/
DBUG_PRINT
(
"info"
,
(
"bytes_decoded=%d; bufptr=0x%lx; buf[EVENT_LEN_OFFSET]=%u"
,
DBUG_PRINT
(
"info"
,
(
"bytes_decoded=%d; bufptr=0x%lx; buf[EVENT_LEN_OFFSET]=%u"
,
bytes_decoded
,
bufptr
,
uint4korr
(
bufptr
+
EVENT_LEN_OFFSET
)));
bytes_decoded
,
bufptr
,
uint4korr
(
bufptr
+
EVENT_LEN_OFFSET
)));
#endif
ev
->
thd
=
thd
;
ev
->
thd
=
thd
;
if
(
int
err
=
ev
->
exec_event
(
thd
->
rli_fake
))
if
(
int
err
=
ev
->
exec_event
(
thd
->
rli_fake
))
{
{
...
...
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