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
73366eaf
Commit
73366eaf
authored
Sep 03, 2004
by
tomas@poseidon.(none)
Browse files
Options
Browse Files
Download
Plain Diff
Merge tulin@bk-internal.mysql.com:/home/bk/mysql-4.1-ndb
into poseidon.(none):/home/tomas/mysql-4.1-ndb
parents
eff2fa5e
caf79dac
Changes
10
Show whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
97 additions
and
28 deletions
+97
-28
mysql-test/r/ndb_alter_table.result
mysql-test/r/ndb_alter_table.result
+11
-0
mysql-test/t/ndb_alter_table.test
mysql-test/t/ndb_alter_table.test
+17
-0
ndb/src/ndbapi/NdbConnection.cpp
ndb/src/ndbapi/NdbConnection.cpp
+4
-2
sql/ha_ndbcluster.cc
sql/ha_ndbcluster.cc
+51
-18
sql/handler.cc
sql/handler.cc
+4
-3
sql/handler.h
sql/handler.h
+1
-1
sql/sql_class.cc
sql/sql_class.cc
+1
-0
sql/sql_class.h
sql/sql_class.h
+1
-0
sql/sql_delete.cc
sql/sql_delete.cc
+5
-2
sql/sql_table.cc
sql/sql_table.cc
+2
-2
No files found.
mysql-test/r/ndb_alter_table.result
View file @
73366eaf
...
...
@@ -72,3 +72,14 @@ col6 col1 col3 fourth col4 col4_5 col5 col7 col8
1 101 3 4 5 PENDING 0000-00-00 00:00:00
2 102 4 3 5 99 PENDING EXTRA 2004-01-01 00:00:00
drop table t1;
DROP TABLE IF EXISTS t2;
create table t2 (a int NOT NULL PRIMARY KEY) engine=myisam;
alter table t2 engine=ndbcluster;
select count(*) from t2;
count(*)
15001
truncate table t2;
select count(*) from t2;
count(*)
0
drop table t2;
mysql-test/t/ndb_alter_table.test
View file @
73366eaf
...
...
@@ -48,4 +48,21 @@ show table status;
select
*
from
t1
order
by
col1
;
drop
table
t1
;
--
disable_warnings
DROP
TABLE
IF
EXISTS
t2
;
--
enable_warnings
create
table
t2
(
a
int
NOT
NULL
PRIMARY
KEY
)
engine
=
myisam
;
let
$
1
=
15001
;
disable_query_log
;
while
(
$
1
)
{
eval
insert
into
t2
values
(
$
1
);
dec
$
1
;
}
enable_query_log
;
alter
table
t2
engine
=
ndbcluster
;
select
count
(
*
)
from
t2
;
truncate
table
t2
;
select
count
(
*
)
from
t2
;
drop
table
t2
;
ndb/src/ndbapi/NdbConnection.cpp
View file @
73366eaf
...
...
@@ -191,6 +191,7 @@ NdbConnection::setErrorCode(int anErrorCode)
int
NdbConnection
::
restart
(){
DBUG_ENTER
(
"NdbConnection::restart"
);
if
(
theCompletionStatus
==
CompletedSuccess
){
releaseCompletedOperations
();
Uint64
tTransid
=
theNdb
->
theFirstTransId
;
...
...
@@ -201,9 +202,10 @@ NdbConnection::restart(){
theNdb
->
theFirstTransId
=
tTransid
+
1
;
}
theCompletionStatus
=
NotCompleted
;
return
0
;
DBUG_RETURN
(
0
)
;
}
return
-
1
;
DBUG_PRINT
(
"error"
,(
"theCompletionStatus != CompletedSuccess"
));
DBUG_RETURN
(
-
1
);
}
/*****************************************************************************
...
...
sql/ha_ndbcluster.cc
View file @
73366eaf
...
...
@@ -20,7 +20,6 @@
NDB Cluster
*/
#ifdef __GNUC__
#pragma implementation // gcc: Class implementation
#endif
...
...
@@ -1068,8 +1067,17 @@ inline int ha_ndbcluster::next_result(byte *buf)
be sent to NDB
*/
DBUG_PRINT
(
"info"
,
(
"ops_pending: %d"
,
ops_pending
));
if
(
current_thd
->
transaction
.
on
)
{
if
(
ops_pending
&&
(
trans
->
execute
(
NoCommit
)
!=
0
))
DBUG_RETURN
(
ndb_err
(
trans
));
}
else
{
if
(
ops_pending
&&
(
trans
->
execute
(
Commit
)
!=
0
))
DBUG_RETURN
(
ndb_err
(
trans
));
trans
->
restart
();
}
ops_pending
=
0
;
contact_ndb
=
(
check
==
2
);
...
...
@@ -1320,7 +1328,6 @@ int ha_ndbcluster::full_table_scan(byte *buf)
DBUG_RETURN
(
define_read_attrs
(
buf
,
op
));
}
inline
int
ha_ndbcluster
::
define_read_attrs
(
byte
*
buf
,
NdbOperation
*
op
)
{
...
...
@@ -1371,7 +1378,6 @@ int ha_ndbcluster::define_read_attrs(byte* buf, NdbOperation* op)
/*
Insert one record into NDB
*/
int
ha_ndbcluster
::
write_row
(
byte
*
record
)
{
bool
has_auto_increment
;
...
...
@@ -1437,17 +1443,45 @@ int ha_ndbcluster::write_row(byte *record)
((
rows_inserted
%
bulk_insert_rows
)
==
0
)
||
uses_blob_value
(
false
)
!=
0
)
{
THD
*
thd
=
current_thd
;
// Send rows to NDB
DBUG_PRINT
(
"info"
,
(
"Sending inserts to NDB, "
\
"rows_inserted:%d, bulk_insert_rows: %d"
,
(
int
)
rows_inserted
,
(
int
)
bulk_insert_rows
));
bulk_insert_not_flushed
=
false
;
if
(
thd
->
transaction
.
on
)
{
if
(
trans
->
execute
(
NoCommit
)
!=
0
)
{
skip_auto_increment
=
true
;
DBUG_RETURN
(
ndb_err
(
trans
));
}
}
else
{
if
(
trans
->
execute
(
Commit
)
!=
0
)
{
skip_auto_increment
=
true
;
DBUG_RETURN
(
ndb_err
(
trans
));
}
#if 0 // this is what we want to use but it is not functional
trans->restart();
#else
m_ndb
->
closeTransaction
(
m_active_trans
);
m_active_trans
=
m_ndb
->
startTransaction
();
if
(
thd
->
transaction
.
all
.
ndb_tid
)
thd
->
transaction
.
all
.
ndb_tid
=
m_active_trans
;
else
thd
->
transaction
.
stmt
.
ndb_tid
=
m_active_trans
;
if
(
m_active_trans
==
NULL
)
{
skip_auto_increment
=
true
;
ERR_RETURN
(
m_ndb
->
getNdbError
());
}
trans
=
m_active_trans
;
#endif
}
}
if
((
has_auto_increment
)
&&
(
skip_auto_increment
))
{
Uint64
next_val
=
(
Uint64
)
table
->
next_number_field
->
val_int
()
+
1
;
...
...
@@ -2521,10 +2555,7 @@ int ha_ndbcluster::external_lock(THD *thd, int lock_type)
trans
=
m_ndb
->
startTransaction
();
if
(
trans
==
NULL
)
{
thd
->
transaction
.
ndb_lock_count
--
;
// We didn't get the lock
ERR_RETURN
(
m_ndb
->
getNdbError
());
}
thd
->
transaction
.
stmt
.
ndb_tid
=
trans
;
}
else
...
...
@@ -2537,10 +2568,7 @@ int ha_ndbcluster::external_lock(THD *thd, int lock_type)
trans
=
m_ndb
->
startTransaction
();
if
(
trans
==
NULL
)
{
thd
->
transaction
.
ndb_lock_count
--
;
// We didn't get the lock
ERR_RETURN
(
m_ndb
->
getNdbError
());
}
/*
If this is the start of a LOCK TABLE, a table look
...
...
@@ -3155,6 +3183,7 @@ ha_ndbcluster::ha_ndbcluster(TABLE *table_arg):
m_active_trans
(
NULL
),
m_active_cursor
(
NULL
),
m_ndb
(
NULL
),
m_share
(
0
),
m_table
(
NULL
),
m_table_flags
(
HA_REC_NOT_IN_SEQ
|
HA_NULL_IN_KEY
|
...
...
@@ -3204,6 +3233,8 @@ ha_ndbcluster::~ha_ndbcluster()
{
DBUG_ENTER
(
"~ha_ndbcluster"
);
if
(
m_share
)
free_share
(
m_share
);
release_metadata
();
my_free
(
blobs_buffer
,
MYF
(
MY_ALLOW_ZERO_PTR
));
blobs_buffer
=
0
;
...
...
@@ -3246,8 +3277,10 @@ int ha_ndbcluster::open(const char *name, int mode, uint test_if_locked)
set_dbname
(
name
);
set_tabname
(
name
);
if
(
check_ndb_connection
())
if
(
check_ndb_connection
())
{
free_share
(
m_share
);
m_share
=
0
;
DBUG_RETURN
(
HA_ERR_NO_CONNECTION
);
}
DBUG_RETURN
(
get_metadata
(
name
));
}
...
...
@@ -3261,7 +3294,7 @@ int ha_ndbcluster::open(const char *name, int mode, uint test_if_locked)
int
ha_ndbcluster
::
close
(
void
)
{
DBUG_ENTER
(
"close"
);
free_share
(
m_share
);
free_share
(
m_share
);
m_share
=
0
;
release_metadata
();
m_ndb
=
NULL
;
DBUG_RETURN
(
0
);
...
...
sql/handler.cc
View file @
73366eaf
...
...
@@ -1199,14 +1199,15 @@ int handler::rename_table(const char * from, const char * to)
}
/*
Tell the handler to turn on or off
logging to the handler's recovery log
Tell the handler to turn on or off
transaction in the handler
*/
int
ha_
recovery_logging
(
THD
*
thd
,
bool
on
)
int
ha_
enable_transaction
(
THD
*
thd
,
bool
on
)
{
int
error
=
0
;
DBUG_ENTER
(
"ha_recovery_logging"
);
DBUG_ENTER
(
"ha_enable_transaction"
);
thd
->
transaction
.
on
=
on
;
DBUG_RETURN
(
error
);
}
...
...
sql/handler.h
View file @
73366eaf
...
...
@@ -550,7 +550,7 @@ int ha_savepoint(THD *thd, char *savepoint_name);
int
ha_autocommit_or_rollback
(
THD
*
thd
,
int
error
);
void
ha_set_spin_retries
(
uint
retries
);
bool
ha_flush_logs
(
void
);
int
ha_
recovery_logging
(
THD
*
thd
,
bool
on
);
int
ha_
enable_transaction
(
THD
*
thd
,
bool
on
);
int
ha_change_key_cache
(
KEY_CACHE
*
old_key_cache
,
KEY_CACHE
*
new_key_cache
);
int
ha_discover
(
const
char
*
dbname
,
const
char
*
name
,
...
...
sql/sql_class.cc
View file @
73366eaf
...
...
@@ -302,6 +302,7 @@ void THD::init(void)
void
THD
::
init_for_queries
()
{
ha_enable_transaction
(
this
,
TRUE
);
init_sql_alloc
(
&
mem_root
,
variables
.
query_alloc_block_size
,
variables
.
query_prealloc_size
);
...
...
sql/sql_class.h
View file @
73366eaf
...
...
@@ -768,6 +768,7 @@ public:
#ifdef HAVE_NDBCLUSTER_DB
void
*
ndb
;
#endif
bool
on
;
/*
Tables changed in transaction (that must be invalidated in query cache).
List contain only transactional tables, that not invalidated in query
...
...
sql/sql_delete.cc
View file @
73366eaf
...
...
@@ -648,8 +648,11 @@ int mysql_truncate(THD *thd, TABLE_LIST *table_list, bool dont_send_ok)
{
/* Probably InnoDB table */
table_list
->
lock_type
=
TL_WRITE
;
DBUG_RETURN
(
mysql_delete
(
thd
,
table_list
,
(
COND
*
)
0
,
(
SQL_LIST
*
)
0
,
HA_POS_ERROR
,
0
));
ha_enable_transaction
(
thd
,
FALSE
);
error
=
mysql_delete
(
thd
,
table_list
,
(
COND
*
)
0
,
(
SQL_LIST
*
)
0
,
HA_POS_ERROR
,
0
);
ha_enable_transaction
(
thd
,
TRUE
);
DBUG_RETURN
(
error
);
}
if
(
lock_and_wait_for_table_name
(
thd
,
table_list
))
DBUG_RETURN
(
-
1
);
...
...
sql/sql_table.cc
View file @
73366eaf
...
...
@@ -3343,7 +3343,7 @@ copy_data_between_tables(TABLE *from,TABLE *to,
Turn off recovery logging since rollback of an alter table is to
delete the new table so there is no need to log the changes to it.
*/
error
=
ha_
recovery_logging
(
thd
,
FALSE
);
error
=
ha_
enable_transaction
(
thd
,
FALSE
);
if
(
error
)
{
error
=
1
;
...
...
@@ -3405,7 +3405,7 @@ copy_data_between_tables(TABLE *from,TABLE *to,
}
to
->
file
->
extra
(
HA_EXTRA_NO_IGNORE_DUP_KEY
);
ha_
recovery_logging
(
thd
,
TRUE
);
ha_
enable_transaction
(
thd
,
TRUE
);
/*
Ensure that the new table is saved properly to disk so that we
can do a rename
...
...
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