transactd 1.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (218) hide show
  1. checksums.yaml +7 -0
  2. data/BUILD_UNIX-JA +174 -0
  3. data/BUILD_WIN-JA +256 -0
  4. data/CMakeLists.txt +96 -0
  5. data/COPYING +339 -0
  6. data/README +406 -0
  7. data/README-JA +424 -0
  8. data/bin/common/tdclc_32_1_0.dll +0 -0
  9. data/bin/common/tdclc_64_1_0.dll +0 -0
  10. data/build/common/check_for_link_iconv.cmake +73 -0
  11. data/build/common/copyifgreater.cmd +30 -0
  12. data/build/common/copyifgreater.js +290 -0
  13. data/build/common/get_boost_libs.cmake +106 -0
  14. data/build/common/get_ruby_path.cmake +115 -0
  15. data/build/common/options.cmake +127 -0
  16. data/build/common/smart_install.cmake +263 -0
  17. data/build/common/system.cmake +122 -0
  18. data/build/common/transactd.rc.in +52 -0
  19. data/build/common/transactd_cl_common.cmake +101 -0
  20. data/build/common/transactd_cl_output.cmake +93 -0
  21. data/build/common/transactd_common.cmake +237 -0
  22. data/build/common/transactd_required.cmake +28 -0
  23. data/build/swig/ruby/generate.cmake.in +35 -0
  24. data/build/swig/ruby/generate.cmd.in +19 -0
  25. data/build/swig/ruby/ruby.swg +101 -0
  26. data/build/swig/tdcl.i +188 -0
  27. data/build/tdclc/BUILDNUMBER.txt +1 -0
  28. data/build/tdclc/CMakeLists.txt +170 -0
  29. data/build/tdclc/tdclc_32.cbproj +181 -0
  30. data/build/tdclc/tdclc_64.cbproj +205 -0
  31. data/build/tdclcpp/BUILDNUMBER.txt +1 -0
  32. data/build/tdclcpp/CMakeLists.txt +142 -0
  33. data/build/tdclcpp/tdclcpp_bcb_32.cbproj +239 -0
  34. data/build/tdclcpp/tdclcpp_bcb_64.cbproj +304 -0
  35. data/build/tdclrb/BUILDNUMBER.txt +1 -0
  36. data/build/tdclrb/CMakeLists.txt +258 -0
  37. data/build/tdclrb/GEM_VERSION +3 -0
  38. data/build/tdclrb/bldgem/extconf.rb +123 -0
  39. data/build/tdclrb/gem/INSTALLLOG.win32 +9 -0
  40. data/build/tdclrb/gem/Makefile.win32-VS +65 -0
  41. data/build/tdclrb/gem/Makefile.win32-prebuilt +48 -0
  42. data/build/tdclrb/gem/detect.rb +31 -0
  43. data/build/tdclrb/gem/helper.rb +113 -0
  44. data/build/tdclrb/gem/transactd.rb +22 -0
  45. data/build/tdclrb/gem_output.cmake +44 -0
  46. data/source/bzs/db/IBlobBuffer.h +51 -0
  47. data/source/bzs/db/blobBuffer.h +177 -0
  48. data/source/bzs/db/blobStructs.h +85 -0
  49. data/source/bzs/db/engine/mysql/IReadRecords.h +52 -0
  50. data/source/bzs/db/engine/mysql/bookmark.h +195 -0
  51. data/source/bzs/db/engine/mysql/database.cpp +1882 -0
  52. data/source/bzs/db/engine/mysql/database.h +465 -0
  53. data/source/bzs/db/engine/mysql/dbManager.cpp +303 -0
  54. data/source/bzs/db/engine/mysql/dbManager.h +143 -0
  55. data/source/bzs/db/engine/mysql/errorMessage.cpp +75 -0
  56. data/source/bzs/db/engine/mysql/errorMessage.h +43 -0
  57. data/source/bzs/db/engine/mysql/fieldAccess.h +158 -0
  58. data/source/bzs/db/engine/mysql/mydebuglog.cpp +349 -0
  59. data/source/bzs/db/engine/mysql/mydebuglog.h +89 -0
  60. data/source/bzs/db/engine/mysql/mysqlInternal.h +171 -0
  61. data/source/bzs/db/engine/mysql/mysqlThd.cpp +169 -0
  62. data/source/bzs/db/engine/mysql/mysqlThd.h +35 -0
  63. data/source/bzs/db/engine/mysql/percentageKey.h +260 -0
  64. data/source/bzs/db/protocol/ICommandExecuter.h +49 -0
  65. data/source/bzs/db/protocol/hs/hsCommandExecuter.cpp +689 -0
  66. data/source/bzs/db/protocol/hs/hsCommandExecuter.h +228 -0
  67. data/source/bzs/db/protocol/tdap/btrDate.cpp +437 -0
  68. data/source/bzs/db/protocol/tdap/btrDate.h +227 -0
  69. data/source/bzs/db/protocol/tdap/client/bulkInsert.h +127 -0
  70. data/source/bzs/db/protocol/tdap/client/client.cpp +106 -0
  71. data/source/bzs/db/protocol/tdap/client/client.h +292 -0
  72. data/source/bzs/db/protocol/tdap/client/connMgr.cpp +144 -0
  73. data/source/bzs/db/protocol/tdap/client/connMgr.h +82 -0
  74. data/source/bzs/db/protocol/tdap/client/database.cpp +863 -0
  75. data/source/bzs/db/protocol/tdap/client/database.h +118 -0
  76. data/source/bzs/db/protocol/tdap/client/databaseFactory.cpp +100 -0
  77. data/source/bzs/db/protocol/tdap/client/dbDef.cpp +1640 -0
  78. data/source/bzs/db/protocol/tdap/client/dbDef.h +135 -0
  79. data/source/bzs/db/protocol/tdap/client/dllmain.cpp +434 -0
  80. data/source/bzs/db/protocol/tdap/client/errorMessage.cpp +92 -0
  81. data/source/bzs/db/protocol/tdap/client/errorMessage_ja.cpp +98 -0
  82. data/source/bzs/db/protocol/tdap/client/fieldDDF.cpp +174 -0
  83. data/source/bzs/db/protocol/tdap/client/fieldDDF.h +91 -0
  84. data/source/bzs/db/protocol/tdap/client/fileDDF.cpp +140 -0
  85. data/source/bzs/db/protocol/tdap/client/fileDDF.h +86 -0
  86. data/source/bzs/db/protocol/tdap/client/filter.cpp +527 -0
  87. data/source/bzs/db/protocol/tdap/client/filter.h +154 -0
  88. data/source/bzs/db/protocol/tdap/client/indexDDF.cpp +137 -0
  89. data/source/bzs/db/protocol/tdap/client/indexDDF.h +84 -0
  90. data/source/bzs/db/protocol/tdap/client/nsDatabase.cpp +724 -0
  91. data/source/bzs/db/protocol/tdap/client/nsDatabase.h +123 -0
  92. data/source/bzs/db/protocol/tdap/client/nsTable.cpp +899 -0
  93. data/source/bzs/db/protocol/tdap/client/nsTable.h +199 -0
  94. data/source/bzs/db/protocol/tdap/client/request.h +198 -0
  95. data/source/bzs/db/protocol/tdap/client/sharedData.cpp +58 -0
  96. data/source/bzs/db/protocol/tdap/client/sharedData.h +56 -0
  97. data/source/bzs/db/protocol/tdap/client/sqlBuilder.cpp +574 -0
  98. data/source/bzs/db/protocol/tdap/client/sqlBuilder.h +53 -0
  99. data/source/bzs/db/protocol/tdap/client/stringConverter.h +627 -0
  100. data/source/bzs/db/protocol/tdap/client/table.cpp +2613 -0
  101. data/source/bzs/db/protocol/tdap/client/table.h +221 -0
  102. data/source/bzs/db/protocol/tdap/client/trdboostapi.h +1096 -0
  103. data/source/bzs/db/protocol/tdap/client/trdboostapiInternal.h +179 -0
  104. data/source/bzs/db/protocol/tdap/client/trdclcppautolink.h +40 -0
  105. data/source/bzs/db/protocol/tdap/client/trnsctcl.def +11 -0
  106. data/source/bzs/db/protocol/tdap/myDateTime.cpp +500 -0
  107. data/source/bzs/db/protocol/tdap/mysql/characterset.cpp +184 -0
  108. data/source/bzs/db/protocol/tdap/mysql/characterset.h +60 -0
  109. data/source/bzs/db/protocol/tdap/mysql/databaseSchema.cpp +284 -0
  110. data/source/bzs/db/protocol/tdap/mysql/databaseSchema.h +53 -0
  111. data/source/bzs/db/protocol/tdap/mysql/debuglog.cpp +383 -0
  112. data/source/bzs/db/protocol/tdap/mysql/debuglog.h +106 -0
  113. data/source/bzs/db/protocol/tdap/mysql/recordsetReader.h +680 -0
  114. data/source/bzs/db/protocol/tdap/mysql/request.h +202 -0
  115. data/source/bzs/db/protocol/tdap/mysql/tdapCommandExecuter.cpp +1020 -0
  116. data/source/bzs/db/protocol/tdap/mysql/tdapCommandExecuter.h +141 -0
  117. data/source/bzs/db/protocol/tdap/tdapRequest.h +190 -0
  118. data/source/bzs/db/protocol/tdap/tdapSchema.cpp +295 -0
  119. data/source/bzs/db/protocol/tdap/tdapSchema.h +558 -0
  120. data/source/bzs/db/protocol/tdap/tdapcapi.h +423 -0
  121. data/source/bzs/db/transactd/appBuilderImple.h +55 -0
  122. data/source/bzs/db/transactd/appModule.cpp +183 -0
  123. data/source/bzs/db/transactd/appModule.h +80 -0
  124. data/source/bzs/db/transactd/connManager.cpp +201 -0
  125. data/source/bzs/db/transactd/connManager.h +60 -0
  126. data/source/bzs/db/transactd/connectionRecord.h +69 -0
  127. data/source/bzs/db/transactd/transactd.cpp +325 -0
  128. data/source/bzs/env/compiler.h +135 -0
  129. data/source/bzs/env/crosscompile.cpp +130 -0
  130. data/source/bzs/env/crosscompile.h +150 -0
  131. data/source/bzs/env/fileopen.h +36 -0
  132. data/source/bzs/env/mbcswchrLinux.cpp +40 -0
  133. data/source/bzs/env/mbcswchrLinux.h +88 -0
  134. data/source/bzs/env/tstring.h +183 -0
  135. data/source/bzs/example/changeSchema.cpp +117 -0
  136. data/source/bzs/example/changeSchema_c.cpp +78 -0
  137. data/source/bzs/example/connection_pool_c.cpp +171 -0
  138. data/source/bzs/example/createDatabase.cpp +305 -0
  139. data/source/bzs/example/createDatabase_c.cpp +202 -0
  140. data/source/bzs/example/deleteRecords.cpp +87 -0
  141. data/source/bzs/example/deleteRecords_c.cpp +57 -0
  142. data/source/bzs/example/dropDatabase.cpp +59 -0
  143. data/source/bzs/example/dropDatabase_c.cpp +34 -0
  144. data/source/bzs/example/insertRecords.cpp +212 -0
  145. data/source/bzs/example/insertRecords_c.cpp +153 -0
  146. data/source/bzs/example/readRecords.cpp +141 -0
  147. data/source/bzs/example/readRecords_c.cpp +107 -0
  148. data/source/bzs/example/updateRecords.cpp +99 -0
  149. data/source/bzs/example/updateRecords_c.cpp +71 -0
  150. data/source/bzs/example/update_with_transaction.cpp +104 -0
  151. data/source/bzs/example/update_with_transaction_c.cpp +80 -0
  152. data/source/bzs/netsvc/client/tcpClient.cpp +226 -0
  153. data/source/bzs/netsvc/client/tcpClient.h +489 -0
  154. data/source/bzs/netsvc/server/IAppModule.h +94 -0
  155. data/source/bzs/netsvc/server/iserver.h +65 -0
  156. data/source/bzs/netsvc/server/serverCpt.cpp +522 -0
  157. data/source/bzs/netsvc/server/serverCpt.h +88 -0
  158. data/source/bzs/netsvc/server/serverPipe.cpp +705 -0
  159. data/source/bzs/netsvc/server/serverPipe.h +96 -0
  160. data/source/bzs/netsvc/server/serverTpool.cpp +416 -0
  161. data/source/bzs/netsvc/server/serverTpool.h +84 -0
  162. data/source/bzs/rtl/benchmark.cpp +96 -0
  163. data/source/bzs/rtl/benchmark.h +65 -0
  164. data/source/bzs/rtl/datetime.cpp +375 -0
  165. data/source/bzs/rtl/datetime.h +53 -0
  166. data/source/bzs/rtl/debuglog.cpp +106 -0
  167. data/source/bzs/rtl/debuglog.h +97 -0
  168. data/source/bzs/rtl/exception.h +116 -0
  169. data/source/bzs/rtl/stl_uty.cpp +35 -0
  170. data/source/bzs/rtl/stl_uty.h +29 -0
  171. data/source/bzs/rtl/stringBuffers.cpp +101 -0
  172. data/source/bzs/rtl/stringBuffers.h +58 -0
  173. data/source/bzs/rtl/strtrim.cpp +135 -0
  174. data/source/bzs/rtl/strtrim.h +46 -0
  175. data/source/bzs/test/tdclatl/bench_tdclatl.js +445 -0
  176. data/source/bzs/test/tdclrb/bench_tdclcpp.rb +375 -0
  177. data/source/bzs/test/tdclrb/prepare.rb +226 -0
  178. data/source/bzs/test/tdclrb/transactd_datetime_spec.rb +172 -0
  179. data/source/bzs/test/tdclrb/transactd_kanjischema_spec.rb +208 -0
  180. data/source/bzs/test/tdclrb/transactd_spec.rb +1536 -0
  181. data/source/bzs/test/transactdBench/transactdBench.cpp +430 -0
  182. data/source/bzs/test/transactdBench/transactdBench2.cpp +342 -0
  183. data/source/bzs/test/trdclengn/test_trdclengn.cpp +2030 -0
  184. data/source/global/tdclatl/Database.cpp +503 -0
  185. data/source/global/tdclatl/Database.h +139 -0
  186. data/source/global/tdclatl/DbDef.cpp +242 -0
  187. data/source/global/tdclatl/DbDef.h +79 -0
  188. data/source/global/tdclatl/Field.cpp +92 -0
  189. data/source/global/tdclatl/Field.h +59 -0
  190. data/source/global/tdclatl/FieldDef.cpp +238 -0
  191. data/source/global/tdclatl/FieldDef.h +87 -0
  192. data/source/global/tdclatl/Flags.cpp +111 -0
  193. data/source/global/tdclatl/Flags.h +55 -0
  194. data/source/global/tdclatl/KeyDef.cpp +51 -0
  195. data/source/global/tdclatl/KeyDef.h +55 -0
  196. data/source/global/tdclatl/KeySegment.cpp +55 -0
  197. data/source/global/tdclatl/Table.cpp +600 -0
  198. data/source/global/tdclatl/Table.h +144 -0
  199. data/source/global/tdclatl/TableDef.cpp +291 -0
  200. data/source/global/tdclatl/TableDef.h +86 -0
  201. data/source/global/tdclatl/TdVersion.cpp +74 -0
  202. data/source/global/tdclatl/TdVersion.h +54 -0
  203. data/source/global/tdclatl/_IDatabaseEvents_CP.h +113 -0
  204. data/source/global/tdclatl/dllmain.cpp +30 -0
  205. data/source/global/tdclatl/dllmain.h +27 -0
  206. data/source/global/tdclatl/keySegment.h +57 -0
  207. data/source/global/tdclatl/resource.h +0 -0
  208. data/source/global/tdclatl/stdafx.cpp +2 -0
  209. data/source/global/tdclatl/stdafx.h +25 -0
  210. data/source/global/tdclatl/targetver.h +4 -0
  211. data/source/global/tdclatl/tdclatl.cpp +68 -0
  212. data/source/global/tdclatl/tdclatl.def +10 -0
  213. data/source/global/tdclatl/tdclatl.idl +1035 -0
  214. data/source/linux/charsetConvert.h +112 -0
  215. data/source/linux/linuxTypes.h +33 -0
  216. data/source/linux/tchar.h +428 -0
  217. data/transactd.gemspec +97 -0
  218. metadata +267 -0
