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
32699243
Commit
32699243
authored
Aug 22, 2004
by
serg@serg.mylan
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
check for mysql_bin_log.is_open() before my_b_tell(&thd->transaction.trans_log
in ha_commit_trans - why it didn't crash earlier ?
parent
d0afecff
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
30 additions
and
11 deletions
+30
-11
mysql-test/r/null.result
mysql-test/r/null.result
+19
-0
sql/handler.cc
sql/handler.cc
+11
-11
No files found.
mysql-test/r/null.result
View file @
32699243
...
...
@@ -156,3 +156,22 @@ drop table t1;
select cast(NULL as signed);
cast(NULL as signed)
NULL
create table t1(i int, key(i));
insert into t1 values(1);
insert into t1 select i*2 from t1;
insert into t1 select i*2 from t1;
insert into t1 select i*2 from t1;
insert into t1 select i*2 from t1;
insert into t1 select i*2 from t1;
insert into t1 select i*2 from t1;
insert into t1 select i*2 from t1;
insert into t1 select i*2 from t1;
insert into t1 select i*2 from t1;
explain select * from t1 where i=2 or i is null;
id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE t1 ref_or_null i i 5 const 10 Using where; Using index
alter table t1 change i i int not null;
explain select * from t1 where i=2 or i is null;
id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE t1 ref i i 4 const 7 Using where; Using index
drop table t1;
sql/handler.cc
View file @
32699243
...
...
@@ -472,7 +472,7 @@ int ha_release_temporary_latches(THD *thd)
int
ha_commit_trans
(
THD
*
thd
,
THD_TRANS
*
trans
)
{
int
error
=
0
;
DBUG_ENTER
(
"ha_commit"
);
DBUG_ENTER
(
"ha_commit
_trans
"
);
#ifdef USING_TRANSACTIONS
if
(
opt_using_transactions
)
{
...
...
@@ -480,8 +480,8 @@ int ha_commit_trans(THD *thd, THD_TRANS* trans)
bool
operation_done
=
0
,
need_start_waiters
=
0
;
/* If transaction has done some updates to tables */
if
(
trans
==
&
thd
->
transaction
.
all
&&
my_b_tell
(
&
thd
->
transaction
.
trans_log
))
if
(
trans
==
&
thd
->
transaction
.
all
&&
mysql_bin_log
.
is_open
()
&&
my_b_tell
(
&
thd
->
transaction
.
trans_log
))
{
if
(
error
=
wait_if_global_read_lock
(
thd
,
0
,
0
))
{
...
...
@@ -576,7 +576,7 @@ int ha_commit_trans(THD *thd, THD_TRANS* trans)
int
ha_rollback_trans
(
THD
*
thd
,
THD_TRANS
*
trans
)
{
int
error
=
0
;
DBUG_ENTER
(
"ha_rollback"
);
DBUG_ENTER
(
"ha_rollback
_trans
"
);
#ifdef USING_TRANSACTIONS
if
(
opt_using_transactions
)
{
...
...
@@ -587,7 +587,7 @@ int ha_rollback_trans(THD *thd, THD_TRANS *trans)
if
((
error
=
ndbcluster_rollback
(
thd
,
trans
->
ndb_tid
)))
{
if
(
error
==
-
1
)
my_error
(
ER_ERROR_DURING_ROLLBACK
,
MYF
(
0
));
my_error
(
ER_ERROR_DURING_ROLLBACK
,
MYF
(
0
));
error
=
1
;
}
trans
->
ndb_tid
=
0
;
...
...
@@ -768,12 +768,12 @@ bool ha_flush_logs()
{
bool
result
=
0
;
#ifdef HAVE_BERKELEY_DB
if
((
have_berkeley_db
==
SHOW_OPTION_YES
)
&&
if
((
have_berkeley_db
==
SHOW_OPTION_YES
)
&&
berkeley_flush_logs
())
result
=
1
;
#endif
#ifdef HAVE_INNOBASE_DB
if
((
have_innodb
==
SHOW_OPTION_YES
)
&&
if
((
have_innodb
==
SHOW_OPTION_YES
)
&&
innobase_flush_logs
())
result
=
1
;
#endif
...
...
@@ -868,7 +868,7 @@ my_off_t ha_get_ptr(byte *ptr, uint pack_length)
int
handler
::
ha_open
(
const
char
*
name
,
int
mode
,
int
test_if_locked
)
{
int
error
;
DBUG_ENTER
(
"handler::open"
);
DBUG_ENTER
(
"handler::
ha_
open"
);
DBUG_PRINT
(
"enter"
,(
"name: %s db_type: %d db_stat: %d mode: %d lock_test: %d"
,
name
,
table
->
db_type
,
table
->
db_stat
,
mode
,
test_if_locked
));
...
...
@@ -967,7 +967,7 @@ void handler::update_auto_increment()
{
longlong
nr
;
THD
*
thd
;
DBUG_ENTER
(
"update_auto_increment"
);
DBUG_ENTER
(
"
handler::
update_auto_increment"
);
if
(
table
->
next_number_field
->
val_int
()
!=
0
||
table
->
auto_increment_field_not_null
&&
current_thd
->
variables
.
sql_mode
&
MODE_NO_AUTO_VALUE_ON_ZERO
)
...
...
@@ -1025,7 +1025,7 @@ longlong handler::get_auto_increment()
void
handler
::
print_error
(
int
error
,
myf
errflag
)
{
DBUG_ENTER
(
"print_error"
);
DBUG_ENTER
(
"
handler::
print_error"
);
DBUG_PRINT
(
"enter"
,(
"error: %d"
,
error
));
int
textno
=
ER_GET_ERRNO
;
...
...
@@ -1164,7 +1164,7 @@ bool handler::get_error_message(int error, String* buf)
uint
handler
::
get_dup_key
(
int
error
)
{
DBUG_ENTER
(
"get_dup_key"
);
DBUG_ENTER
(
"
handler::
get_dup_key"
);
table
->
file
->
errkey
=
(
uint
)
-
1
;
if
(
error
==
HA_ERR_FOUND_DUPP_KEY
||
error
==
HA_ERR_FOUND_DUPP_UNIQUE
)
info
(
HA_STATUS_ERRKEY
|
HA_STATUS_NO_LOCK
);
...
...
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