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
cfad8ecc
Commit
cfad8ecc
authored
Sep 06, 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
1cc60149
77cd417c
Changes
8
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
94 additions
and
55 deletions
+94
-55
mysql-test/t/ndb_autodiscover2.test
mysql-test/t/ndb_autodiscover2.test
+1
-0
ndb/src/ndbapi/Ndb.cpp
ndb/src/ndbapi/Ndb.cpp
+42
-26
ndb/src/ndbapi/NdbDictionaryImpl.cpp
ndb/src/ndbapi/NdbDictionaryImpl.cpp
+5
-2
ndb/src/ndbapi/Ndbif.cpp
ndb/src/ndbapi/Ndbif.cpp
+5
-4
ndb/src/ndbapi/Ndbinit.cpp
ndb/src/ndbapi/Ndbinit.cpp
+0
-1
ndb/src/ndbapi/ndb_cluster_connection.cpp
ndb/src/ndbapi/ndb_cluster_connection.cpp
+15
-8
ndb/src/ndbapi/ndberror.c
ndb/src/ndbapi/ndberror.c
+2
-1
sql/ha_ndbcluster.cc
sql/ha_ndbcluster.cc
+24
-13
No files found.
mysql-test/t/ndb_autodiscover2.test
View file @
cfad8ecc
...
@@ -5,6 +5,7 @@
...
@@ -5,6 +5,7 @@
# The previous step has simply removed the frm file
# The previous step has simply removed the frm file
# from disk, but left the table in NDB
# from disk, but left the table in NDB
#
#
--
sleep
3
;
select
*
from
t9
order
by
a
;
select
*
from
t9
order
by
a
;
# handler_discover should be zero
# handler_discover should be zero
...
...
ndb/src/ndbapi/Ndb.cpp
View file @
cfad8ecc
...
@@ -246,6 +246,7 @@ Ndb::waitUntilReady(int timeout)
...
@@ -246,6 +246,7 @@ Ndb::waitUntilReady(int timeout)
int
secondsCounter
=
0
;
int
secondsCounter
=
0
;
int
milliCounter
=
0
;
int
milliCounter
=
0
;
int
noChecksSinceFirstAliveFound
=
0
;
int
noChecksSinceFirstAliveFound
=
0
;
int
id
;
if
(
theInitState
!=
Initialised
)
{
if
(
theInitState
!=
Initialised
)
{
// Ndb::init is not called
// Ndb::init is not called
...
@@ -254,39 +255,48 @@ Ndb::waitUntilReady(int timeout)
...
@@ -254,39 +255,48 @@ Ndb::waitUntilReady(int timeout)
}
}
do
{
do
{
unsigned
int
foundAliveNode
=
0
;
if
((
id
=
theNode
)
!=
0
)
{
TransporterFacade
*
tp
=
TransporterFacade
::
instance
();
unsigned
int
foundAliveNode
=
0
;
tp
->
lock_mutex
();
TransporterFacade
*
tp
=
TransporterFacade
::
instance
();
for
(
unsigned
int
i
=
0
;
i
<
theNoOfDBnodes
;
i
++
)
{
tp
->
lock_mutex
();
const
NodeId
nodeId
=
theDBnodes
[
i
];
for
(
unsigned
int
i
=
0
;
i
<
theNoOfDBnodes
;
i
++
)
{
//************************************************
const
NodeId
nodeId
=
theDBnodes
[
i
];
// If any node is answering, ndb is answering
//************************************************
//************************************************
// If any node is answering, ndb is answering
if
(
tp
->
get_node_alive
(
nodeId
)
!=
0
)
{
//************************************************
foundAliveNode
++
;
if
(
tp
->
get_node_alive
(
nodeId
)
!=
0
)
{
foundAliveNode
++
;
}
//if
}
//for
tp
->
unlock_mutex
();
if
(
foundAliveNode
==
theNoOfDBnodes
)
{
DBUG_RETURN
(
0
);
}
//if
}
//if
}
//for
if
(
foundAliveNode
>
0
)
{
noChecksSinceFirstAliveFound
++
;
tp
->
unlock_mutex
();
}
//if
if
(
foundAliveNode
==
theNoOfDBnodes
)
{
if
(
noChecksSinceFirstAliveFound
>
30
)
{
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
//if
}
//if
if
(
foundAliveNode
>
0
)
{
}
//if theNode != 0
noChecksSinceFirstAliveFound
++
;
if
(
secondsCounter
>=
timeout
)
}
//if
break
;
if
(
noChecksSinceFirstAliveFound
>
30
)
{
DBUG_RETURN
(
0
);
}
//if
NdbSleep_MilliSleep
(
100
);
NdbSleep_MilliSleep
(
100
);
milliCounter
+=
100
;
milliCounter
+=
100
;
if
(
milliCounter
>=
1000
)
{
if
(
milliCounter
>=
1000
)
{
secondsCounter
++
;
secondsCounter
++
;
milliCounter
=
0
;
milliCounter
=
0
;
}
//if
}
//if
}
while
(
secondsCounter
<
timeout
);
}
while
(
1
);
if
(
id
==
0
)
{
theError
.
code
=
4269
;
DBUG_RETURN
(
-
1
);
}
if
(
noChecksSinceFirstAliveFound
>
0
)
{
if
(
noChecksSinceFirstAliveFound
>
0
)
{
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
//if
}
//if
theError
.
code
=
4009
;
DBUG_RETURN
(
-
1
);
DBUG_RETURN
(
-
1
);
}
}
...
@@ -789,8 +799,10 @@ Ndb::readAutoIncrementValue(const char* aTableName)
...
@@ -789,8 +799,10 @@ Ndb::readAutoIncrementValue(const char* aTableName)
{
{
DEBUG_TRACE
(
"readtAutoIncrementValue"
);
DEBUG_TRACE
(
"readtAutoIncrementValue"
);
const
NdbTableImpl
*
table
=
theDictionary
->
getTable
(
aTableName
);
const
NdbTableImpl
*
table
=
theDictionary
->
getTable
(
aTableName
);
if
(
table
==
0
)
if
(
table
==
0
)
{
theError
=
theDictionary
->
getNdbError
();
return
~
0
;
return
~
0
;
}
Uint64
tupleId
=
readTupleIdFromNdb
(
table
->
m_tableId
);
Uint64
tupleId
=
readTupleIdFromNdb
(
table
->
m_tableId
);
return
tupleId
;
return
tupleId
;
}
}
...
@@ -821,8 +833,10 @@ Ndb::setAutoIncrementValue(const char* aTableName, Uint64 val, bool increase)
...
@@ -821,8 +833,10 @@ Ndb::setAutoIncrementValue(const char* aTableName, Uint64 val, bool increase)
{
{
DEBUG_TRACE
(
"setAutoIncrementValue "
<<
val
);
DEBUG_TRACE
(
"setAutoIncrementValue "
<<
val
);
const
NdbTableImpl
*
table
=
theDictionary
->
getTable
(
aTableName
);
const
NdbTableImpl
*
table
=
theDictionary
->
getTable
(
aTableName
);
if
(
table
==
0
)
if
(
table
==
0
)
{
theError
=
theDictionary
->
getNdbError
();
return
false
;
return
false
;
}
return
setTupleIdInNdb
(
table
->
m_tableId
,
val
,
increase
);
return
setTupleIdInNdb
(
table
->
m_tableId
,
val
,
increase
);
}
}
...
@@ -841,8 +855,10 @@ Ndb::setTupleIdInNdb(const char* aTableName, Uint64 val, bool increase )
...
@@ -841,8 +855,10 @@ Ndb::setTupleIdInNdb(const char* aTableName, Uint64 val, bool increase )
{
{
DEBUG_TRACE
(
"setTupleIdInNdb"
);
DEBUG_TRACE
(
"setTupleIdInNdb"
);
const
NdbTableImpl
*
table
=
theDictionary
->
getTable
(
aTableName
);
const
NdbTableImpl
*
table
=
theDictionary
->
getTable
(
aTableName
);
if
(
table
==
0
)
if
(
table
==
0
)
{
theError
=
theDictionary
->
getNdbError
();
return
false
;
return
false
;
}
return
setTupleIdInNdb
(
table
->
m_tableId
,
val
,
increase
);
return
setTupleIdInNdb
(
table
->
m_tableId
,
val
,
increase
);
}
}
...
...
ndb/src/ndbapi/NdbDictionaryImpl.cpp
View file @
cfad8ecc
...
@@ -1500,8 +1500,11 @@ NdbDictInterface::createOrAlterTable(Ndb & ndb,
...
@@ -1500,8 +1500,11 @@ NdbDictInterface::createOrAlterTable(Ndb & ndb,
if
(
!
alter
&&
haveAutoIncrement
)
{
if
(
!
alter
&&
haveAutoIncrement
)
{
// if (!ndb.setAutoIncrementValue(impl.m_internalName.c_str(), autoIncrementValue)) {
// if (!ndb.setAutoIncrementValue(impl.m_internalName.c_str(), autoIncrementValue)) {
if
(
!
ndb
.
setAutoIncrementValue
(
impl
.
m_externalName
.
c_str
(),
autoIncrementValue
))
{
if
(
!
ndb
.
setAutoIncrementValue
(
impl
.
m_externalName
.
c_str
(),
autoIncrementValue
))
{
m_error
.
code
=
4336
;
if
(
ndb
.
theError
.
code
==
0
)
{
ndb
.
theError
=
m_error
;
m_error
.
code
=
4336
;
ndb
.
theError
=
m_error
;
}
else
m_error
=
ndb
.
theError
;
ret
=
-
1
;
// errorcode set in initialize_autoincrement
ret
=
-
1
;
// errorcode set in initialize_autoincrement
}
}
}
}
...
...
ndb/src/ndbapi/Ndbif.cpp
View file @
cfad8ecc
...
@@ -185,10 +185,10 @@ Ndb::executeMessage(void* NdbObject,
...
@@ -185,10 +185,10 @@ Ndb::executeMessage(void* NdbObject,
void
Ndb
::
connected
(
Uint32
ref
)
void
Ndb
::
connected
(
Uint32
ref
)
{
{
theMyRef
=
ref
;
theMyRef
=
ref
;
t
heNode
=
refToNode
(
ref
);
Uint32
tmpT
heNode
=
refToNode
(
ref
);
Uint64
tBlockNo
=
refToBlock
(
ref
);
Uint64
tBlockNo
=
refToBlock
(
ref
);
if
(
theNdbBlockNumber
>=
0
){
if
(
theNdbBlockNumber
>=
0
){
assert
(
theMyRef
==
numberToRef
(
theNdbBlockNumber
,
theNode
));
assert
(
theMyRef
==
numberToRef
(
theNdbBlockNumber
,
t
mpT
heNode
));
}
}
TransporterFacade
*
theFacade
=
TransporterFacade
::
instance
();
TransporterFacade
*
theFacade
=
TransporterFacade
::
instance
();
...
@@ -201,18 +201,19 @@ void Ndb::connected(Uint32 ref)
...
@@ -201,18 +201,19 @@ void Ndb::connected(Uint32 ref)
}
}
}
}
theFirstTransId
=
((
Uint64
)
tBlockNo
<<
52
)
+
theFirstTransId
=
((
Uint64
)
tBlockNo
<<
52
)
+
((
Uint64
)
theNode
<<
40
);
((
Uint64
)
t
mpT
heNode
<<
40
);
theFirstTransId
+=
theFacade
->
m_max_trans_id
;
theFirstTransId
+=
theFacade
->
m_max_trans_id
;
// assert(0);
// assert(0);
DBUG_PRINT
(
"info"
,(
"connected with ref=%x, id=%d, no_db_nodes=%d, first_trans_id=%lx"
,
DBUG_PRINT
(
"info"
,(
"connected with ref=%x, id=%d, no_db_nodes=%d, first_trans_id=%lx"
,
theMyRef
,
theMyRef
,
theNode
,
t
mpT
heNode
,
theNoOfDBnodes
,
theNoOfDBnodes
,
theFirstTransId
));
theFirstTransId
));
startTransactionNodeSelectionData
.
init
(
theNoOfDBnodes
,
theDBnodes
);
startTransactionNodeSelectionData
.
init
(
theNoOfDBnodes
,
theDBnodes
);
theCommitAckSignal
=
new
NdbApiSignal
(
theMyRef
);
theCommitAckSignal
=
new
NdbApiSignal
(
theMyRef
);
theDictionary
->
m_receiver
.
m_reference
=
theMyRef
;
theDictionary
->
m_receiver
.
m_reference
=
theMyRef
;
theNode
=
tmpTheNode
;
// flag that Ndb object is initialized
}
}
void
void
...
...
ndb/src/ndbapi/Ndbinit.cpp
View file @
cfad8ecc
...
@@ -125,7 +125,6 @@ void Ndb::setup(Ndb_cluster_connection *ndb_cluster_connection,
...
@@ -125,7 +125,6 @@ void Ndb::setup(Ndb_cluster_connection *ndb_cluster_connection,
theNode
=
0
;
theNode
=
0
;
theFirstTransId
=
0
;
theFirstTransId
=
0
;
theMyRef
=
0
;
theMyRef
=
0
;
theNoOfDBnodes
=
0
;
fullyQualifiedNames
=
true
;
fullyQualifiedNames
=
true
;
...
...
ndb/src/ndbapi/ndb_cluster_connection.cpp
View file @
cfad8ecc
...
@@ -54,14 +54,15 @@ void Ndb_cluster_connection::connect_thread()
...
@@ -54,14 +54,15 @@ void Ndb_cluster_connection::connect_thread()
{
{
DBUG_ENTER
(
"Ndb_cluster_connection::connect_thread"
);
DBUG_ENTER
(
"Ndb_cluster_connection::connect_thread"
);
int
r
;
int
r
;
while
(
g_run_connect_thread
)
{
do
{
if
((
r
=
connect
(
1
))
==
0
)
if
((
r
=
connect
(
1
))
==
0
)
break
;
break
;
if
(
r
==
-
1
)
{
if
(
r
==
-
1
)
{
printf
(
"Ndb_cluster_connection::connect_thread error
\n
"
);
printf
(
"Ndb_cluster_connection::connect_thread error
\n
"
);
abort
();
DBUG_ASSERT
(
false
);
g_run_connect_thread
=
0
;
}
}
}
}
while
(
g_run_connect_thread
);
if
(
m_connect_callback
)
if
(
m_connect_callback
)
(
*
m_connect_callback
)();
(
*
m_connect_callback
)();
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
...
@@ -69,13 +70,19 @@ void Ndb_cluster_connection::connect_thread()
...
@@ -69,13 +70,19 @@ void Ndb_cluster_connection::connect_thread()
int
Ndb_cluster_connection
::
start_connect_thread
(
int
(
*
connect_callback
)(
void
))
int
Ndb_cluster_connection
::
start_connect_thread
(
int
(
*
connect_callback
)(
void
))
{
{
int
r
;
DBUG_ENTER
(
"Ndb_cluster_connection::start_connect_thread"
);
DBUG_ENTER
(
"Ndb_cluster_connection::start_connect_thread"
);
m_connect_callback
=
connect_callback
;
m_connect_callback
=
connect_callback
;
m_connect_thread
=
NdbThread_Create
(
run_ndb_cluster_connection_connect_thread
,
if
((
r
=
connect
(
1
))
==
1
)
(
void
**
)
this
,
m_connect_thread
=
NdbThread_Create
(
run_ndb_cluster_connection_connect_thread
,
32768
,
(
void
**
)
this
,
"ndb_cluster_connection"
,
32768
,
NDB_THREAD_PRIO_LOW
);
"ndb_cluster_connection"
,
NDB_THREAD_PRIO_LOW
);
else
if
(
r
<
0
)
DBUG_RETURN
(
-
1
)
else
if
(
m_connect_callback
)
(
*
m_connect_callback
)();
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
}
...
...
ndb/src/ndbapi/ndberror.c
View file @
cfad8ecc
...
@@ -424,7 +424,8 @@ ErrorBundle ErrorCodes[] = {
...
@@ -424,7 +424,8 @@ ErrorBundle ErrorCodes[] = {
{
4266
,
AE
,
"Invalid blob seek position"
},
{
4266
,
AE
,
"Invalid blob seek position"
},
{
4267
,
IE
,
"Corrupted blob value"
},
{
4267
,
IE
,
"Corrupted blob value"
},
{
4268
,
IE
,
"Error in blob head update forced rollback of transaction"
},
{
4268
,
IE
,
"Error in blob head update forced rollback of transaction"
},
{
4268
,
IE
,
"Unknown blob error"
}
{
4268
,
IE
,
"Unknown blob error"
},
{
4269
,
IE
,
"No connection to ndb management server"
}
};
};
static
static
...
...
sql/ha_ndbcluster.cc
View file @
cfad8ecc
...
@@ -69,6 +69,7 @@ typedef NdbDictionary::Dictionary NDBDICT;
...
@@ -69,6 +69,7 @@ typedef NdbDictionary::Dictionary NDBDICT;
bool
ndbcluster_inited
=
false
;
bool
ndbcluster_inited
=
false
;
static
Ndb
*
g_ndb
=
NULL
;
static
Ndb
*
g_ndb
=
NULL
;
static
Ndb_cluster_connection
*
g_ndb_cluster_connection
=
NULL
;
// Handler synchronization
// Handler synchronization
pthread_mutex_t
ndbcluster_mutex
;
pthread_mutex_t
ndbcluster_mutex
;
...
@@ -3183,12 +3184,12 @@ ha_ndbcluster::ha_ndbcluster(TABLE *table_arg):
...
@@ -3183,12 +3184,12 @@ ha_ndbcluster::ha_ndbcluster(TABLE *table_arg):
m_active_trans
(
NULL
),
m_active_trans
(
NULL
),
m_active_cursor
(
NULL
),
m_active_cursor
(
NULL
),
m_ndb
(
NULL
),
m_ndb
(
NULL
),
m_share
(
0
),
m_table
(
NULL
),
m_table
(
NULL
),
m_table_flags
(
HA_REC_NOT_IN_SEQ
|
m_table_flags
(
HA_REC_NOT_IN_SEQ
|
HA_NULL_IN_KEY
|
HA_NULL_IN_KEY
|
HA_NOT_EXACT_COUNT
|
HA_NOT_EXACT_COUNT
|
HA_NO_PREFIX_CHAR_KEYS
),
HA_NO_PREFIX_CHAR_KEYS
),
m_share
(
0
),
m_use_write
(
false
),
m_use_write
(
false
),
retrieve_all_fields
(
FALSE
),
retrieve_all_fields
(
FALSE
),
rows_to_insert
(
1
),
rows_to_insert
(
1
),
...
@@ -3196,8 +3197,8 @@ ha_ndbcluster::ha_ndbcluster(TABLE *table_arg):
...
@@ -3196,8 +3197,8 @@ ha_ndbcluster::ha_ndbcluster(TABLE *table_arg):
bulk_insert_rows
(
1024
),
bulk_insert_rows
(
1024
),
bulk_insert_not_flushed
(
false
),
bulk_insert_not_flushed
(
false
),
ops_pending
(
0
),
ops_pending
(
0
),
blobs_pending
(
0
),
skip_auto_increment
(
true
),
skip_auto_increment
(
true
),
blobs_pending
(
0
),
blobs_buffer
(
0
),
blobs_buffer
(
0
),
blobs_buffer_size
(
0
),
blobs_buffer_size
(
0
),
dupkey
((
uint
)
-
1
)
dupkey
((
uint
)
-
1
)
...
@@ -3311,7 +3312,7 @@ Ndb* ha_ndbcluster::seize_ndb()
...
@@ -3311,7 +3312,7 @@ Ndb* ha_ndbcluster::seize_ndb()
// Seize from pool
// Seize from pool
ndb
=
Ndb
::
seize
();
ndb
=
Ndb
::
seize
();
#else
#else
ndb
=
new
Ndb
(
""
);
ndb
=
new
Ndb
(
g_ndb_cluster_connection
,
""
);
#endif
#endif
if
(
ndb
->
init
(
max_transactions
)
!=
0
)
if
(
ndb
->
init
(
max_transactions
)
!=
0
)
{
{
...
@@ -3395,8 +3396,12 @@ int ndbcluster_discover(const char *dbname, const char *name,
...
@@ -3395,8 +3396,12 @@ int ndbcluster_discover(const char *dbname, const char *name,
DBUG_ENTER
(
"ndbcluster_discover"
);
DBUG_ENTER
(
"ndbcluster_discover"
);
DBUG_PRINT
(
"enter"
,
(
"db: %s, name: %s"
,
dbname
,
name
));
DBUG_PRINT
(
"enter"
,
(
"db: %s, name: %s"
,
dbname
,
name
));
Ndb
ndb
(
dbname
);
Ndb
ndb
(
g_ndb_cluster_connection
,
dbname
);
if
((
ndb
.
init
()
!=
0
)
&&
(
ndb
.
waitUntilReady
()
!=
0
))
if
(
ndb
.
init
())
ERR_RETURN
(
ndb
.
getNdbError
());
if
(
ndb
.
waitUntilReady
(
0
))
ERR_RETURN
(
ndb
.
getNdbError
());
ERR_RETURN
(
ndb
.
getNdbError
());
if
(
!
(
tab
=
ndb
.
getDictionary
()
->
getTable
(
name
)))
if
(
!
(
tab
=
ndb
.
getDictionary
()
->
getTable
(
name
)))
...
@@ -3471,21 +3476,24 @@ bool ndbcluster_init()
...
@@ -3471,21 +3476,24 @@ bool ndbcluster_init()
DBUG_ENTER
(
"ndbcluster_init"
);
DBUG_ENTER
(
"ndbcluster_init"
);
// Set connectstring if specified
// Set connectstring if specified
if
(
ndbcluster_connectstring
!=
0
)
if
(
ndbcluster_connectstring
!=
0
)
{
DBUG_PRINT
(
"connectstring"
,
(
"%s"
,
ndbcluster_connectstring
));
DBUG_PRINT
(
"connectstring"
,
(
"%s"
,
ndbcluster_connectstring
));
Ndb
::
setConnectString
(
ndbcluster_connectstring
);
if
((
g_ndb_cluster_connection
=
new
Ndb_cluster_connection
(
ndbcluster_connectstring
))
==
0
)
{
DBUG_PRINT
(
"error"
,(
"Ndb_cluster_connection(%s)"
,
ndbcluster_connectstring
));
DBUG_RETURN
(
TRUE
);
}
}
// Create a Ndb object to open the connection to NDB
if
(
g_ndb_cluster_connection
->
start_connect_thread
())
g_ndb
=
new
Ndb
(
"sys"
);
if
(
g_ndb
->
init
()
!=
0
)
{
{
ERR_PRINT
(
g_ndb
->
getNdbError
(
));
DBUG_PRINT
(
"error"
,
(
"g_ndb_cluster_connection->start_connect_thread()"
));
DBUG_RETURN
(
TRUE
);
DBUG_RETURN
(
TRUE
);
}
}
if
(
g_ndb
->
waitUntilReady
()
!=
0
)
// Create a Ndb object to open the connection to NDB
g_ndb
=
new
Ndb
(
g_ndb_cluster_connection
,
"sys"
);
if
(
g_ndb
->
init
()
!=
0
)
{
{
ERR_PRINT
(
g_ndb
->
getNdbError
());
ERR_PRINT
(
g_ndb
->
getNdbError
());
DBUG_RETURN
(
TRUE
);
DBUG_RETURN
(
TRUE
);
}
}
(
void
)
hash_init
(
&
ndbcluster_open_tables
,
system_charset_info
,
32
,
0
,
0
,
(
void
)
hash_init
(
&
ndbcluster_open_tables
,
system_charset_info
,
32
,
0
,
0
,
(
hash_get_key
)
ndbcluster_get_key
,
0
,
0
);
(
hash_get_key
)
ndbcluster_get_key
,
0
,
0
);
...
@@ -3511,6 +3519,9 @@ bool ndbcluster_end()
...
@@ -3511,6 +3519,9 @@ bool ndbcluster_end()
delete
g_ndb
;
delete
g_ndb
;
g_ndb
=
NULL
;
g_ndb
=
NULL
;
if
(
g_ndb_cluster_connection
)
delete
g_ndb_cluster_connection
;
g_ndb_cluster_connection
=
NULL
;
if
(
!
ndbcluster_inited
)
if
(
!
ndbcluster_inited
)
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
hash_free
(
&
ndbcluster_open_tables
);
hash_free
(
&
ndbcluster_open_tables
);
...
...
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