@@ -0,0 +1,445 @@
1
+ /*=================================================================
2
+ Copyright (C) 2013 BizStation Corp All rights reserved.
3
+
4
+ This program is free software; you can redistribute it and/or
5
+ modify it under the terms of the GNU General Public License
6
+ as published by the Free Software Foundation; either version 2
7
+ of the License, or (at your option) any later version.
8
+
9
+ This program is distributed in the hope that it will be useful,
10
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
11
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12
+ GNU General Public License for more details.
13
+
14
+ You should have received a copy of the GNU General Public License
15
+ along with this program; if not, write to the Free Software
16
+ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
17
+ 02111-1307, USA.
18
+ =================================================================*/
19
+ var TYPE_DDF = 1;
20
+ var TYPE_BDF = 0;
21
+ var READ_ONLY = -2;
22
+ var OPEN_NORMAL = 0;
23
+ var AUTO_CREATE_TABLE = true;
24
+ var OWNER_NAME = "";
25
+ var DIR="";
26
+
27
+ var fn_id = 0;
28
+ var fn_user = 1;
29
+ var S_NOWAIT_LOCK = 200;
30
+ var M_NOWAIT_LOCK = 400;
31
+ var CCURR_T_BIAS = 1000;
32
+ var trans_bias = S_NOWAIT_LOCK + CCURR_T_BIAS;
33
+
34
+
35
+ // field type
36
+ var ft_string = 0;
37
+ var ft_integer = 1;
38
+ var ft_float = 2;
39
+ var ft_date = 3;
40
+ var ft_time = 4;
41
+ var ft_decimal = 5;
42
+ var ft_money = 6;
43
+ var ft_logical = 7;
44
+ var ft_numeric = 8;
45
+ var ft_bfloat = 9;
46
+ var ft_lstring = 10;
47
+ var ft_zstring = 11;
48
+ var ft_note = 12;
49
+ var ft_lvar = 13;
50
+ var ft_uinteger = 14;
51
+ var ft_autoinc = 15;
52
+ var ft_bit = 16;
53
+ var ft_numericsts = 17;
54
+ var ft_numericsa = 18;
55
+ var ft_currency = 19;
56
+ var ft_timestamp = 20;
57
+ var ft_blob = 21;
58
+ var ft_reserve22 = 22;
59
+ var ft_reserve23 = 23;
60
+ var ft_reserve24 = 24;
61
+ var ft_wstring = 25;
62
+ var ft_wzstring = 26;
63
+ var ft_guid = 27;
64
+ var ft_datatime = 30;
65
+ var ft_varchar = 40;
66
+ var ft_varbinary = 41;
67
+ var ft_wvarchar = 42;
68
+ var ft_wvarbinary = 43;
69
+ var ft_char = 44;
70
+ var ft_wchar = 45;
71
+ var ft_mydate = 46;
72
+ var ft_mytime = 47;
73
+ var ft_mydatetime = 48;
74
+ var ft_mytimestamp = 49;
75
+ var ft_mytext = 50;
76
+ var ft_myblob = 51;
77
+
78
+ //key flag
79
+ var key_duplicate = 0;
80
+ var key_changeable = 1;
81
+ var key_allnullkey = 3;
82
+ var key_desc = 6;
83
+ var key_extend = 8;
84
+ var key_anynullkey = 9;
85
+ var key_incase = 10;
86
+
87
+ var changeCurrentNcc = 1;
88
+
89
+ var USE_NONE = 0;
90
+ var USE_TRAN = 1;
91
+ var USE_BULKINSERT = 2;
92
+ var USE_SNAPSHOT = 4;
93
+
94
+
95
+ /*--------------------------------------------------------------------------------*/
96
+
97
+ WScript.quit(main());
98
+
99
+ /*--------------------------------------------------------------------------------*/
100
+ function showTableError(tb, TableName)
101
+ {
102
+ if (tb.stat != 0)
103
+ WScript.Echo(TableName + " error No." + tb.stat);
104
+ }
105
+ /*--------------------------------------------------------------------------------*/
106
+ function openTable(db, tableName)
107
+ {
108
+ var ret = db.OpenTable(tableName, OPEN_NORMAL, AUTO_CREATE_TABLE,OWNER_NAME,DIR);
109
+ if (ret == null)
110
+ WScript.Echo(tableName + " open erorr:No" + db.stat);
111
+ return ret;
112
+ }
113
+ /*--------------------------------------------------------------------------------*/
114
+ function write(tb, start, end)
115
+ {
116
+ tb.KeyNum = 0;
117
+ for (var i=start;i< end;i++)
118
+ {
119
+ tb.ClearBuffer();
120
+ tb.Vlng(fn_id) = i;
121
+ tb.Text("name") = i;
122
+ tb.Insert(changeCurrentNcc);
123
+ if (tb.Stat != 0)
124
+ {
125
+ WScript.Echo(tb.Stat);
126
+ return false;
127
+ }
128
+ }
129
+ return true;
130
+ }
131
+ /*--------------------------------------------------------------------------------*/
132
+ function deleteAll(db,tb, start, end)
133
+ {
134
+ db.BeginTrn(trans_bias);
135
+ for (var i=start;i<end;i++)
136
+ {
137
+ tb.Vlng(fn_id) = i;
138
+ tb.Seek();
139
+ if (tb.Stat==0)
140
+ {
141
+ tb.Delete();
142
+ if (tb.Stat!=0)
143
+ {
144
+ showTableError(tb, "deleteAll");
145
+ db.EndTrn();
146
+ return false;
147
+ }
148
+ }
149
+ }
150
+ db.EndTrn();
151
+ return true;
152
+ }
153
+ /*--------------------------------------------------------------------------------*/
154
+ function Inserts(db, tb, start, end, name, mode, unit)
155
+ {
156
+ var ret = deleteAll(db,tb, start, end);
157
+
158
+ if (ret == true)
159
+ {
160
+ var now = new Date();
161
+ var ticks = now.getTime();
162
+ var total = end - start;
163
+ var count = total/unit;
164
+ var st = start;
165
+ var en = st;
166
+ while (en != end)
167
+ {
168
+ en = st + unit;
169
+ if (mode == USE_TRAN)
170
+ db.BeginTrn(trans_bias);
171
+ else if (mode == USE_BULKINSERT)
172
+ tb.BeginBulkInsert();
173
+ ret = write(tb, st, en);
174
+ if (mode == USE_BULKINSERT)
175
+ tb.CommitBulkInsert();
176
+ else if (mode == USE_TRAN)
177
+ db.EndTrn();
178
+ if (ret==false) break;
179
+ st = en;
180
+ }
181
+ if (ret == true)
182
+ {
183
+ now = new Date();
184
+ WScript.Echo((now.getTime() - ticks) + " msec" + name);
185
+ return;
186
+ }
187
+ }
188
+ WScript.Echo("Erorr " + name);
189
+
190
+ }
191
+ /*--------------------------------------------------------------------------------*/
192
+ function Reads(db, tb, start, end, name, shapshot)
193
+ {
194
+ var ret = true;
195
+ var now = new Date();
196
+ var ticks = now.getTime();
197
+ if (shapshot==USE_SNAPSHOT) db.BeginSnapShot();
198
+ for (var i=start;i<end;i++)
199
+ {
200
+ tb.Vlng(fn_id) = i;
201
+ tb.Seek();
202
+ if ((tb.Stat!=0) || (tb.Vlng(0) !=i))
203
+ {
204
+ WScript.Echo("Seek Error Stat = " + tb.Stat + " Value " + i + " = " + tb.Vlng(0));
205
+ ret = false;
206
+ break;
207
+ }
208
+ }
209
+ if (shapshot==USE_SNAPSHOT) db.EndSnapShot();
210
+ if (ret == true)
211
+ {
212
+ now = new Date();
213
+ WScript.Echo((now.getTime() - ticks) + " msec" + name);
214
+ }else
215
+ WScript.Echo("Erorr " + name);
216
+ }
217
+ /*--------------------------------------------------------------------------------*/
218
+ function ReadRange(db, tb, start, end, name, unit, shapshot)
219
+ {
220
+ var ret = true;
221
+ var now = new Date();
222
+ var ticks = now.getTime();
223
+ tb.KeyNum = 0;
224
+ var total = end - start;
225
+ var count = total/unit;
226
+ var st = start;
227
+ if (shapshot == USE_SNAPSHOT) db.BeginSnapShot();
228
+ var en = st;
229
+ while (en != end)
230
+ {
231
+ en = st + unit;
232
+ tb.Filter = "id >= " + st + " and id < " + en;
233
+ tb.FilterRejectCount = 1;
234
+ tb.ClearBuffer();
235
+ tb.Vlng(fn_id) = st;
236
+ tb.SeekGreater(true/*orEqual*/);
237
+ for(var i=st;i<en;i++)
238
+ {
239
+ if (tb.Vlng(fn_id) != i)
240
+ {
241
+ WScript.Echo("FindNext Error Stat = " + tb.Stat + " Value " + i + " = " + tb.Vlng(0));
242
+ ret = false;
243
+ break;
244
+ }
245
+ tb.FindNext();
246
+
247
+ }
248
+ if (ret==false) break;
249
+ st = en;
250
+
251
+ }
252
+ if (shapshot == USE_SNAPSHOT) db.EndSnapShot();
253
+ if (ret == true)
254
+ {
255
+ now = new Date();
256
+ WScript.Echo((now.getTime() - ticks) + " msec" + name);
257
+ }else
258
+ WScript.Echo("Erorr " + name);
259
+ }
260
+ /*--------------------------------------------------------------------------------*/
261
+ function Updates(db, tb, start, end, name, tran, unit)
262
+ {
263
+ var ret = true;
264
+ var now = new Date();
265
+ var ticks = now.getTime();
266
+ tb.KeyNum = 0;
267
+
268
+ var total = end - start;
269
+ var count = total/unit;
270
+ var st = start;
271
+ var en = st;
272
+ while (en != end)
273
+ {
274
+ en = st + unit;
275
+
276
+ if (tran==USE_TRAN) db.BeginTrn(trans_bias);
277
+ for (var i=st;i<en;i++)
278
+ {
279
+ tb.Vlng(fn_id) = i;
280
+ tb.Seek();
281
+ if ((tb.Stat!=0) || (tb.Vlng(0) !=i))
282
+ {
283
+ WScript.Echo("Seek Error Stat = " + tb.Stat + " Value " + i + " = " + tb.Vlng(0));
284
+ ret = false;
285
+ break;
286
+ }
287
+ tb.Text("name") = (i+1+tran);
288
+ tb.UpDate(changeCurrentNcc);
289
+ if (tb.Stat!=0)
290
+ {
291
+ showTableError(tb, name);
292
+ ret = false;
293
+ break;
294
+ }
295
+ }
296
+ if (tran==USE_TRAN) db.EndTrn();
297
+ if (ret==false) break;
298
+ st = en;
299
+ }
300
+
301
+ if (ret == true)
302
+ {
303
+ now = new Date();
304
+ WScript.Echo((now.getTime() - ticks) + " msec" + name);
305
+ }else
306
+ WScript.Echo("Erorr " + name);
307
+ }
308
+ /*--------------------------------------------------------------------------------*/
309
+ function createTestDataBase(db, uri)
310
+ {
311
+ db.Create(uri);
312
+ if (db.Stat!=0)
313
+ {
314
+ WScript.Echo("createTestDataBase erorr:No." + db.Stat + " " + uri);
315
+ return false;
316
+ }
317
+ if (db.Open(uri, TYPE_BDF, OPEN_NORMAL, "", ""))
318
+ {
319
+ var dbdef = db.DbDef;
320
+ var tableid = 1;
321
+
322
+ var tableDef = dbdef.InsertTable(tableid);
323
+ tableDef.TableName = "user";
324
+ tableDef.FileName = "user.dat";
325
+
326
+ var filedIndex = 0;
327
+ var fd = dbdef.InsertField(tableid, filedIndex);
328
+ fd.Name = "id";
329
+ fd.Type = ft_integer;
330
+ fd.Len = 4;
331
+
332
+ filedIndex = 1;
333
+ fd = dbdef.InsertField(tableid, filedIndex);
334
+ fd.Name = "name";
335
+ fd.Type = ft_zstring;
336
+ fd.Len = 33;
337
+
338
+ var keyNum = 0;
339
+ var key = dbdef.InsertKey(tableid, keyNum);
340
+ var seg1 = key.Segments(0);
341
+ seg1.FieldNum = 0;
342
+ seg1.Flags.Bits(key_extend) = true; //extended key type
343
+ seg1.Flags.Bits(key_changeable) = true;//chanageable
344
+ key.SegmentCount = 1;
345
+
346
+ tableDef.PrimaryKeyNum = keyNum;
347
+ dbdef.UpDateTableDef(tableid);
348
+ dbdef = null;
349
+ return true;
350
+
351
+ }
352
+ WScript.Echo("open daatabse erorr:No" + db.stat);
353
+ return false;
354
+ }
355
+ /* -------------------------------------------------------------------------------- */
356
+ function showUsage()
357
+ {
358
+
359
+ var s = "usage: transactdBench databaseUri processNumber functionNumber\n "
360
+ + "\t --- Below is list of functionNumber ---\n"
361
+ + "\t-1: all function\n"
362
+ + "\t 0: Insert\n"
363
+ + "\t 1: Insert in transaction. 20rec x 1000times\n"
364
+ + "\t 2: Insert by bulkmode. 20rec x 1000times\n"
365
+ + "\t 3: read each record\n"
366
+ + "\t 4: read each record with snapshpot\n"
367
+ + "\t 5: read range. 20rec x 1000times\n"
368
+ + "\t 6: read range with snapshpot. 20rec x 1000times\n"
369
+ + "\t 7: update\n"
370
+ + "\t 8: update in transaction. 20rec x 1000times\n"
371
+ + "exsample : transactdBench \"tdap://localhost/test?dbfile=test.bdf\" 0 -1\n";
372
+ WScript.Echo(s);
373
+ }
374
+ /*--------------------------------------------------------------------------------*/
375
+ function main()
376
+ {
377
+
378
+ if (WScript.Arguments.length < 3)
379
+ {
380
+ showUsage();
381
+ return 1;
382
+ }
383
+
384
+ var URI = WScript.Arguments(0);//"tdap://localhost/test?dbfile=test.bdf";
385
+ var db = new ActiveXObject('transactd.database');
386
+ var procID = parseInt(WScript.Arguments(1), 10);
387
+ var execType = parseInt(WScript.Arguments(2), 10);
388
+
389
+ var count = 20000;
390
+ var start = procID * count + 1;
391
+ var end = start + count;
392
+
393
+ if (db.Open(URI, TYPE_BDF, OPEN_NORMAL, "", ""))
394
+ db.Drop();
395
+ if (db.Stat == 3106)
396
+ {
397
+ WScript.Echo("Error! Maybe MySQL or Tranasactd is stopping! ");
398
+ return 1;
399
+ }
400
+ if (!createTestDataBase(db, URI))
401
+ return 1;
402
+
403
+ var now = new Date();
404
+ WScript.Echo("Start Bench mark Insert Items = " + count);
405
+ WScript.Echo(now);
406
+ WScript.Echo(URI);
407
+ WScript.Echo("----------------------------------------");
408
+
409
+ if (db.Open(URI, TYPE_BDF, OPEN_NORMAL, "", ""))
410
+ {
411
+ var tb = openTable(db, "user");
412
+ if (tb != null)
413
+ {
414
+ if ((execType == -1) || (execType == 0))
415
+ Inserts(db, tb, start, end, ": Insert", USE_NONE, 1);
416
+ if ((execType == -1) || (execType == 1))
417
+ Inserts(db, tb, start, end, ": Insert in transaction. 20rec �~ 1000times.", USE_TRAN, 20);
418
+ if ((execType == -1) || (execType == 2))
419
+ Inserts(db, tb, start, end, ": Insert by bulkmode. 20rec �~ 1000times.", USE_BULKINSERT, 20)
420
+ if ((execType == -1) || (execType == 3))
421
+ Reads(db, tb, start, end, ": read each record.", USE_NONE);
422
+ if ((execType == -1) || (execType == 4))
423
+ Reads(db, tb, start,end, ": read each record in snapshot.", USE_SNAPSHOT)
424
+ if ((execType == -1) || (execType == 5))
425
+ ReadRange(db, tb, start, end, ": read range. 20rec �~ 1000times.", 20, USE_NONE)
426
+ if ((execType == -1) || (execType == 6))
427
+ ReadRange(db, tb, start, end, ": read range with snapshpot. 20rec x 1000times.", 20, USE_SNAPSHOT)
428
+ if ((execType == -1) || (execType == 7))
429
+ Updates(db, tb, start, end, ": update.", USE_NONE, 1);
430
+ if ((execType == -1) || (execType == 8))
431
+ Updates(db, tb, start, end, ": update in transaction. 20rec �~ 1000times.", USE_TRAN, 20);
432
+ tb.Close();
433
+ }
434
+
435
+ }
436
+ if (db.stat!=0)
437
+ {
438
+ WScript.Echo("open table erorr:No" + db.stat);
439
+ return 1;
440
+ }
441
+
442
+ db.Close();
443
+ WScript.Echo("----------------------------------------");
444
+ return 0;
445
+ }