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
abb093fc
Commit
abb093fc
authored
Jul 19, 2004
by
mronstrom@mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge mronstrom@bk-internal.mysql.com:/home/bk/mysql-4.1
into mysql.com:/Users/mikron/mysql-4.1
parents
5eadafe5
03f43020
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
48 additions
and
20 deletions
+48
-20
ndb/test/include/HugoTransactions.hpp
ndb/test/include/HugoTransactions.hpp
+2
-1
ndb/test/ndbapi/testBasic.cpp
ndb/test/ndbapi/testBasic.cpp
+16
-2
ndb/test/src/HugoTransactions.cpp
ndb/test/src/HugoTransactions.cpp
+30
-17
No files found.
ndb/test/include/HugoTransactions.hpp
View file @
abb093fc
...
@@ -34,7 +34,8 @@ public:
...
@@ -34,7 +34,8 @@ public:
int
records
,
int
records
,
int
batch
=
512
,
int
batch
=
512
,
bool
allowConstraintViolation
=
true
,
bool
allowConstraintViolation
=
true
,
int
doSleep
=
0
);
int
doSleep
=
0
,
bool
oneTrans
=
false
);
int
scanReadRecords
(
Ndb
*
,
int
scanReadRecords
(
Ndb
*
,
int
records
,
int
records
,
int
abort
=
0
,
int
abort
=
0
,
...
...
ndb/test/ndbapi/testBasic.cpp
View file @
abb093fc
...
@@ -29,9 +29,18 @@
...
@@ -29,9 +29,18 @@
* delete should be visible to same transaction
* delete should be visible to same transaction
*
*
*/
*/
int
runLoadTable2
(
NDBT_Context
*
ctx
,
NDBT_Step
*
step
)
{
int
records
=
ctx
->
getNumRecords
();
HugoTransactions
hugoTrans
(
*
ctx
->
getTab
());
if
(
hugoTrans
.
loadTable
(
GETNDB
(
step
),
records
,
512
,
false
,
0
,
true
)
!=
0
){
return
NDBT_FAILED
;
}
return
NDBT_OK
;
}
int
runLoadTable
(
NDBT_Context
*
ctx
,
NDBT_Step
*
step
)
{
int
runLoadTable
(
NDBT_Context
*
ctx
,
NDBT_Step
*
step
)
{
int
records
=
ctx
->
getNumRecords
();
int
records
=
ctx
->
getNumRecords
();
HugoTransactions
hugoTrans
(
*
ctx
->
getTab
());
HugoTransactions
hugoTrans
(
*
ctx
->
getTab
());
if
(
hugoTrans
.
loadTable
(
GETNDB
(
step
),
records
)
!=
0
){
if
(
hugoTrans
.
loadTable
(
GETNDB
(
step
),
records
)
!=
0
){
...
@@ -1255,6 +1264,11 @@ TESTCASE("MassiveRollback2",
...
@@ -1255,6 +1264,11 @@ TESTCASE("MassiveRollback2",
INITIALIZER
(
runMassiveRollback2
);
INITIALIZER
(
runMassiveRollback2
);
FINALIZER
(
runClearTable2
);
FINALIZER
(
runClearTable2
);
}
}
TESTCASE
(
"MassiveTransaction"
,
"Test very large insert transaction"
){
INITIALIZER
(
runLoadTable2
);
FINALIZER
(
runClearTable2
);
}
NDBT_TESTSUITE_END
(
testBasic
);
NDBT_TESTSUITE_END
(
testBasic
);
int
main
(
int
argc
,
const
char
**
argv
){
int
main
(
int
argc
,
const
char
**
argv
){
...
...
ndb/test/src/HugoTransactions.cpp
View file @
abb093fc
...
@@ -819,12 +819,14 @@ HugoTransactions::loadTable(Ndb* pNdb,
...
@@ -819,12 +819,14 @@ HugoTransactions::loadTable(Ndb* pNdb,
int
records
,
int
records
,
int
batch
,
int
batch
,
bool
allowConstraintViolation
,
bool
allowConstraintViolation
,
int
doSleep
){
int
doSleep
,
bool
oneTrans
){
int
check
;
int
check
;
int
retryAttempt
=
0
;
int
retryAttempt
=
0
;
int
retryMax
=
5
;
int
retryMax
=
5
;
NdbConnection
*
pTrans
;
NdbConnection
*
pTrans
;
NdbOperation
*
pOp
;
NdbOperation
*
pOp
;
bool
first_batch
=
true
;
const
int
org
=
batch
;
const
int
org
=
batch
;
const
int
cols
=
tab
.
getNoOfColumns
();
const
int
cols
=
tab
.
getNoOfColumns
();
...
@@ -841,7 +843,7 @@ HugoTransactions::loadTable(Ndb* pNdb,
...
@@ -841,7 +843,7 @@ HugoTransactions::loadTable(Ndb* pNdb,
g_info
<<
"|- Inserting records..."
<<
endl
;
g_info
<<
"|- Inserting records..."
<<
endl
;
for
(
int
c
=
0
;
c
<
records
;
){
for
(
int
c
=
0
;
c
<
records
;
){
bool
closeTrans
;
if
(
retryAttempt
>=
retryMax
){
if
(
retryAttempt
>=
retryMax
){
g_info
<<
"Record "
<<
c
<<
" could not be inserted, has retried "
g_info
<<
"Record "
<<
c
<<
" could not be inserted, has retried "
<<
retryAttempt
<<
" times "
<<
endl
;
<<
retryAttempt
<<
" times "
<<
endl
;
...
@@ -852,6 +854,8 @@ HugoTransactions::loadTable(Ndb* pNdb,
...
@@ -852,6 +854,8 @@ HugoTransactions::loadTable(Ndb* pNdb,
if
(
doSleep
>
0
)
if
(
doSleep
>
0
)
NdbSleep_MilliSleep
(
doSleep
);
NdbSleep_MilliSleep
(
doSleep
);
if
(
first_batch
||
!
oneTrans
)
{
first_batch
=
false
;
pTrans
=
pNdb
->
startTransaction
();
pTrans
=
pNdb
->
startTransaction
();
if
(
pTrans
==
NULL
)
{
if
(
pTrans
==
NULL
)
{
...
@@ -866,6 +870,7 @@ HugoTransactions::loadTable(Ndb* pNdb,
...
@@ -866,6 +870,7 @@ HugoTransactions::loadTable(Ndb* pNdb,
ERR
(
err
);
ERR
(
err
);
return
NDBT_FAILED
;
return
NDBT_FAILED
;
}
}
}
for
(
int
b
=
0
;
b
<
batch
&&
c
+
b
<
records
;
b
++
){
for
(
int
b
=
0
;
b
<
batch
&&
c
+
b
<
records
;
b
++
){
...
@@ -894,7 +899,13 @@ HugoTransactions::loadTable(Ndb* pNdb,
...
@@ -894,7 +899,13 @@ HugoTransactions::loadTable(Ndb* pNdb,
}
}
// Execute the transaction and insert the record
// Execute the transaction and insert the record
if
(
!
oneTrans
||
(
c
+
batch
)
>=
records
)
{
closeTrans
=
true
;
check
=
pTrans
->
execute
(
Commit
);
check
=
pTrans
->
execute
(
Commit
);
}
else
{
closeTrans
=
false
;
check
=
pTrans
->
execute
(
NoCommit
);
}
if
(
check
==
-
1
)
{
if
(
check
==
-
1
)
{
const
NdbError
err
=
pTrans
->
getNdbError
();
const
NdbError
err
=
pTrans
->
getNdbError
();
pNdb
->
closeTransaction
(
pTrans
);
pNdb
->
closeTransaction
(
pTrans
);
...
@@ -938,8 +949,10 @@ HugoTransactions::loadTable(Ndb* pNdb,
...
@@ -938,8 +949,10 @@ HugoTransactions::loadTable(Ndb* pNdb,
}
}
}
}
else
{
else
{
if
(
closeTrans
)
{
pNdb
->
closeTransaction
(
pTrans
);
pNdb
->
closeTransaction
(
pTrans
);
}
}
}
// Step to next record
// Step to next record
c
=
c
+
batch
;
c
=
c
+
batch
;
...
...
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