Coverage for SQL.py: 76%

547 statements  

« prev     ^ index     » next       coverage.py v7.6.1, created at 2024-09-28 16:41 +0000

1#!/usr/bin/env python 

2# -*- coding: utf-8 -*- 

3"""Returns a dict of SQL statements used in fpdb. 

4""" 

5from __future__ import print_function 

6# Copyright 2008-2011, Ray E. Barker 

7#  

8# This program is free software; you can redistribute it and/or modify 

9# it under the terms of the GNU General Public License as published by 

10# the Free Software Foundation; either version 2 of the License, or 

11# (at your option) any later version. 

12#  

13# This program is distributed in the hope that it will be useful, 

14# but WITHOUT ANY WARRANTY; without even the implied warranty of 

15# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 

16# GNU General Public License for more details. 

17#  

18# You should have received a copy of the GNU General Public License 

19# along with this program; if not, write to the Free Software 

20# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 

21 

22# NOTES: The sql statements use the placeholder %s for bind variables 

23# which is then replaced by ? for sqlite. Comments can be included  

24# within sql statements using C style /* ... */ comments, BUT 

25# THE COMMENTS MUST NOT INCLUDE %s OR ?. 

26 

27######################################################################## 

28 

29# Standard Library modules 

30 

31import re 

32 

33# pyGTK modules 

34 

35# FreePokerTools modules 

36 

37class Sql(object): 

38 

39 def __init__(self, game='holdem', db_server='mysql'): 

40 self.query = {} 

41###############################################################################3 

42# Support for the Free Poker DataBase = fpdb http://fpdb.sourceforge.net/ 

43# 

44 

45 ################################ 

46 # List tables 

47 ################################ 

48 if db_server == 'mysql': 

49 self.query['list_tables'] = """SHOW TABLES""" 

50 elif db_server == 'postgresql': 

51 self.query['list_tables'] = """SELECT table_name FROM information_schema.tables WHERE table_schema = 'public'""" 

52 elif db_server == 'sqlite': 

53 self.query['list_tables'] = """SELECT name FROM sqlite_master 

54 WHERE type='table' 

55 ORDER BY name;""" 

56 

57 ################################ 

58 # List indexes 

59 ################################ 

60 if db_server == 'mysql': 

61 self.query['list_indexes'] = """SHOW INDEXES""" 

62 elif db_server == 'postgresql': 

63 self.query['list_indexes'] = """SELECT tablename, indexname FROM PG_INDEXES""" 

64 elif db_server == 'sqlite': 

65 self.query['list_indexes'] = """SELECT name FROM sqlite_master 

66 WHERE type='index' 

67 ORDER BY name;""" 

68 

69 ################################################################## 

70 # Drop Tables - MySQL, PostgreSQL and SQLite all share same syntax 

71 ################################################################## 

72 

73 self.query['drop_table'] = """DROP TABLE IF EXISTS """ 

74 

75 

76 ################################################################## 

77 # Set transaction isolation level 

78 ################################################################## 

79 

80 if db_server == 'mysql' or db_server == 'postgresql': 

81 self.query['set tx level'] = """SET SESSION TRANSACTION 

82 ISOLATION LEVEL READ COMMITTED""" 

83 elif db_server == 'sqlite': 

84 self.query['set tx level'] = """ """ 

85 

86 

87 ################################ 

88 # Select basic info 

89 ################################ 

90 

91 self.query['getSiteId'] = """SELECT id from Sites where name = %s""" 

92 

93 self.query['getGames'] = """SELECT DISTINCT category from Gametypes""" 

94 

95 self.query['getCurrencies'] = """SELECT DISTINCT currency from Gametypes ORDER BY currency""" 

96 

97 self.query['getLimits'] = """SELECT DISTINCT bigBlind from Gametypes ORDER by bigBlind DESC""" 

98 

99 self.query['getTourneyTypesIds'] = "SELECT id FROM TourneyTypes" 

100 

101 self.query['getTourneyTypes'] = "SELECT DISTINCT tourneyName FROM Tourneys" 

102 

103 self.query['getTourneyNames'] = "SELECT tourneyName FROM Tourneys" 

104 

105 ################################ 

106 # Create Settings 

107 ################################ 

108 if db_server == 'mysql': 

109 self.query['createSettingsTable'] = """CREATE TABLE Settings ( 

110 version SMALLINT NOT NULL) 

111 ENGINE=INNODB""" 

112 elif db_server == 'postgresql': 

113 self.query['createSettingsTable'] = """CREATE TABLE Settings (version SMALLINT NOT NULL)""" 

114 

115 elif db_server == 'sqlite': 

116 self.query['createSettingsTable'] = """CREATE TABLE Settings 

117 (version INTEGER NOT NULL) """ 

118 

119 ################################ 

120 # Create InsertLock 

121 ################################ 

122 if db_server == 'mysql': 

123 self.query['createLockTable'] = """CREATE TABLE InsertLock ( 

124 id BIGINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

125 locked BOOLEAN NOT NULL DEFAULT FALSE) 

126 ENGINE=INNODB""" 

127 

128 ################################ 

129 # Create RawHands (this table is all but identical with RawTourneys) 

130 ################################ 

131 if db_server == 'mysql': 

132 self.query['createRawHands'] = """CREATE TABLE RawHands ( 

133 id BIGINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

134 handId BIGINT NOT NULL, 

135 rawHand TEXT NOT NULL, 

136 complain BOOLEAN NOT NULL DEFAULT FALSE) 

137 ENGINE=INNODB""" 

138 elif db_server == 'postgresql': 

139 self.query['createRawHands'] = """CREATE TABLE RawHands ( 

140 id BIGSERIAL, PRIMARY KEY (id), 

141 handId BIGINT NOT NULL, 

142 rawHand TEXT NOT NULL, 

143 complain BOOLEAN NOT NULL DEFAULT FALSE)""" 

144 elif db_server == 'sqlite': 

145 self.query['createRawHands'] = """CREATE TABLE RawHands ( 

146 id INTEGER PRIMARY KEY, 

147 handId BIGINT NOT NULL, 

148 rawHand TEXT NOT NULL, 

149 complain BOOLEAN NOT NULL DEFAULT FALSE)""" 

150 

151 ################################ 

152 # Create RawTourneys (this table is all but identical with RawHands) 

153 ################################ 

154 if db_server == 'mysql': 

155 self.query['createRawTourneys'] = """CREATE TABLE RawTourneys ( 

156 id BIGINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

157 tourneyId BIGINT NOT NULL, 

158 rawTourney TEXT NOT NULL, 

159 complain BOOLEAN NOT NULL DEFAULT FALSE) 

160 ENGINE=INNODB""" 

161 elif db_server == 'postgresql': 

162 self.query['createRawTourneys'] = """CREATE TABLE RawTourneys ( 

163 id BIGSERIAL, PRIMARY KEY (id), 

164 tourneyId BIGINT NOT NULL, 

165 rawTourney TEXT NOT NULL, 

166 complain BOOLEAN NOT NULL DEFAULT FALSE)""" 

167 elif db_server == 'sqlite': 

168 self.query['createRawTourneys'] = """CREATE TABLE RawTourneys ( 

169 id INTEGER PRIMARY KEY, 

170 tourneyId BIGINT NOT NULL, 

171 rawTourney TEXT NOT NULL, 

172 complain BOOLEAN NOT NULL DEFAULT FALSE)""" 

173 

174 ################################ 

175 # Create Actions 

176 ################################ 

177 

178 if db_server == 'mysql': 

179 self.query['createActionsTable'] = """CREATE TABLE Actions ( 

180 id SMALLINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

181 name varchar(32) NOT NULL, 

182 code char(4) NOT NULL) 

183 ENGINE=INNODB""" 

184 elif db_server == 'postgresql': 

185 self.query['createActionsTable'] = """CREATE TABLE Actions ( 

186 id SERIAL, PRIMARY KEY (id), 

187 name varchar(32), 

188 code char(4))""" 

189 elif db_server == 'sqlite': 

190 self.query['createActionsTable'] = """CREATE TABLE Actions ( 

191 id INTEGER PRIMARY KEY, 

192 name TEXT NOT NULL, 

193 code TEXT NOT NULL)""" 

194 

195 ################################ 

196 # Create Rank 

197 ################################ 

198 

199 if db_server == 'mysql': 

200 self.query['createRankTable'] = """CREATE TABLE Rank ( 

201 id SMALLINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id),  

202 name varchar(8) NOT NULL) 

203 ENGINE=INNODB""" 

204 

205 elif db_server == 'postgresql': 

206 self.query['createRankTable'] = """CREATE TABLE Rank ( 

207 id SERIAL, PRIMARY KEY (id), 

208 name varchar(8))""" 

209 elif db_server == 'sqlite': 

210 self.query['createRankTable'] = """CREATE TABLE Rank ( 

211 id INTEGER PRIMARY KEY, 

212 name TEXT NOT NULL)""" 

213 

214 ################################ 

215 # Create StartCards 

216 ################################ 

217 

218 if db_server == 'mysql': 

219 self.query['createStartCardsTable'] = """CREATE TABLE StartCards ( 

220 id SMALLINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

221 category varchar(9) NOT NULL, 

222 name varchar(32) NOT NULL, 

223 rank SMALLINT NOT NULL, 

224 combinations SMALLINT NOT NULL) 

225 ENGINE=INNODB""" 

226 

227 elif db_server == 'postgresql': 

228 self.query['createStartCardsTable'] = """CREATE TABLE StartCards ( 

229 id SERIAL, PRIMARY KEY (id), 

230 category varchar(9) NOT NULL, 

231 name varchar(32), 

232 rank SMALLINT NOT NULL, 

233 combinations SMALLINT NOT NULL)""" 

234 

235 elif db_server == 'sqlite': 

236 self.query['createStartCardsTable'] = """CREATE TABLE StartCards ( 

237 id INTEGER PRIMARY KEY, 

238 category TEXT NOT NULL, 

239 name TEXT NOT NULL, 

240 rank SMALLINT NOT NULL, 

241 combinations SMALLINT NOT NULL)""" 

242 

243 ################################ 

244 # Create Sites 

245 ################################ 

246 

247 if db_server == 'mysql': 

248 self.query['createSitesTable'] = """CREATE TABLE Sites ( 

249 id SMALLINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

250 name varchar(32) NOT NULL, 

251 code char(2) NOT NULL) 

252 ENGINE=INNODB""" 

253 elif db_server == 'postgresql': 

254 self.query['createSitesTable'] = """CREATE TABLE Sites ( 

255 id SERIAL, PRIMARY KEY (id), 

256 name varchar(32), 

257 code char(2))""" 

258 elif db_server == 'sqlite': 

259 self.query['createSitesTable'] = """CREATE TABLE Sites ( 

260 id INTEGER PRIMARY KEY, 

261 name TEXT NOT NULL, 

262 code TEXT NOT NULL)""" 

263 

264 ################################ 

265 # Create Backings 

266 ################################ 

267 

268 if db_server == 'mysql': 

269 self.query['createBackingsTable'] = """CREATE TABLE Backings ( 

270 id SMALLINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

271 tourneysPlayersId BIGINT UNSIGNED NOT NULL, FOREIGN KEY (tourneysPlayersId) REFERENCES TourneysPlayers(id), 

272 playerId INT UNSIGNED NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

273 buyInPercentage FLOAT UNSIGNED NOT NULL, 

274 payOffPercentage FLOAT UNSIGNED NOT NULL) ENGINE=INNODB""" 

275 elif db_server == 'postgresql': 

276 self.query['createBackingsTable'] = """CREATE TABLE Backings ( 

277 id BIGSERIAL, PRIMARY KEY (id), 

278 tourneysPlayersId INT NOT NULL, FOREIGN KEY (tourneysPlayersId) REFERENCES TourneysPlayers(id), 

279 playerId INT NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

280 buyInPercentage FLOAT NOT NULL, 

281 payOffPercentage FLOAT NOT NULL)""" 

282 elif db_server == 'sqlite': 

283 self.query['createBackingsTable'] = """CREATE TABLE Backings ( 

284 id INTEGER PRIMARY KEY, 

285 tourneysPlayersId INT NOT NULL, 

286 playerId INT NOT NULL, 

287 buyInPercentage REAL UNSIGNED NOT NULL, 

288 payOffPercentage REAL UNSIGNED NOT NULL)""" 

289 

290 ################################ 

291 # Create Gametypes 

292 ################################ 

293 

294 if db_server == 'mysql': 

295 self.query['createGametypesTable'] = """CREATE TABLE Gametypes ( 

296 id SMALLINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

297 siteId SMALLINT UNSIGNED NOT NULL, FOREIGN KEY (siteId) REFERENCES Sites(id), 

298 currency varchar(4) NOT NULL, 

299 type char(4) NOT NULL, 

300 base char(4) NOT NULL, 

301 category varchar(9) NOT NULL, 

302 limitType char(2) NOT NULL, 

303 hiLo char(1) NOT NULL, 

304 mix varchar(9) NOT NULL, 

305 smallBlind bigint, 

306 bigBlind bigint, 

307 smallBet bigint NOT NULL, 

308 bigBet bigint NOT NULL, 

309 maxSeats TINYINT NOT NULL, 

310 ante INT NOT NULL, 

311 buyinType varchar(9) NOT NULL, 

312 fast BOOLEAN, 

313 newToGame BOOLEAN, 

314 homeGame BOOLEAN, 

315 split BOOLEAN) 

316 ENGINE=INNODB""" 

317 elif db_server == 'postgresql': 

318 self.query['createGametypesTable'] = """CREATE TABLE Gametypes ( 

319 id SERIAL NOT NULL, PRIMARY KEY (id), 

320 siteId INTEGER NOT NULL, FOREIGN KEY (siteId) REFERENCES Sites(id), 

321 currency varchar(4) NOT NULL, 

322 type char(4) NOT NULL, 

323 base char(4) NOT NULL, 

324 category varchar(9) NOT NULL, 

325 limitType char(2) NOT NULL, 

326 hiLo char(1) NOT NULL, 

327 mix varchar(9) NOT NULL, 

328 smallBlind bigint, 

329 bigBlind bigint, 

330 smallBet bigint NOT NULL, 

331 bigBet bigint NOT NULL, 

332 maxSeats SMALLINT NOT NULL, 

333 ante INT NOT NULL, 

334 buyinType varchar(9) NOT NULL, 

335 fast BOOLEAN, 

336 newToGame BOOLEAN, 

337 homeGame BOOLEAN, 

338 split BOOLEAN)""" 

339 elif db_server == 'sqlite': 

340 self.query['createGametypesTable'] = """CREATE TABLE Gametypes ( 

341 id INTEGER PRIMARY KEY NOT NULL, 

342 siteId INTEGER NOT NULL, 

343 currency TEXT NOT NULL, 

344 type TEXT NOT NULL, 

345 base TEXT NOT NULL, 

346 category TEXT NOT NULL, 

347 limitType TEXT NOT NULL, 

348 hiLo TEXT NOT NULL, 

349 mix TEXT NOT NULL, 

350 smallBlind INTEGER, 

351 bigBlind INTEGER, 

352 smallBet INTEGER NOT NULL, 

353 bigBet INTEGER NOT NULL, 

354 maxSeats INT NOT NULL, 

355 ante INT NOT NULL, 

356 buyinType TEXT NOT NULL, 

357 fast INT, 

358 newToGame INT, 

359 homeGame INT, 

360 split INT, 

361 FOREIGN KEY(siteId) REFERENCES Sites(id) ON DELETE CASCADE)""" 

362 

363 

364 ################################ 

365 # Create Players 

366 ################################ 

367 

368 if db_server == 'mysql': 

369 self.query['createPlayersTable'] = """CREATE TABLE Players ( 

370 id INT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

371 name VARCHAR(32) NOT NULL, 

372 siteId SMALLINT UNSIGNED NOT NULL, FOREIGN KEY (siteId) REFERENCES Sites(id), 

373 hero BOOLEAN,  

374 chars char(3), 

375 comment text, 

376 commentTs DATETIME, 

377 profil text, 

378 color_code VARCHAR(7) DEFAULT '#FFFFFF', 

379 symbol VARCHAR(10) DEFAULT '★'  

380 ) 

381 ENGINE=INNODB""" 

382 elif db_server == 'postgresql': 

383 self.query['createPlayersTable'] = """CREATE TABLE Players ( 

384 id SERIAL, PRIMARY KEY (id), 

385 name VARCHAR(32), 

386 siteId INTEGER, FOREIGN KEY (siteId) REFERENCES Sites(id), 

387 hero BOOLEAN, 

388 chars char(3), 

389 comment text, 

390 commentTs timestamp without time zone, 

391 profil text, 

392 color_code VARCHAR(7) DEFAULT '#FFFFFF', 

393 symbol VARCHAR(10) DEFAULT '★' )""" 

394 elif db_server == 'sqlite': 

395 self.query['createPlayersTable'] = """CREATE TABLE Players ( 

396 id INTEGER PRIMARY KEY, 

397 name TEXT, 

398 siteId INTEGER, 

399 hero BOOLEAN, 

400 chars TEXT, 

401 comment TEXT, 

402 commentTs timestamp, 

403 profil TEXT, 

404 color_code TEXT DEFAULT '#FFFFFF', 

405 symbol TEXT DEFAULT '★',  

406 FOREIGN KEY(siteId) REFERENCES Sites(id) ON DELETE CASCADE)""" 

407 

408 

409 ################################ 

410 # Create Autorates 

411 ################################ 

412 

413 if db_server == 'mysql': 

414 self.query['createAutoratesTable'] = """CREATE TABLE Autorates ( 

415 id BIGINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

416 playerId INT UNSIGNED NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

417 gametypeId SMALLINT UNSIGNED NOT NULL, FOREIGN KEY (gametypeId) REFERENCES Gametypes(id), 

418 description varchar(50) NOT NULL, 

419 shortDesc char(8) NOT NULL, 

420 ratingTime DATETIME NOT NULL, 

421 handCount int NOT NULL) 

422 ENGINE=INNODB""" 

423 elif db_server == 'postgresql': 

424 self.query['createAutoratesTable'] = """CREATE TABLE Autorates ( 

425 id BIGSERIAL, PRIMARY KEY (id), 

426 playerId INT, FOREIGN KEY (playerId) REFERENCES Players(id), 

427 gametypeId INT, FOREIGN KEY (gametypeId) REFERENCES Gametypes(id), 

428 description varchar(50), 

429 shortDesc char(8), 

430 ratingTime timestamp without time zone, 

431 handCount int)""" 

432 elif db_server == 'sqlite': 

433 self.query['createAutoratesTable'] = """CREATE TABLE Autorates ( 

434 id INTEGER PRIMARY KEY, 

435 playerId INT, 

436 gametypeId INT, 

437 description TEXT, 

438 shortDesc TEXT, 

439 ratingTime timestamp, 

440 handCount int)""" 

441 

442 

443 ################################ 

444 # Create Hands 

445 ################################ 

446 

447 if db_server == 'mysql': 

448 self.query['createHandsTable'] = """CREATE TABLE Hands ( 

449 id BIGINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

450 tableName VARCHAR(50) NOT NULL, 

451 siteHandNo BIGINT NOT NULL, 

452 tourneyId INT UNSIGNED, FOREIGN KEY (tourneyId) REFERENCES Tourneys(id), 

453 gametypeId SMALLINT UNSIGNED NOT NULL, FOREIGN KEY (gametypeId) REFERENCES Gametypes(id), 

454 sessionId INT UNSIGNED, FOREIGN KEY (sessionId) REFERENCES Sessions(id), 

455 fileId INT(10) UNSIGNED NOT NULL, FOREIGN KEY (fileId) REFERENCES Files(id),  

456 startTime DATETIME NOT NULL, 

457 importTime DATETIME NOT NULL, 

458 seats TINYINT NOT NULL, 

459 heroSeat TINYINT NOT NULL, 

460 maxPosition TINYINT NOT NULL, 

461 boardcard1 smallint, /* 0=none, 1-13=2-Ah 14-26=2-Ad 27-39=2-Ac 40-52=2-As */ 

462 boardcard2 smallint, 

463 boardcard3 smallint, 

464 boardcard4 smallint, 

465 boardcard5 smallint, 

466 texture smallint, 

467 runItTwice BOOLEAN, 

468 playersVpi SMALLINT NOT NULL, /* num of players vpi */ 

469 playersAtStreet1 SMALLINT NOT NULL, /* num of players seeing flop/street4 */ 

470 playersAtStreet2 SMALLINT NOT NULL, 

471 playersAtStreet3 SMALLINT NOT NULL, 

472 playersAtStreet4 SMALLINT NOT NULL, 

473 playersAtShowdown SMALLINT NOT NULL, 

474 street0Raises TINYINT NOT NULL, /* num small bets paid to see flop/street4, including blind */ 

475 street1Raises TINYINT NOT NULL, /* num small bets paid to see turn/street5 */ 

476 street2Raises TINYINT NOT NULL, /* num big bets paid to see river/street6 */ 

477 street3Raises TINYINT NOT NULL, /* num big bets paid to see sd/street7 */ 

478 street4Raises TINYINT NOT NULL, /* num big bets paid to see showdown */ 

479 street0Pot BIGINT, /* pot size at pre-flop/street2 */ 

480 street1Pot BIGINT, /* pot size at flop/street4 */ 

481 street2Pot BIGINT, /* pot size at turn/street5 */ 

482 street3Pot BIGINT, /* pot size at river/street6 */ 

483 street4Pot BIGINT, /* pot size at sd/street7 */ 

484 finalPot BIGINT, /* final pot size */ 

485 comment TEXT, 

486 commentTs DATETIME) 

487 ENGINE=INNODB""" 

488 elif db_server == 'postgresql': 

489 self.query['createHandsTable'] = """CREATE TABLE Hands ( 

490 id BIGSERIAL, PRIMARY KEY (id), 

491 tableName VARCHAR(50) NOT NULL, 

492 siteHandNo BIGINT NOT NULL, 

493 tourneyId INT, FOREIGN KEY (tourneyId) REFERENCES Tourneys(id), 

494 gametypeId INT NOT NULL, FOREIGN KEY (gametypeId) REFERENCES Gametypes(id), 

495 sessionId INT, FOREIGN KEY (sessionId) REFERENCES Sessions(id), 

496 fileId BIGINT NOT NULL, FOREIGN KEY (fileId) REFERENCES Files(id), 

497 startTime timestamp without time zone NOT NULL, 

498 importTime timestamp without time zone NOT NULL, 

499 seats SMALLINT NOT NULL, 

500 heroSeat SMALLINT NOT NULL, 

501 maxPosition SMALLINT NOT NULL, 

502 boardcard1 smallint, /* 0=none, 1-13=2-Ah 14-26=2-Ad 27-39=2-Ac 40-52=2-As */ 

503 boardcard2 smallint, 

504 boardcard3 smallint, 

505 boardcard4 smallint, 

506 boardcard5 smallint, 

507 texture smallint, 

508 runItTwice BOOLEAN, 

509 playersVpi SMALLINT NOT NULL, /* num of players vpi */ 

510 playersAtStreet1 SMALLINT NOT NULL, /* num of players seeing flop/street4 */ 

511 playersAtStreet2 SMALLINT NOT NULL, 

512 playersAtStreet3 SMALLINT NOT NULL, 

513 playersAtStreet4 SMALLINT NOT NULL, 

514 playersAtShowdown SMALLINT NOT NULL, 

515 street0Raises SMALLINT NOT NULL, /* num small bets paid to see flop/street4, including blind */ 

516 street1Raises SMALLINT NOT NULL, /* num small bets paid to see turn/street5 */ 

517 street2Raises SMALLINT NOT NULL, /* num big bets paid to see river/street6 */ 

518 street3Raises SMALLINT NOT NULL, /* num big bets paid to see sd/street7 */ 

519 street4Raises SMALLINT NOT NULL, /* num big bets paid to see showdown */ 

520 street0Pot BIGINT, /* pot size at preflop/street3 */ 

521 street1Pot BIGINT, /* pot size at flop/street4 */ 

522 street2Pot BIGINT, /* pot size at turn/street5 */ 

523 street3Pot BIGINT, /* pot size at river/street6 */ 

524 street4Pot BIGINT, /* pot size at sd/street7 */ 

525 finalPot BIGINT, /* final pot size */ 

526 comment TEXT, 

527 commentTs timestamp without time zone)""" 

528 elif db_server == 'sqlite': 

529 self.query['createHandsTable'] = """CREATE TABLE Hands ( 

530 id INTEGER PRIMARY KEY, 

531 tableName TEXT(50) NOT NULL, 

532 siteHandNo INT NOT NULL, 

533 tourneyId INT, 

534 gametypeId INT NOT NULL, 

535 sessionId INT, 

536 fileId INT NOT NULL, 

537 startTime timestamp NOT NULL, 

538 importTime timestamp NOT NULL, 

539 seats INT NOT NULL, 

540 heroSeat INT NOT NULL, 

541 maxPosition INT NOT NULL, 

542 boardcard1 INT, /* 0=none, 1-13=2-Ah 14-26=2-Ad 27-39=2-Ac 40-52=2-As */ 

543 boardcard2 INT, 

544 boardcard3 INT, 

545 boardcard4 INT, 

546 boardcard5 INT, 

547 texture INT, 

548 runItTwice BOOLEAN, 

549 playersVpi INT NOT NULL, /* num of players vpi */ 

550 playersAtStreet1 INT NOT NULL, /* num of players seeing flop/street4 */ 

551 playersAtStreet2 INT NOT NULL, 

552 playersAtStreet3 INT NOT NULL, 

553 playersAtStreet4 INT NOT NULL, 

554 playersAtShowdown INT NOT NULL, 

555 street0Raises INT NOT NULL, /* num small bets paid to see flop/street4, including blind */ 

556 street1Raises INT NOT NULL, /* num small bets paid to see turn/street5 */ 

557 street2Raises INT NOT NULL, /* num big bets paid to see river/street6 */ 

558 street3Raises INT NOT NULL, /* num big bets paid to see sd/street7 */ 

559 street4Raises INT NOT NULL, /* num big bets paid to see showdown */ 

560 street0Pot INT, /* pot size at preflop/street3 */ 

561 street1Pot INT, /* pot size at flop/street4 */ 

562 street2Pot INT, /* pot size at turn/street5 */ 

563 street3Pot INT, /* pot size at river/street6 */ 

564 street4Pot INT, /* pot size at sd/street7 */ 

565 finalPot INT, /* final pot size */ 

566 comment TEXT, 

567 commentTs timestamp)""" 

568 

569 ################################ 

570 # Create Boards 

571 ################################ 

572 

573 if db_server == 'mysql': 

574 self.query['createBoardsTable'] = """CREATE TABLE Boards ( 

575 id BIGINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

576 handId BIGINT UNSIGNED NOT NULL, FOREIGN KEY (handId) REFERENCES Hands(id), 

577 boardId smallint, 

578 boardcard1 smallint, /* 0=none, 1-13=2-Ah 14-26=2-Ad 27-39=2-Ac 40-52=2-As */ 

579 boardcard2 smallint, 

580 boardcard3 smallint, 

581 boardcard4 smallint, 

582 boardcard5 smallint) 

583 ENGINE=INNODB""" 

584 elif db_server == 'postgresql': 

585 self.query['createBoardsTable'] = """CREATE TABLE Boards ( 

586 id BIGSERIAL, PRIMARY KEY (id), 

587 handId BIGINT NOT NULL, FOREIGN KEY (handId) REFERENCES Hands(id), 

588 boardId smallint, 

589 boardcard1 smallint, /* 0=none, 1-13=2-Ah 14-26=2-Ad 27-39=2-Ac 40-52=2-As */ 

590 boardcard2 smallint, 

591 boardcard3 smallint, 

592 boardcard4 smallint, 

593 boardcard5 smallint)""" 

594 elif db_server == 'sqlite': 

595 self.query['createBoardsTable'] = """CREATE TABLE Boards ( 

596 id INTEGER PRIMARY KEY, 

597 handId INT NOT NULL, 

598 boardId INT, 

599 boardcard1 INT, /* 0=none, 1-13=2-Ah 14-26=2-Ad 27-39=2-Ac 40-52=2-As */ 

600 boardcard2 INT, 

601 boardcard3 INT, 

602 boardcard4 INT, 

603 boardcard5 INT)""" 

604 

605 

606 

607 

608 

609 

610 

611 

612 

613 

614 

615 ################################ 

616 # Create TourneyTypes 

617 ################################ 

618 

619 if db_server == 'mysql': 

620 self.query['createTourneyTypesTable'] = """CREATE TABLE TourneyTypes ( 

621 id SMALLINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

622 siteId SMALLINT UNSIGNED NOT NULL, FOREIGN KEY (siteId) REFERENCES Sites(id), 

623 currency varchar(4), 

624 buyIn BIGINT, 

625 fee BIGINT, 

626 category varchar(9) NOT NULL, 

627 limitType char(2) NOT NULL, 

628 buyInChips BIGINT, 

629 stack varchar(8), 

630 maxSeats INT, 

631 rebuy BOOLEAN, 

632 rebuyCost BIGINT, 

633 rebuyFee BIGINT, 

634 rebuyChips BIGINT, 

635 addOn BOOLEAN, 

636 addOnCost BIGINT, 

637 addOnFee BIGINT, 

638 addOnChips BIGINT, 

639 knockout BOOLEAN, 

640 koBounty BIGINT, 

641 progressive BOOLEAN, 

642 step BOOLEAN, 

643 stepNo INT, 

644 chance BOOLEAN, 

645 chanceCount INT, 

646 speed varchar(10), 

647 shootout BOOLEAN, 

648 matrix BOOLEAN, 

649 multiEntry BOOLEAN, 

650 reEntry BOOLEAN, 

651 fast BOOLEAN,  

652 newToGame BOOLEAN, 

653 homeGame BOOLEAN, 

654 split BOOLEAN, 

655 sng BOOLEAN, 

656 fifty50 BOOLEAN, 

657 time BOOLEAN, 

658 timeAmt INT, 

659 satellite BOOLEAN, 

660 doubleOrNothing BOOLEAN, 

661 cashOut BOOLEAN, 

662 onDemand BOOLEAN, 

663 flighted BOOLEAN, 

664 guarantee BOOLEAN, 

665 guaranteeAmt BIGINT) 

666 ENGINE=INNODB""" 

667 elif db_server == 'postgresql': 

668 self.query['createTourneyTypesTable'] = """CREATE TABLE TourneyTypes ( 

669 id SERIAL, PRIMARY KEY (id), 

670 siteId INT NOT NULL, FOREIGN KEY (siteId) REFERENCES Sites(id), 

671 currency varchar(4), 

672 buyin BIGINT, 

673 fee BIGINT, 

674 category varchar(9), 

675 limitType char(2), 

676 buyInChips BIGINT, 

677 stack varchar(8), 

678 maxSeats INT, 

679 rebuy BOOLEAN, 

680 rebuyCost BIGINT, 

681 rebuyFee BIGINT, 

682 rebuyChips BIGINT, 

683 addOn BOOLEAN, 

684 addOnCost BIGINT, 

685 addOnFee BIGINT, 

686 addOnChips BIGINT, 

687 knockout BOOLEAN, 

688 koBounty BIGINT, 

689 progressive BOOLEAN, 

690 step BOOLEAN, 

691 stepNo INT, 

692 chance BOOLEAN, 

693 chanceCount INT, 

694 speed varchar(10), 

695 shootout BOOLEAN, 

696 matrix BOOLEAN, 

697 multiEntry BOOLEAN, 

698 reEntry BOOLEAN, 

699 fast BOOLEAN, 

700 newToGame BOOLEAN, 

701 homeGame BOOLEAN, 

702 split BOOLEAN, 

703 sng BOOLEAN, 

704 fifty50 BOOLEAN, 

705 time BOOLEAN, 

706 timeAmt INT, 

707 satellite BOOLEAN, 

708 doubleOrNothing BOOLEAN, 

709 cashOut BOOLEAN, 

710 onDemand BOOLEAN, 

711 flighted BOOLEAN, 

712 guarantee BOOLEAN, 

713 guaranteeAmt BIGINT)""" 

714 elif db_server == 'sqlite': 

715 self.query['createTourneyTypesTable'] = """CREATE TABLE TourneyTypes ( 

716 id INTEGER PRIMARY KEY, 

717 siteId INT NOT NULL, 

718 currency VARCHAR(4), 

719 buyin INT, 

720 fee INT, 

721 category TEXT, 

722 limitType TEXT, 

723 buyInChips INT, 

724 stack VARCHAR(8), 

725 maxSeats INT, 

726 rebuy BOOLEAN, 

727 rebuyCost INT, 

728 rebuyFee INT, 

729 rebuyChips INT, 

730 addOn BOOLEAN, 

731 addOnCost INT, 

732 addOnFee INT, 

733 addOnChips INT, 

734 knockout BOOLEAN, 

735 koBounty INT, 

736 progressive BOOLEAN, 

737 step BOOLEAN, 

738 stepNo INT, 

739 chance BOOLEAN, 

740 chanceCount INT, 

741 speed TEXT, 

742 shootout BOOLEAN, 

743 matrix BOOLEAN, 

744 multiEntry BOOLEAN, 

745 reEntry BOOLEAN, 

746 fast BOOLEAN, 

747 newToGame BOOLEAN, 

748 homeGame BOOLEAN, 

749 split BOOLEAN, 

750 sng BOOLEAN, 

751 fifty50 BOOLEAN, 

752 time BOOLEAN, 

753 timeAmt INT, 

754 satellite BOOLEAN, 

755 doubleOrNothing BOOLEAN, 

756 cashOut BOOLEAN, 

757 onDemand BOOLEAN, 

758 flighted BOOLEAN, 

759 guarantee BOOLEAN, 

760 guaranteeAmt INT)""" 

761 

762 ################################ 

763 # Create Tourneys 

764 ################################ 

765 

766 if db_server == 'mysql': 

767 self.query['createTourneysTable'] = """CREATE TABLE Tourneys ( 

768 id INT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

769 tourneyTypeId SMALLINT UNSIGNED NOT NULL, FOREIGN KEY (tourneyTypeId) REFERENCES TourneyTypes(id), 

770 sessionId INT UNSIGNED, FOREIGN KEY (sessionId) REFERENCES Sessions(id), 

771 siteTourneyNo BIGINT NOT NULL, 

772 entries INT, 

773 prizepool BIGINT, 

774 startTime DATETIME, 

775 endTime DATETIME, 

776 tourneyName TEXT, 

777 totalRebuyCount INT, 

778 totalAddOnCount INT, 

779 added BIGINT, 

780 addedCurrency VARCHAR(4), 

781 comment TEXT, 

782 commentTs DATETIME) 

783 ENGINE=INNODB""" 

784 elif db_server == 'postgresql': 

785 self.query['createTourneysTable'] = """CREATE TABLE Tourneys ( 

786 id SERIAL, PRIMARY KEY (id), 

787 tourneyTypeId INT, FOREIGN KEY (tourneyTypeId) REFERENCES TourneyTypes(id), 

788 sessionId INT, FOREIGN KEY (sessionId) REFERENCES Sessions(id), 

789 siteTourneyNo BIGINT, 

790 entries INT, 

791 prizepool BIGINT, 

792 startTime timestamp without time zone, 

793 endTime timestamp without time zone, 

794 tourneyName TEXT, 

795 totalRebuyCount INT, 

796 totalAddOnCount INT, 

797 added BIGINT, 

798 addedCurrency VARCHAR(4), 

799 comment TEXT, 

800 commentTs timestamp without time zone)""" 

801 elif db_server == 'sqlite': 

802 self.query['createTourneysTable'] = """CREATE TABLE Tourneys ( 

803 id INTEGER PRIMARY KEY, 

804 tourneyTypeId INT, 

805 sessionId INT, 

806 siteTourneyNo INT, 

807 entries INT, 

808 prizepool INT, 

809 startTime timestamp, 

810 endTime timestamp, 

811 tourneyName TEXT, 

812 totalRebuyCount INT, 

813 totalAddOnCount INT, 

814 added INT, 

815 addedCurrency VARCHAR(4), 

816 comment TEXT, 

817 commentTs timestamp)""" 

818 

819 ################################ 

820 # Create HandsPlayers 

821 ################################ 

822 

823 if db_server == 'mysql': 

824 self.query['createHandsPlayersTable'] = """CREATE TABLE HandsPlayers ( 

825 id BIGINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

826 handId BIGINT UNSIGNED NOT NULL, FOREIGN KEY (handId) REFERENCES Hands(id), 

827 playerId INT UNSIGNED NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

828 startCash BIGINT NOT NULL, 

829 effStack BIGINT NOT NULL, 

830 startBounty BIGINT, 

831 endBounty BIGINT, 

832 position CHAR(1), 

833 seatNo SMALLINT NOT NULL, 

834 sitout BOOLEAN NOT NULL, 

835  

836 card1 smallint NOT NULL, /* 0=none, 1-13=2-Ah 14-26=2-Ad 27-39=2-Ac 40-52=2-As */ 

837 card2 smallint NOT NULL, 

838 card3 smallint, 

839 card4 smallint, 

840 card5 smallint, 

841 card6 smallint, 

842 card7 smallint, 

843 card8 smallint, /* cards 8-20 for draw hands */ 

844 card9 smallint, 

845 card10 smallint, 

846 card11 smallint, 

847 card12 smallint, 

848 card13 smallint, 

849 card14 smallint, 

850 card15 smallint, 

851 card16 smallint, 

852 card17 smallint, 

853 card18 smallint, 

854 card19 smallint, 

855 card20 smallint, 

856 startCards SMALLINT UNSIGNED, FOREIGN KEY (startCards) REFERENCES StartCards(id), 

857  

858 common BIGINT NOT NULL, 

859 committed BIGINT NOT NULL,  

860 winnings BIGINT NOT NULL, 

861 rake BIGINT NOT NULL, 

862 rakeDealt NUMERIC NOT NULL, 

863 rakeContributed NUMERIC NOT NULL, 

864 rakeWeighted NUMERIC NOT NULL, 

865 totalProfit BIGINT, 

866 allInEV NUMERIC, 

867 comment text, 

868 commentTs DATETIME, 

869 tourneysPlayersId BIGINT UNSIGNED, FOREIGN KEY (tourneysPlayersId) REFERENCES TourneysPlayers(id), 

870 

871 wonWhenSeenStreet1 BOOLEAN, 

872 wonWhenSeenStreet2 BOOLEAN, 

873 wonWhenSeenStreet3 BOOLEAN, 

874 wonWhenSeenStreet4 BOOLEAN, 

875 wonAtSD BOOLEAN, 

876  

877 street0VPIChance BOOLEAN, 

878 street0VPI BOOLEAN, 

879 street0AggrChance BOOLEAN, 

880 street0Aggr BOOLEAN, 

881 street0CalledRaiseChance TINYINT, 

882 street0CalledRaiseDone TINYINT, 

883 street0_2BChance BOOLEAN, 

884 street0_2BDone BOOLEAN, 

885 street0_3BChance BOOLEAN, 

886 street0_3BDone BOOLEAN, 

887 street0_4BChance BOOLEAN, 

888 street0_C4BChance BOOLEAN, 

889 street0_4BDone BOOLEAN, 

890 street0_C4BDone BOOLEAN, 

891 street0_FoldTo2BChance BOOLEAN, 

892 street0_FoldTo2BDone BOOLEAN, 

893 street0_FoldTo3BChance BOOLEAN, 

894 street0_FoldTo3BDone BOOLEAN, 

895 street0_FoldTo4BChance BOOLEAN, 

896 street0_FoldTo4BDone BOOLEAN, 

897 street0_SqueezeChance BOOLEAN, 

898 street0_SqueezeDone BOOLEAN, 

899 

900 raiseToStealChance BOOLEAN, 

901 raiseToStealDone BOOLEAN, 

902 stealChance BOOLEAN, 

903 stealDone BOOLEAN, 

904 success_Steal BOOLEAN, 

905 

906 street1Seen BOOLEAN, 

907 street2Seen BOOLEAN, 

908 street3Seen BOOLEAN, 

909 street4Seen BOOLEAN, 

910 sawShowdown BOOLEAN, 

911 showed BOOLEAN, 

912  

913 street0AllIn BOOLEAN, 

914 street1AllIn BOOLEAN, 

915 street2AllIn BOOLEAN, 

916 street3AllIn BOOLEAN, 

917 street4AllIn BOOLEAN, 

918 wentAllIn BOOLEAN, 

919  

920 street0InPosition BOOLEAN, 

921 street1InPosition BOOLEAN, 

922 street2InPosition BOOLEAN, 

923 street3InPosition BOOLEAN, 

924 street4InPosition BOOLEAN, 

925 street0FirstToAct BOOLEAN, 

926 street1FirstToAct BOOLEAN, 

927 street2FirstToAct BOOLEAN, 

928 street3FirstToAct BOOLEAN, 

929 street4FirstToAct BOOLEAN, 

930 

931 street1Aggr BOOLEAN, 

932 street2Aggr BOOLEAN, 

933 street3Aggr BOOLEAN, 

934 street4Aggr BOOLEAN, 

935 

936 otherRaisedStreet0 BOOLEAN, 

937 otherRaisedStreet1 BOOLEAN, 

938 otherRaisedStreet2 BOOLEAN, 

939 otherRaisedStreet3 BOOLEAN, 

940 otherRaisedStreet4 BOOLEAN, 

941 foldToOtherRaisedStreet0 BOOLEAN, 

942 foldToOtherRaisedStreet1 BOOLEAN, 

943 foldToOtherRaisedStreet2 BOOLEAN, 

944 foldToOtherRaisedStreet3 BOOLEAN, 

945 foldToOtherRaisedStreet4 BOOLEAN, 

946 

947 raiseFirstInChance BOOLEAN, 

948 raisedFirstIn BOOLEAN, 

949 foldBbToStealChance BOOLEAN, 

950 foldedBbToSteal BOOLEAN, 

951 foldSbToStealChance BOOLEAN, 

952 foldedSbToSteal BOOLEAN, 

953 

954 street1CBChance BOOLEAN, 

955 street1CBDone BOOLEAN, 

956 street2CBChance BOOLEAN, 

957 street2CBDone BOOLEAN, 

958 street3CBChance BOOLEAN, 

959 street3CBDone BOOLEAN, 

960 street4CBChance BOOLEAN, 

961 street4CBDone BOOLEAN, 

962 

963 foldToStreet1CBChance BOOLEAN, 

964 foldToStreet1CBDone BOOLEAN, 

965 foldToStreet2CBChance BOOLEAN, 

966 foldToStreet2CBDone BOOLEAN, 

967 foldToStreet3CBChance BOOLEAN, 

968 foldToStreet3CBDone BOOLEAN, 

969 foldToStreet4CBChance BOOLEAN, 

970 foldToStreet4CBDone BOOLEAN, 

971 

972 street1CheckCallRaiseChance BOOLEAN, 

973 street1CheckCallDone BOOLEAN, 

974 street1CheckRaiseDone BOOLEAN, 

975 street2CheckCallRaiseChance BOOLEAN, 

976 street2CheckCallDone BOOLEAN, 

977 street2CheckRaiseDone BOOLEAN, 

978 street3CheckCallRaiseChance BOOLEAN, 

979 street3CheckCallDone BOOLEAN, 

980 street3CheckRaiseDone BOOLEAN, 

981 street4CheckCallRaiseChance BOOLEAN, 

982 street4CheckCallDone BOOLEAN, 

983 street4CheckRaiseDone BOOLEAN, 

984 

985 street0Calls TINYINT, 

986 street1Calls TINYINT, 

987 street2Calls TINYINT, 

988 street3Calls TINYINT, 

989 street4Calls TINYINT, 

990 street0Bets TINYINT, 

991 street1Bets TINYINT, 

992 street2Bets TINYINT, 

993 street3Bets TINYINT, 

994 street4Bets TINYINT, 

995 street0Raises TINYINT, 

996 street1Raises TINYINT, 

997 street2Raises TINYINT, 

998 street3Raises TINYINT, 

999 street4Raises TINYINT, 

1000 street1Discards TINYINT, 

1001 street2Discards TINYINT, 

1002 street3Discards TINYINT, 

1003  

1004 handString TEXT, 

1005 actionString VARCHAR(15)) 

1006 ENGINE=INNODB""" 

1007 elif db_server == 'postgresql': 

1008 self.query['createHandsPlayersTable'] = """CREATE TABLE HandsPlayers ( 

1009 id BIGSERIAL, PRIMARY KEY (id), 

1010 handId BIGINT NOT NULL, FOREIGN KEY (handId) REFERENCES Hands(id), 

1011 playerId INT NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

1012 startCash BIGINT NOT NULL, 

1013 effStack BIGINT NOT NULL, 

1014 startBounty BIGINT, 

1015 endBounty BIGINT, 

1016 position CHAR(1), 

1017 seatNo SMALLINT NOT NULL, 

1018 sitout BOOLEAN NOT NULL, 

1019 

1020 card1 smallint NOT NULL, /* 0=none, 1-13=2-Ah 14-26=2-Ad 27-39=2-Ac 40-52=2-As */ 

1021 card2 smallint NOT NULL, 

1022 card3 smallint, 

1023 card4 smallint, 

1024 card5 smallint, 

1025 card6 smallint, 

1026 card7 smallint, 

1027 card8 smallint, /* cards 8-20 for draw hands */ 

1028 card9 smallint, 

1029 card10 smallint, 

1030 card11 smallint, 

1031 card12 smallint, 

1032 card13 smallint, 

1033 card14 smallint, 

1034 card15 smallint, 

1035 card16 smallint, 

1036 card17 smallint, 

1037 card18 smallint, 

1038 card19 smallint, 

1039 card20 smallint,  

1040 startCards smallint, FOREIGN KEY (startCards) REFERENCES StartCards(id), 

1041 

1042 common BIGINT NOT NULL, 

1043 committed BIGINT NOT NULL, 

1044 winnings BIGINT NOT NULL, 

1045 rake BIGINT NOT NULL, 

1046 rakeDealt NUMERIC NOT NULL, 

1047 rakeContributed NUMERIC NOT NULL, 

1048 rakeWeighted NUMERIC NOT NULL, 

1049 totalProfit BIGINT, 

1050 allInEV NUMERIC, 

1051 comment text, 

1052 commentTs timestamp without time zone, 

1053 tourneysPlayersId BIGINT, FOREIGN KEY (tourneysPlayersId) REFERENCES TourneysPlayers(id), 

1054 

1055 wonWhenSeenStreet1 BOOLEAN, 

1056 wonWhenSeenStreet2 BOOLEAN, 

1057 wonWhenSeenStreet3 BOOLEAN, 

1058 wonWhenSeenStreet4 BOOLEAN, 

1059 wonAtSD BOOLEAN, 

1060 

1061 street0VPIChance BOOLEAN, 

1062 street0VPI BOOLEAN, 

1063 street0AggrChance BOOLEAN, 

1064 street0Aggr BOOLEAN, 

1065 street0CalledRaiseChance SMALLINT, 

1066 street0CalledRaiseDone SMALLINT, 

1067 street0_2BChance BOOLEAN, 

1068 street0_2BDone BOOLEAN, 

1069 street0_3BChance BOOLEAN, 

1070 street0_3BDone BOOLEAN, 

1071 street0_4BChance BOOLEAN, 

1072 street0_4BDone BOOLEAN, 

1073 street0_C4BChance BOOLEAN, 

1074 street0_C4BDone BOOLEAN, 

1075 street0_FoldTo2BChance BOOLEAN, 

1076 street0_FoldTo2BDone BOOLEAN, 

1077 street0_FoldTo3BChance BOOLEAN, 

1078 street0_FoldTo3BDone BOOLEAN, 

1079 street0_FoldTo4BChance BOOLEAN, 

1080 street0_FoldTo4BDone BOOLEAN, 

1081 street0_SqueezeChance BOOLEAN, 

1082 street0_SqueezeDone BOOLEAN, 

1083 

1084 raiseToStealChance BOOLEAN, 

1085 raiseToStealDone BOOLEAN, 

1086 stealChance BOOLEAN, 

1087 stealDone BOOLEAN, 

1088 success_Steal BOOLEAN, 

1089 

1090 street1Seen BOOLEAN, 

1091 street2Seen BOOLEAN, 

1092 street3Seen BOOLEAN, 

1093 street4Seen BOOLEAN, 

1094 sawShowdown BOOLEAN, 

1095 showed BOOLEAN, 

1096  

1097 street0AllIn BOOLEAN, 

1098 street1AllIn BOOLEAN, 

1099 street2AllIn BOOLEAN, 

1100 street3AllIn BOOLEAN, 

1101 street4AllIn BOOLEAN, 

1102 wentAllIn BOOLEAN, 

1103  

1104 street0InPosition BOOLEAN, 

1105 street1InPosition BOOLEAN, 

1106 street2InPosition BOOLEAN, 

1107 street3InPosition BOOLEAN, 

1108 street4InPosition BOOLEAN, 

1109 street0FirstToAct BOOLEAN, 

1110 street1FirstToAct BOOLEAN, 

1111 street2FirstToAct BOOLEAN, 

1112 street3FirstToAct BOOLEAN, 

1113 street4FirstToAct BOOLEAN, 

1114 

1115 street1Aggr BOOLEAN, 

1116 street2Aggr BOOLEAN, 

1117 street3Aggr BOOLEAN, 

1118 street4Aggr BOOLEAN, 

1119 

1120 otherRaisedStreet0 BOOLEAN, 

1121 otherRaisedStreet1 BOOLEAN, 

1122 otherRaisedStreet2 BOOLEAN, 

1123 otherRaisedStreet3 BOOLEAN, 

1124 otherRaisedStreet4 BOOLEAN, 

1125 foldToOtherRaisedStreet0 BOOLEAN, 

1126 foldToOtherRaisedStreet1 BOOLEAN, 

1127 foldToOtherRaisedStreet2 BOOLEAN, 

1128 foldToOtherRaisedStreet3 BOOLEAN, 

1129 foldToOtherRaisedStreet4 BOOLEAN, 

1130 

1131 raiseFirstInChance BOOLEAN, 

1132 raisedFirstIn BOOLEAN, 

1133 foldBbToStealChance BOOLEAN, 

1134 foldedBbToSteal BOOLEAN, 

1135 foldSbToStealChance BOOLEAN, 

1136 foldedSbToSteal BOOLEAN, 

1137 

1138 street1CBChance BOOLEAN, 

1139 street1CBDone BOOLEAN, 

1140 street2CBChance BOOLEAN, 

1141 street2CBDone BOOLEAN, 

1142 street3CBChance BOOLEAN, 

1143 street3CBDone BOOLEAN, 

1144 street4CBChance BOOLEAN, 

1145 street4CBDone BOOLEAN, 

1146 

1147 foldToStreet1CBChance BOOLEAN, 

1148 foldToStreet1CBDone BOOLEAN, 

1149 foldToStreet2CBChance BOOLEAN, 

1150 foldToStreet2CBDone BOOLEAN, 

1151 foldToStreet3CBChance BOOLEAN, 

1152 foldToStreet3CBDone BOOLEAN, 

1153 foldToStreet4CBChance BOOLEAN, 

1154 foldToStreet4CBDone BOOLEAN, 

1155 

1156 street1CheckCallRaiseChance BOOLEAN, 

1157 street1CheckCallDone BOOLEAN, 

1158 street1CheckRaiseDone BOOLEAN, 

1159 street2CheckCallRaiseChance BOOLEAN, 

1160 street2CheckCallDone BOOLEAN, 

1161 street2CheckRaiseDone BOOLEAN, 

1162 street3CheckCallRaiseChance BOOLEAN, 

1163 street3CheckCallDone BOOLEAN, 

1164 street3CheckRaiseDone BOOLEAN, 

1165 street4CheckCallRaiseChance BOOLEAN, 

1166 street4CheckCallDone BOOLEAN, 

1167 street4CheckRaiseDone BOOLEAN, 

1168 

1169 street0Calls SMALLINT, 

1170 street1Calls SMALLINT, 

1171 street2Calls SMALLINT, 

1172 street3Calls SMALLINT, 

1173 street4Calls SMALLINT, 

1174 street0Bets SMALLINT, 

1175 street1Bets SMALLINT, 

1176 street2Bets SMALLINT, 

1177 street3Bets SMALLINT, 

1178 street4Bets SMALLINT, 

1179 street0Raises SMALLINT, 

1180 street1Raises SMALLINT, 

1181 street2Raises SMALLINT, 

1182 street3Raises SMALLINT, 

1183 street4Raises SMALLINT, 

1184 street1Discards SMALLINT, 

1185 street2Discards SMALLINT, 

1186 street3Discards SMALLINT, 

1187  

1188 handString TEXT, 

1189 actionString VARCHAR(15))""" 

1190 elif db_server == 'sqlite': 

1191 self.query['createHandsPlayersTable'] = """CREATE TABLE HandsPlayers ( 

1192 id INTEGER PRIMARY KEY, 

1193 handId INT NOT NULL, 

1194 playerId INT NOT NULL, 

1195 startCash INT NOT NULL, 

1196 effStack INT NOT NULL, 

1197 startBounty INT, 

1198 endBounty INT, 

1199 position TEXT, 

1200 seatNo INT NOT NULL, 

1201 sitout BOOLEAN NOT NULL, 

1202  

1203 card1 INT NOT NULL, /* 0=none, 1-13=2-Ah 14-26=2-Ad 27-39=2-Ac 40-52=2-As */ 

1204 card2 INT NOT NULL, 

1205 card3 INT, 

1206 card4 INT, 

1207 card5 INT, 

1208 card6 INT, 

1209 card7 INT, 

1210 card8 INT, /* cards 8-20 for draw hands */ 

1211 card9 INT, 

1212 card10 INT, 

1213 card11 INT, 

1214 card12 INT, 

1215 card13 INT, 

1216 card14 INT, 

1217 card15 INT, 

1218 card16 INT, 

1219 card17 INT, 

1220 card18 INT, 

1221 card19 INT, 

1222 card20 INT, 

1223 startCards INT, 

1224  

1225 common INT NOT NULL, 

1226 committed INT NOT NULL, 

1227 winnings INT NOT NULL, 

1228 rake INT NOT NULL, 

1229 rakeDealt decimal NOT NULL, 

1230 rakeContributed decimal NOT NULL, 

1231 rakeWeighted decimal NOT NULL, 

1232 totalProfit INT, 

1233 allInEV decimal, 

1234 comment TEXT, 

1235 commentTs timestamp, 

1236 tourneysPlayersId INT, 

1237 

1238 wonWhenSeenStreet1 INT, 

1239 wonWhenSeenStreet2 INT, 

1240 wonWhenSeenStreet3 INT, 

1241 wonWhenSeenStreet4 INT, 

1242 wonAtSD INT, 

1243  

1244 street0VPIChance INT, 

1245 street0VPI INT, 

1246 street0AggrChance INT, 

1247 street0Aggr INT, 

1248 street0CalledRaiseChance INT, 

1249 street0CalledRaiseDone INT, 

1250 street0_2BChance INT, 

1251 street0_2BDone INT, 

1252 street0_3BChance INT, 

1253 street0_3BDone INT, 

1254 street0_4BChance INT, 

1255 street0_4BDone INT, 

1256 street0_C4BChance INT, 

1257 street0_C4BDone INT, 

1258 street0_FoldTo2BChance INT, 

1259 street0_FoldTo2BDone INT, 

1260 street0_FoldTo3BChance INT, 

1261 street0_FoldTo3BDone INT, 

1262 street0_FoldTo4BChance INT, 

1263 street0_FoldTo4BDone INT, 

1264 street0_SqueezeChance INT, 

1265 street0_SqueezeDone INT, 

1266 

1267 raiseToStealChance INT, 

1268 raiseToStealDone INT, 

1269 stealChance INT, 

1270 stealDone INT, 

1271 success_Steal INT, 

1272 

1273 street1Seen INT, 

1274 street2Seen INT, 

1275 street3Seen INT, 

1276 street4Seen INT, 

1277 sawShowdown INT, 

1278 showed INT, 

1279  

1280 street0AllIn INT, 

1281 street1AllIn INT, 

1282 street2AllIn INT, 

1283 street3AllIn INT, 

1284 street4AllIn INT, 

1285 wentAllIn INT, 

1286  

1287 street0InPosition INT, 

1288 street1InPosition INT, 

1289 street2InPosition INT, 

1290 street3InPosition INT, 

1291 street4InPosition INT, 

1292 street0FirstToAct INT, 

1293 street1FirstToAct INT, 

1294 street2FirstToAct INT, 

1295 street3FirstToAct INT, 

1296 street4FirstToAct INT, 

1297 

1298 street1Aggr INT, 

1299 street2Aggr INT, 

1300 street3Aggr INT, 

1301 street4Aggr INT, 

1302 

1303 otherRaisedStreet0 INT, 

1304 otherRaisedStreet1 INT, 

1305 otherRaisedStreet2 INT, 

1306 otherRaisedStreet3 INT, 

1307 otherRaisedStreet4 INT, 

1308 foldToOtherRaisedStreet0 INT, 

1309 foldToOtherRaisedStreet1 INT, 

1310 foldToOtherRaisedStreet2 INT, 

1311 foldToOtherRaisedStreet3 INT, 

1312 foldToOtherRaisedStreet4 INT, 

1313 

1314 raiseFirstInChance INT, 

1315 raisedFirstIn INT, 

1316 foldBbToStealChance INT, 

1317 foldedBbToSteal INT, 

1318 foldSbToStealChance INT, 

1319 foldedSbToSteal INT, 

1320 

1321 street1CBChance INT, 

1322 street1CBDone INT, 

1323 street2CBChance INT, 

1324 street2CBDone INT, 

1325 street3CBChance INT, 

1326 street3CBDone INT, 

1327 street4CBChance INT, 

1328 street4CBDone INT, 

1329 

1330 foldToStreet1CBChance INT, 

1331 foldToStreet1CBDone INT, 

1332 foldToStreet2CBChance INT, 

1333 foldToStreet2CBDone INT, 

1334 foldToStreet3CBChance INT, 

1335 foldToStreet3CBDone INT, 

1336 foldToStreet4CBChance INT, 

1337 foldToStreet4CBDone INT, 

1338 

1339 street1CheckCallRaiseChance INT, 

1340 street1CheckCallDone INT, 

1341 street1CheckRaiseDone INT, 

1342 street2CheckCallRaiseChance INT, 

1343 street2CheckCallDone INT, 

1344 street2CheckRaiseDone INT, 

1345 street3CheckCallRaiseChance INT, 

1346 street3CheckCallDone INT, 

1347 street3CheckRaiseDone INT, 

1348 street4CheckCallRaiseChance INT, 

1349 street4CheckCallDone INT, 

1350 street4CheckRaiseDone INT, 

1351 

1352 street0Calls INT, 

1353 street1Calls INT, 

1354 street2Calls INT, 

1355 street3Calls INT, 

1356 street4Calls INT, 

1357 street0Bets INT, 

1358 street1Bets INT, 

1359 street2Bets INT, 

1360 street3Bets INT, 

1361 street4Bets INT, 

1362 street0Raises INT, 

1363 street1Raises INT, 

1364 street2Raises INT, 

1365 street3Raises INT, 

1366 street4Raises INT, 

1367 street1Discards INT, 

1368 street2Discards INT, 

1369 street3Discards INT, 

1370  

1371 handString TEXT, 

1372 actionString VARCHAR(15)) 

1373 """ 

1374 

1375 

1376 ################################ 

1377 # Create TourneysPlayers 

1378 ################################ 

1379 

1380 if db_server == 'mysql': 

1381 self.query['createTourneysPlayersTable'] = """CREATE TABLE TourneysPlayers ( 

1382 id BIGINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

1383 tourneyId INT UNSIGNED NOT NULL, FOREIGN KEY (tourneyId) REFERENCES Tourneys(id), 

1384 playerId INT UNSIGNED NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

1385 entryId INT, 

1386 rank INT, 

1387 winnings BIGINT, 

1388 winningsCurrency VARCHAR(4), 

1389 rebuyCount INT, 

1390 addOnCount INT, 

1391 koCount NUMERIC, 

1392 comment TEXT, 

1393 commentTs DATETIME) 

1394 ENGINE=INNODB""" 

1395 elif db_server == 'postgresql': 

1396 self.query['createTourneysPlayersTable'] = """CREATE TABLE TourneysPlayers ( 

1397 id BIGSERIAL, PRIMARY KEY (id), 

1398 tourneyId INT, FOREIGN KEY (tourneyId) REFERENCES Tourneys(id), 

1399 playerId INT, FOREIGN KEY (playerId) REFERENCES Players(id), 

1400 entryId INT, 

1401 rank INT, 

1402 winnings BIGINT, 

1403 winningsCurrency VARCHAR(4), 

1404 rebuyCount INT, 

1405 addOnCount INT, 

1406 koCount NUMERIC, 

1407 comment TEXT, 

1408 commentTs timestamp without time zone)""" 

1409 elif db_server == 'sqlite': 

1410 self.query['createTourneysPlayersTable'] = """CREATE TABLE TourneysPlayers ( 

1411 id INTEGER PRIMARY KEY, 

1412 tourneyId INT, 

1413 playerId INT, 

1414 entryId INT, 

1415 rank INT, 

1416 winnings INT, 

1417 winningsCurrency VARCHAR(4), 

1418 rebuyCount INT, 

1419 addOnCount INT, 

1420 koCount decimal, 

1421 comment TEXT, 

1422 commentTs timestamp, 

1423 FOREIGN KEY (tourneyId) REFERENCES Tourneys(id), 

1424 FOREIGN KEY (playerId) REFERENCES Players(id) 

1425 )""" 

1426 

1427 

1428 ################################ 

1429 # Create HandsActions 

1430 ################################ 

1431 

1432 if db_server == 'mysql': 

1433 self.query['createHandsActionsTable'] = """CREATE TABLE HandsActions ( 

1434 id BIGINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

1435 handId BIGINT UNSIGNED NOT NULL, FOREIGN KEY (handId) REFERENCES Hands(id), 

1436 playerId INT UNSIGNED NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

1437 street SMALLINT NOT NULL, 

1438 actionNo SMALLINT NOT NULL, 

1439 streetActionNo SMALLINT NOT NULL, 

1440 actionId SMALLINT UNSIGNED NOT NULL, FOREIGN KEY (actionId) REFERENCES Actions(id), 

1441 amount BIGINT NOT NULL, 

1442 raiseTo BIGINT NOT NULL, 

1443 amountCalled BIGINT NOT NULL, 

1444 numDiscarded SMALLINT NOT NULL, 

1445 cardsDiscarded varchar(14), 

1446 allIn BOOLEAN NOT NULL) 

1447 ENGINE=INNODB""" 

1448 elif db_server == 'postgresql': 

1449 self.query['createHandsActionsTable'] = """CREATE TABLE HandsActions ( 

1450 id BIGSERIAL, PRIMARY KEY (id), 

1451 handId BIGINT NOT NULL, FOREIGN KEY (handId) REFERENCES Hands(id), 

1452 playerId INT NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

1453 street SMALLINT, 

1454 actionNo SMALLINT, 

1455 streetActionNo SMALLINT, 

1456 actionId SMALLINT, FOREIGN KEY (actionId) REFERENCES Actions(id), 

1457 amount BIGINT, 

1458 raiseTo BIGINT, 

1459 amountCalled BIGINT, 

1460 numDiscarded SMALLINT, 

1461 cardsDiscarded varchar(14), 

1462 allIn BOOLEAN)""" 

1463 elif db_server == 'sqlite': 

1464 self.query['createHandsActionsTable'] = """CREATE TABLE HandsActions ( 

1465 id INTEGER PRIMARY KEY, 

1466 handId INT NOT NULL, 

1467 playerId INT NOT NULL, 

1468 street SMALLINT, 

1469 actionNo SMALLINT, 

1470 streetActionNo SMALLINT, 

1471 actionId SMALLINT, 

1472 amount INT, 

1473 raiseTo INT, 

1474 amountCalled INT, 

1475 numDiscarded SMALLINT, 

1476 cardsDiscarded TEXT, 

1477 allIn BOOLEAN 

1478 )""" 

1479 

1480 

1481 ################################ 

1482 # Create HandsStove 

1483 ################################ 

1484 

1485 if db_server == 'mysql': 

1486 self.query['createHandsStoveTable'] = """CREATE TABLE HandsStove ( 

1487 id BIGINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

1488 handId BIGINT UNSIGNED NOT NULL, FOREIGN KEY (handId) REFERENCES Hands(id), 

1489 playerId INT UNSIGNED NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

1490 streetId SMALLINT, 

1491 boardId SMALLINT, 

1492 hiLo char(1) NOT NULL, 

1493 rankId SMALLINT UNSIGNED NOT NULL, FOREIGN KEY (rankId) REFERENCES Rank(id), 

1494 value BIGINT, 

1495 cards VARCHAR(5), 

1496 ev NUMERIC) 

1497 ENGINE=INNODB""" 

1498 elif db_server == 'postgresql': 

1499 self.query['createHandsStoveTable'] = """CREATE TABLE HandsStove ( 

1500 id BIGSERIAL, PRIMARY KEY (id), 

1501 handId BIGINT NOT NULL, FOREIGN KEY (handId) REFERENCES Hands(id), 

1502 playerId INT NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

1503 streetId SMALLINT, 

1504 boardId SMALLINT, 

1505 hiLo char(1) NOT NULL, 

1506 rankId SMALLINT NOT NULL, FOREIGN KEY (rankId) REFERENCES Rank(id), 

1507 value BIGINT, 

1508 cards VARCHAR(5), 

1509 ev NUMERIC)""" 

1510 elif db_server == 'sqlite': 

1511 self.query['createHandsStoveTable'] = """CREATE TABLE HandsStove ( 

1512 id INTEGER PRIMARY KEY, 

1513 handId INT NOT NULL, 

1514 playerId INT NOT NULL, 

1515 streetId INT, 

1516 boardId INT, 

1517 hiLo TEXT NOT NULL, 

1518 rankId INT, 

1519 value INT, 

1520 cards TEXT, 

1521 ev decimal 

1522 )""" 

1523 

1524 ################################ 

1525 # Create HandsPots 

1526 ################################ 

1527 

1528 if db_server == 'mysql': 

1529 self.query['createHandsPotsTable'] = """CREATE TABLE HandsPots ( 

1530 id BIGINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

1531 handId BIGINT UNSIGNED NOT NULL, FOREIGN KEY (handId) REFERENCES Hands(id), 

1532 potId SMALLINT, 

1533 boardId SMALLINT, 

1534 hiLo char(1) NOT NULL, 

1535 playerId INT UNSIGNED NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

1536 pot BIGINT, 

1537 collected BIGINT, 

1538 rake INT) 

1539 ENGINE=INNODB""" 

1540 elif db_server == 'postgresql': 

1541 self.query['createHandsPotsTable'] = """CREATE TABLE HandsPots ( 

1542 id BIGSERIAL, PRIMARY KEY (id), 

1543 handId BIGINT NOT NULL, FOREIGN KEY (handId) REFERENCES Hands(id), 

1544 potId SMALLINT, 

1545 boardId SMALLINT, 

1546 hiLo char(1) NOT NULL, 

1547 playerId INT NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

1548 pot BIGINT, 

1549 collected BIGINT, 

1550 rake INT)""" 

1551 elif db_server == 'sqlite': 

1552 self.query['createHandsPotsTable'] = """CREATE TABLE HandsPots ( 

1553 id INTEGER PRIMARY KEY, 

1554 handId INT NOT NULL, 

1555 potId INT, 

1556 boardId INT, 

1557 hiLo TEXT NOT NULL, 

1558 playerId INT NOT NULL, 

1559 pot INT, 

1560 collected INT, 

1561 rake INT 

1562 )""" 

1563 

1564 ################################ 

1565 # Create Files 

1566 ################################ 

1567 

1568 if db_server == 'mysql': 

1569 self.query['createFilesTable'] = """CREATE TABLE Files ( 

1570 id INT(10) UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

1571 file text NOT NULL, 

1572 site VARCHAR(32), 

1573 type VARCHAR(7), 

1574 startTime DATETIME NOT NULL, 

1575 lastUpdate DATETIME NOT NULL, 

1576 endTime DATETIME, 

1577 hands INT, 

1578 storedHands INT, 

1579 dups INT, 

1580 partial INT, 

1581 skipped INT, 

1582 errs INT, 

1583 ttime100 INT, 

1584 finished BOOLEAN) 

1585 ENGINE=INNODB""" 

1586 elif db_server == 'postgresql': 

1587 self.query['createFilesTable'] = """CREATE TABLE Files ( 

1588 id BIGSERIAL, PRIMARY KEY (id), 

1589 file TEXT NOT NULL, 

1590 site VARCHAR(32), 

1591 type VARCHAR(7), 

1592 startTime timestamp without time zone NOT NULL, 

1593 lastUpdate timestamp without time zone NOT NULL, 

1594 endTime timestamp without time zone, 

1595 hands INT, 

1596 storedHands INT, 

1597 dups INT, 

1598 partial INT, 

1599 skipped INT, 

1600 errs INT, 

1601 ttime100 INT, 

1602 finished BOOLEAN)""" 

1603 elif db_server == 'sqlite': 

1604 self.query['createFilesTable'] = """CREATE TABLE Files ( 

1605 id INTEGER PRIMARY KEY, 

1606 file TEXT NOT NULL, 

1607 site VARCHAR(32), 

1608 type VARCHAR(7), 

1609 startTime timestamp NOT NULL, 

1610 lastUpdate timestamp NOT NULL, 

1611 endTime timestamp, 

1612 hands INT, 

1613 storedHands INT, 

1614 dups INT, 

1615 partial INT, 

1616 skipped INT, 

1617 errs INT, 

1618 ttime100 INT, 

1619 finished BOOLEAN 

1620 )""" 

1621 

1622 ################################ 

1623 # Create HudCache 

1624 ################################ 

1625 

1626 if db_server == 'mysql': 

1627 self.query['createHudCacheTable'] = """CREATE TABLE HudCache ( 

1628 id BIGINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

1629 gametypeId SMALLINT UNSIGNED NOT NULL, FOREIGN KEY (gametypeId) REFERENCES Gametypes(id), 

1630 playerId INT UNSIGNED NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

1631 seats SMALLINT NOT NULL, 

1632 position CHAR(1), 

1633 tourneyTypeId SMALLINT UNSIGNED, FOREIGN KEY (tourneyTypeId) REFERENCES TourneyTypes(id), 

1634 styleKey CHAR(7) NOT NULL, /* 1st char is style (A/T/H/S), other 6 are the key */ 

1635 n INT NOT NULL,  

1636 street0VPIChance INT, 

1637 street0VPI INT, 

1638 street0AggrChance INT, 

1639 street0Aggr INT, 

1640 street0CalledRaiseChance INT, 

1641 street0CalledRaiseDone INT, 

1642 street0_2BChance INT, 

1643 street0_2BDone INT, 

1644 street0_3BChance INT, 

1645 street0_3BDone INT, 

1646 street0_4BChance INT, 

1647 street0_4BDone INT, 

1648 street0_C4BChance INT, 

1649 street0_C4BDone INT, 

1650 street0_FoldTo2BChance INT, 

1651 street0_FoldTo2BDone INT, 

1652 street0_FoldTo3BChance INT, 

1653 street0_FoldTo3BDone INT, 

1654 street0_FoldTo4BChance INT, 

1655 street0_FoldTo4BDone INT, 

1656 street0_SqueezeChance INT, 

1657 street0_SqueezeDone INT, 

1658 raiseToStealChance INT, 

1659 raiseToStealDone INT, 

1660 stealChance INT, 

1661 stealDone INT, 

1662 success_Steal INT, 

1663 street1Seen INT, 

1664 street2Seen INT, 

1665 street3Seen INT, 

1666 street4Seen INT, 

1667 sawShowdown INT,  

1668 street1Aggr INT, 

1669 street2Aggr INT, 

1670 street3Aggr INT, 

1671 street4Aggr INT, 

1672 otherRaisedStreet0 INT, 

1673 otherRaisedStreet1 INT, 

1674 otherRaisedStreet2 INT, 

1675 otherRaisedStreet3 INT, 

1676 otherRaisedStreet4 INT, 

1677 foldToOtherRaisedStreet0 INT, 

1678 foldToOtherRaisedStreet1 INT, 

1679 foldToOtherRaisedStreet2 INT, 

1680 foldToOtherRaisedStreet3 INT, 

1681 foldToOtherRaisedStreet4 INT, 

1682 wonWhenSeenStreet1 INT, 

1683 wonWhenSeenStreet2 INT, 

1684 wonWhenSeenStreet3 INT, 

1685 wonWhenSeenStreet4 INT, 

1686 wonAtSD INT,  

1687 raiseFirstInChance INT, 

1688 raisedFirstIn INT, 

1689 foldBbToStealChance INT, 

1690 foldedBbToSteal INT, 

1691 foldSbToStealChance INT, 

1692 foldedSbToSteal INT, 

1693 street1CBChance INT, 

1694 street1CBDone INT, 

1695 street2CBChance INT, 

1696 street2CBDone INT, 

1697 street3CBChance INT, 

1698 street3CBDone INT, 

1699 street4CBChance INT, 

1700 street4CBDone INT,  

1701 foldToStreet1CBChance INT, 

1702 foldToStreet1CBDone INT, 

1703 foldToStreet2CBChance INT, 

1704 foldToStreet2CBDone INT, 

1705 foldToStreet3CBChance INT, 

1706 foldToStreet3CBDone INT, 

1707 foldToStreet4CBChance INT, 

1708 foldToStreet4CBDone INT,  

1709 common BIGINT, 

1710 committed BIGINT, 

1711 winnings BIGINT, 

1712 rake BIGINT, 

1713 rakeDealt NUMERIC, 

1714 rakeContributed NUMERIC, 

1715 rakeWeighted NUMERIC, 

1716 totalProfit BIGINT, 

1717 allInEV NUMERIC, 

1718 showdownWinnings BIGINT, 

1719 nonShowdownWinnings BIGINT,  

1720 street1CheckCallRaiseChance INT, 

1721 street1CheckCallDone INT, 

1722 street1CheckRaiseDone INT, 

1723 street2CheckCallRaiseChance INT, 

1724 street2CheckCallDone INT, 

1725 street2CheckRaiseDone INT, 

1726 street3CheckCallRaiseChance INT, 

1727 street3CheckCallDone INT, 

1728 street3CheckRaiseDone INT, 

1729 street4CheckCallRaiseChance INT, 

1730 street4CheckCallDone INT, 

1731 street4CheckRaiseDone INT, 

1732 street0Calls INT, 

1733 street1Calls INT, 

1734 street2Calls INT, 

1735 street3Calls INT, 

1736 street4Calls INT, 

1737 street0Bets INT, 

1738 street1Bets INT, 

1739 street2Bets INT, 

1740 street3Bets INT, 

1741 street4Bets INT, 

1742 street0Raises INT, 

1743 street1Raises INT, 

1744 street2Raises INT, 

1745 street3Raises INT, 

1746 street4Raises INT,  

1747 street1Discards INT, 

1748 street2Discards INT, 

1749 street3Discards INT) 

1750 ENGINE=INNODB""" 

1751 elif db_server == 'postgresql': 

1752 self.query['createHudCacheTable'] = """CREATE TABLE HudCache ( 

1753 id BIGSERIAL, PRIMARY KEY (id), 

1754 gametypeId INT, FOREIGN KEY (gametypeId) REFERENCES Gametypes(id), 

1755 playerId INT, FOREIGN KEY (playerId) REFERENCES Players(id), 

1756 seats SMALLINT, 

1757 position CHAR(1), 

1758 tourneyTypeId INT, FOREIGN KEY (tourneyTypeId) REFERENCES TourneyTypes(id), 

1759 styleKey CHAR(7) NOT NULL, /* 1st char is style (A/T/H/S), other 6 are the key */ 

1760 n INT,  

1761 street0VPIChance INT, 

1762 street0VPI INT, 

1763 street0AggrChance INT, 

1764 street0Aggr INT, 

1765 street0CalledRaiseChance INT, 

1766 street0CalledRaiseDone INT, 

1767 street0_2BChance INT, 

1768 street0_2BDone INT, 

1769 street0_3BChance INT, 

1770 street0_3BDone INT, 

1771 street0_4BChance INT, 

1772 street0_4BDone INT, 

1773 street0_C4BChance INT, 

1774 street0_C4BDone INT, 

1775 street0_FoldTo2BChance INT, 

1776 street0_FoldTo2BDone INT, 

1777 street0_FoldTo3BChance INT, 

1778 street0_FoldTo3BDone INT, 

1779 street0_FoldTo4BChance INT, 

1780 street0_FoldTo4BDone INT, 

1781 street0_SqueezeChance INT, 

1782 street0_SqueezeDone INT, 

1783 raiseToStealChance INT, 

1784 raiseToStealDone INT, 

1785 stealChance INT, 

1786 stealDone INT, 

1787 success_Steal INT, 

1788 street1Seen INT, 

1789 street2Seen INT, 

1790 street3Seen INT, 

1791 street4Seen INT, 

1792 sawShowdown INT, 

1793 street1Aggr INT, 

1794 street2Aggr INT, 

1795 street3Aggr INT, 

1796 street4Aggr INT, 

1797 otherRaisedStreet0 INT, 

1798 otherRaisedStreet1 INT, 

1799 otherRaisedStreet2 INT, 

1800 otherRaisedStreet3 INT, 

1801 otherRaisedStreet4 INT, 

1802 foldToOtherRaisedStreet0 INT, 

1803 foldToOtherRaisedStreet1 INT, 

1804 foldToOtherRaisedStreet2 INT, 

1805 foldToOtherRaisedStreet3 INT, 

1806 foldToOtherRaisedStreet4 INT, 

1807 wonWhenSeenStreet1 INT, 

1808 wonWhenSeenStreet2 INT, 

1809 wonWhenSeenStreet3 INT, 

1810 wonWhenSeenStreet4 INT, 

1811 wonAtSD INT, 

1812 raiseFirstInChance INT, 

1813 raisedFirstIn INT, 

1814 foldBbToStealChance INT, 

1815 foldedBbToSteal INT, 

1816 foldSbToStealChance INT, 

1817 foldedSbToSteal INT, 

1818 street1CBChance INT, 

1819 street1CBDone INT, 

1820 street2CBChance INT, 

1821 street2CBDone INT, 

1822 street3CBChance INT, 

1823 street3CBDone INT, 

1824 street4CBChance INT, 

1825 street4CBDone INT, 

1826 foldToStreet1CBChance INT, 

1827 foldToStreet1CBDone INT, 

1828 foldToStreet2CBChance INT, 

1829 foldToStreet2CBDone INT, 

1830 foldToStreet3CBChance INT, 

1831 foldToStreet3CBDone INT, 

1832 foldToStreet4CBChance INT, 

1833 foldToStreet4CBDone INT, 

1834 common BIGINT, 

1835 committed BIGINT, 

1836 winnings BIGINT, 

1837 rake BIGINT, 

1838 rakeDealt NUMERIC, 

1839 rakeContributed NUMERIC, 

1840 rakeWeighted NUMERIC, 

1841 totalProfit BIGINT, 

1842 allInEV NUMERIC, 

1843 showdownWinnings BIGINT, 

1844 nonShowdownWinnings BIGINT, 

1845 street1CheckCallRaiseChance INT, 

1846 street1CheckCallDone INT, 

1847 street1CheckRaiseDone INT, 

1848 street2CheckCallRaiseChance INT, 

1849 street2CheckCallDone INT, 

1850 street2CheckRaiseDone INT, 

1851 street3CheckCallRaiseChance INT, 

1852 street3CheckCallDone INT, 

1853 street3CheckRaiseDone INT, 

1854 street4CheckCallRaiseChance INT, 

1855 street4CheckCallDone INT, 

1856 street4CheckRaiseDone INT, 

1857 street0Calls INT, 

1858 street1Calls INT, 

1859 street2Calls INT, 

1860 street3Calls INT, 

1861 street4Calls INT, 

1862 street0Bets INT, 

1863 street1Bets INT, 

1864 street2Bets INT, 

1865 street3Bets INT, 

1866 street4Bets INT, 

1867 street0Raises INT, 

1868 street1Raises INT, 

1869 street2Raises INT, 

1870 street3Raises INT, 

1871 street4Raises INT, 

1872 street1Discards INT, 

1873 street2Discards INT, 

1874 street3Discards INT) 

1875 """ 

1876 elif db_server == 'sqlite': 

1877 self.query['createHudCacheTable'] = """CREATE TABLE HudCache ( 

1878 id INTEGER PRIMARY KEY, 

1879 gametypeId INT, 

1880 playerId INT, 

1881 seats INT, 

1882 position TEXT, 

1883 tourneyTypeId INT, 

1884 styleKey TEXT NOT NULL, /* 1st char is style (A/T/H/S), other 6 are the key */ 

1885 n INT,  

1886 street0VPIChance INT, 

1887 street0VPI INT, 

1888 street0AggrChance INT, 

1889 street0Aggr INT, 

1890 street0CalledRaiseChance INT, 

1891 street0CalledRaiseDone INT, 

1892 street0_2BChance INT, 

1893 street0_2BDone INT, 

1894 street0_3BChance INT, 

1895 street0_3BDone INT, 

1896 street0_4BChance INT, 

1897 street0_4BDone INT, 

1898 street0_C4BChance INT, 

1899 street0_C4BDone INT, 

1900 street0_FoldTo2BChance INT, 

1901 street0_FoldTo2BDone INT, 

1902 street0_FoldTo3BChance INT, 

1903 street0_FoldTo3BDone INT, 

1904 street0_FoldTo4BChance INT, 

1905 street0_FoldTo4BDone INT, 

1906 street0_SqueezeChance INT, 

1907 street0_SqueezeDone INT, 

1908 raiseToStealChance INT, 

1909 raiseToStealDone INT, 

1910 stealChance INT, 

1911 stealDone INT, 

1912 success_Steal INT, 

1913 street1Seen INT, 

1914 street2Seen INT, 

1915 street3Seen INT, 

1916 street4Seen INT, 

1917 sawShowdown INT, 

1918 street1Aggr INT, 

1919 street2Aggr INT, 

1920 street3Aggr INT, 

1921 street4Aggr INT, 

1922 otherRaisedStreet0 INT, 

1923 otherRaisedStreet1 INT, 

1924 otherRaisedStreet2 INT, 

1925 otherRaisedStreet3 INT, 

1926 otherRaisedStreet4 INT, 

1927 foldToOtherRaisedStreet0 INT, 

1928 foldToOtherRaisedStreet1 INT, 

1929 foldToOtherRaisedStreet2 INT, 

1930 foldToOtherRaisedStreet3 INT, 

1931 foldToOtherRaisedStreet4 INT, 

1932 wonWhenSeenStreet1 INT, 

1933 wonWhenSeenStreet2 INT, 

1934 wonWhenSeenStreet3 INT, 

1935 wonWhenSeenStreet4 INT, 

1936 wonAtSD INT, 

1937 raiseFirstInChance INT, 

1938 raisedFirstIn INT, 

1939 foldBbToStealChance INT, 

1940 foldedBbToSteal INT, 

1941 foldSbToStealChance INT, 

1942 foldedSbToSteal INT, 

1943 street1CBChance INT, 

1944 street1CBDone INT, 

1945 street2CBChance INT, 

1946 street2CBDone INT, 

1947 street3CBChance INT, 

1948 street3CBDone INT, 

1949 street4CBChance INT, 

1950 street4CBDone INT, 

1951 foldToStreet1CBChance INT, 

1952 foldToStreet1CBDone INT, 

1953 foldToStreet2CBChance INT, 

1954 foldToStreet2CBDone INT, 

1955 foldToStreet3CBChance INT, 

1956 foldToStreet3CBDone INT, 

1957 foldToStreet4CBChance INT, 

1958 foldToStreet4CBDone INT, 

1959 common INT, 

1960 committed INT, 

1961 winnings INT, 

1962 rake INT, 

1963 rakeDealt decimal, 

1964 rakeContributed decimal, 

1965 rakeWeighted decimal, 

1966 totalProfit INT, 

1967 allInEV decimal, 

1968 showdownWinnings INT, 

1969 nonShowdownWinnings INT, 

1970 street1CheckCallRaiseChance INT, 

1971 street1CheckCallDone INT, 

1972 street1CheckRaiseDone INT, 

1973 street2CheckCallRaiseChance INT, 

1974 street2CheckCallDone INT, 

1975 street2CheckRaiseDone INT, 

1976 street3CheckCallRaiseChance INT, 

1977 street3CheckCallDone INT, 

1978 street3CheckRaiseDone INT, 

1979 street4CheckCallRaiseChance INT, 

1980 street4CheckCallDone INT, 

1981 street4CheckRaiseDone INT, 

1982 street0Calls INT, 

1983 street1Calls INT, 

1984 street2Calls INT, 

1985 street3Calls INT, 

1986 street4Calls INT, 

1987 street0Bets INT, 

1988 street1Bets INT, 

1989 street2Bets INT, 

1990 street3Bets INT, 

1991 street4Bets INT, 

1992 street0Raises INT, 

1993 street1Raises INT, 

1994 street2Raises INT, 

1995 street3Raises INT, 

1996 street4Raises INT, 

1997 street1Discards INT, 

1998 street2Discards INT, 

1999 street3Discards INT) 

2000 """ 

2001 

2002 ################################ 

2003 # Create CardsCache 

2004 ################################ 

2005 

2006 if db_server == 'mysql': 

2007 self.query['createCardsCacheTable'] = """CREATE TABLE CardsCache ( 

2008 id BIGINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

2009 weekId INT UNSIGNED, FOREIGN KEY (weekId) REFERENCES Weeks(id), 

2010 monthId INT UNSIGNED, FOREIGN KEY (monthId) REFERENCES Months(id), 

2011 gametypeId SMALLINT UNSIGNED, FOREIGN KEY (gametypeId) REFERENCES Gametypes(id), 

2012 tourneyTypeId SMALLINT UNSIGNED, FOREIGN KEY (tourneyTypeId) REFERENCES TourneyTypes(id), 

2013 playerId INT UNSIGNED NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

2014 startCards SMALLINT UNSIGNED NOT NULL, FOREIGN KEY (startCards) REFERENCES StartCards(id), 

2015 n INT NOT NULL,  

2016 street0VPIChance INT, 

2017 street0VPI INT, 

2018 street0AggrChance INT, 

2019 street0Aggr INT, 

2020 street0CalledRaiseChance INT, 

2021 street0CalledRaiseDone INT, 

2022 street0_2BChance INT, 

2023 street0_2BDone INT, 

2024 street0_3BChance INT, 

2025 street0_3BDone INT, 

2026 street0_4BChance INT, 

2027 street0_4BDone INT, 

2028 street0_C4BChance INT, 

2029 street0_C4BDone INT, 

2030 street0_FoldTo2BChance INT, 

2031 street0_FoldTo2BDone INT, 

2032 street0_FoldTo3BChance INT, 

2033 street0_FoldTo3BDone INT, 

2034 street0_FoldTo4BChance INT, 

2035 street0_FoldTo4BDone INT, 

2036 street0_SqueezeChance INT, 

2037 street0_SqueezeDone INT, 

2038 raiseToStealChance INT, 

2039 raiseToStealDone INT, 

2040 stealChance INT, 

2041 stealDone INT, 

2042 success_Steal INT, 

2043 street1Seen INT, 

2044 street2Seen INT, 

2045 street3Seen INT, 

2046 street4Seen INT, 

2047 sawShowdown INT,  

2048 street1Aggr INT, 

2049 street2Aggr INT, 

2050 street3Aggr INT, 

2051 street4Aggr INT, 

2052 otherRaisedStreet0 INT, 

2053 otherRaisedStreet1 INT, 

2054 otherRaisedStreet2 INT, 

2055 otherRaisedStreet3 INT, 

2056 otherRaisedStreet4 INT, 

2057 foldToOtherRaisedStreet0 INT, 

2058 foldToOtherRaisedStreet1 INT, 

2059 foldToOtherRaisedStreet2 INT, 

2060 foldToOtherRaisedStreet3 INT, 

2061 foldToOtherRaisedStreet4 INT, 

2062 wonWhenSeenStreet1 INT, 

2063 wonWhenSeenStreet2 INT, 

2064 wonWhenSeenStreet3 INT, 

2065 wonWhenSeenStreet4 INT, 

2066 wonAtSD INT,  

2067 raiseFirstInChance INT, 

2068 raisedFirstIn INT, 

2069 foldBbToStealChance INT, 

2070 foldedBbToSteal INT, 

2071 foldSbToStealChance INT, 

2072 foldedSbToSteal INT, 

2073 street1CBChance INT, 

2074 street1CBDone INT, 

2075 street2CBChance INT, 

2076 street2CBDone INT, 

2077 street3CBChance INT, 

2078 street3CBDone INT, 

2079 street4CBChance INT, 

2080 street4CBDone INT,  

2081 foldToStreet1CBChance INT, 

2082 foldToStreet1CBDone INT, 

2083 foldToStreet2CBChance INT, 

2084 foldToStreet2CBDone INT, 

2085 foldToStreet3CBChance INT, 

2086 foldToStreet3CBDone INT, 

2087 foldToStreet4CBChance INT, 

2088 foldToStreet4CBDone INT,  

2089 common BIGINT, 

2090 committed BIGINT, 

2091 winnings BIGINT, 

2092 rake BIGINT, 

2093 rakeDealt NUMERIC, 

2094 rakeContributed NUMERIC, 

2095 rakeWeighted NUMERIC, 

2096 totalProfit BIGINT, 

2097 allInEV NUMERIC, 

2098 showdownWinnings BIGINT, 

2099 nonShowdownWinnings BIGINT,  

2100 street1CheckCallRaiseChance INT, 

2101 street1CheckCallDone INT, 

2102 street1CheckRaiseDone INT, 

2103 street2CheckCallRaiseChance INT, 

2104 street2CheckCallDone INT, 

2105 street2CheckRaiseDone INT, 

2106 street3CheckCallRaiseChance INT, 

2107 street3CheckCallDone INT, 

2108 street3CheckRaiseDone INT, 

2109 street4CheckCallRaiseChance INT, 

2110 street4CheckCallDone INT, 

2111 street4CheckRaiseDone INT, 

2112 street0Calls INT, 

2113 street1Calls INT, 

2114 street2Calls INT, 

2115 street3Calls INT, 

2116 street4Calls INT, 

2117 street0Bets INT, 

2118 street1Bets INT, 

2119 street2Bets INT, 

2120 street3Bets INT, 

2121 street4Bets INT, 

2122 street0Raises INT, 

2123 street1Raises INT, 

2124 street2Raises INT, 

2125 street3Raises INT, 

2126 street4Raises INT, 

2127 street1Discards INT, 

2128 street2Discards INT, 

2129 street3Discards INT) 

2130 ENGINE=INNODB""" 

2131 elif db_server == 'postgresql': 

2132 self.query['createCardsCacheTable'] = """CREATE TABLE CardsCache ( 

2133 id BIGSERIAL, PRIMARY KEY (id), 

2134 weekId INT, FOREIGN KEY (weekId) REFERENCES Weeks(id), 

2135 monthId INT, FOREIGN KEY (monthId) REFERENCES Months(id), 

2136 gametypeId INT, FOREIGN KEY (gametypeId) REFERENCES Gametypes(id), 

2137 tourneyTypeId INT, FOREIGN KEY (tourneyTypeId) REFERENCES TourneyTypes(id), 

2138 playerId INT, FOREIGN KEY (playerId) REFERENCES Players(id), 

2139 startCards SMALLINT, FOREIGN KEY (startCards) REFERENCES StartCards(id), 

2140 n INT,  

2141 street0VPIChance INT, 

2142 street0VPI INT, 

2143 street0AggrChance INT, 

2144 street0Aggr INT, 

2145 street0CalledRaiseChance INT, 

2146 street0CalledRaiseDone INT, 

2147 street0_2BChance INT, 

2148 street0_2BDone INT, 

2149 street0_3BChance INT, 

2150 street0_3BDone INT, 

2151 street0_4BChance INT, 

2152 street0_4BDone INT, 

2153 street0_C4BChance INT, 

2154 street0_C4BDone INT, 

2155 street0_FoldTo2BChance INT, 

2156 street0_FoldTo2BDone INT, 

2157 street0_FoldTo3BChance INT, 

2158 street0_FoldTo3BDone INT, 

2159 street0_FoldTo4BChance INT, 

2160 street0_FoldTo4BDone INT, 

2161 street0_SqueezeChance INT, 

2162 street0_SqueezeDone INT, 

2163 raiseToStealChance INT, 

2164 raiseToStealDone INT, 

2165 stealChance INT, 

2166 stealDone INT, 

2167 success_Steal INT, 

2168 street1Seen INT, 

2169 street2Seen INT, 

2170 street3Seen INT, 

2171 street4Seen INT, 

2172 sawShowdown INT, 

2173 street1Aggr INT, 

2174 street2Aggr INT, 

2175 street3Aggr INT, 

2176 street4Aggr INT, 

2177 otherRaisedStreet0 INT, 

2178 otherRaisedStreet1 INT, 

2179 otherRaisedStreet2 INT, 

2180 otherRaisedStreet3 INT, 

2181 otherRaisedStreet4 INT, 

2182 foldToOtherRaisedStreet0 INT, 

2183 foldToOtherRaisedStreet1 INT, 

2184 foldToOtherRaisedStreet2 INT, 

2185 foldToOtherRaisedStreet3 INT, 

2186 foldToOtherRaisedStreet4 INT, 

2187 wonWhenSeenStreet1 INT, 

2188 wonWhenSeenStreet2 INT, 

2189 wonWhenSeenStreet3 INT, 

2190 wonWhenSeenStreet4 INT, 

2191 wonAtSD INT, 

2192 raiseFirstInChance INT, 

2193 raisedFirstIn INT, 

2194 foldBbToStealChance INT, 

2195 foldedBbToSteal INT, 

2196 foldSbToStealChance INT, 

2197 foldedSbToSteal INT, 

2198 street1CBChance INT, 

2199 street1CBDone INT, 

2200 street2CBChance INT, 

2201 street2CBDone INT, 

2202 street3CBChance INT, 

2203 street3CBDone INT, 

2204 street4CBChance INT, 

2205 street4CBDone INT, 

2206 foldToStreet1CBChance INT, 

2207 foldToStreet1CBDone INT, 

2208 foldToStreet2CBChance INT, 

2209 foldToStreet2CBDone INT, 

2210 foldToStreet3CBChance INT, 

2211 foldToStreet3CBDone INT, 

2212 foldToStreet4CBChance INT, 

2213 foldToStreet4CBDone INT, 

2214 common BIGINT, 

2215 committed BIGINT, 

2216 winnings BIGINT, 

2217 rake BIGINT, 

2218 rakeDealt NUMERIC, 

2219 rakeContributed NUMERIC, 

2220 rakeWeighted NUMERIC, 

2221 totalProfit BIGINT, 

2222 allInEV NUMERIC, 

2223 showdownWinnings BIGINT, 

2224 nonShowdownWinnings BIGINT, 

2225 street1CheckCallRaiseChance INT, 

2226 street1CheckCallDone INT, 

2227 street1CheckRaiseDone INT, 

2228 street2CheckCallRaiseChance INT, 

2229 street2CheckCallDone INT, 

2230 street2CheckRaiseDone INT, 

2231 street3CheckCallRaiseChance INT, 

2232 street3CheckCallDone INT, 

2233 street3CheckRaiseDone INT, 

2234 street4CheckCallRaiseChance INT, 

2235 street4CheckCallDone INT, 

2236 street4CheckRaiseDone INT, 

2237 street0Calls INT, 

2238 street1Calls INT, 

2239 street2Calls INT, 

2240 street3Calls INT, 

2241 street4Calls INT, 

2242 street0Bets INT, 

2243 street1Bets INT, 

2244 street2Bets INT, 

2245 street3Bets INT, 

2246 street4Bets INT, 

2247 street0Raises INT, 

2248 street1Raises INT, 

2249 street2Raises INT, 

2250 street3Raises INT, 

2251 street4Raises INT, 

2252 street1Discards INT, 

2253 street2Discards INT, 

2254 street3Discards INT) 

2255 """ 

2256 elif db_server == 'sqlite': 

2257 self.query['createCardsCacheTable'] = """CREATE TABLE CardsCache ( 

2258 id INTEGER PRIMARY KEY, 

2259 weekId INT, 

2260 monthId INT, 

2261 gametypeId INT, 

2262 tourneyTypeId INT, 

2263 playerId INT, 

2264 startCards INT, 

2265 n INT,  

2266 street0VPIChance INT, 

2267 street0VPI INT, 

2268 street0AggrChance INT, 

2269 street0Aggr INT, 

2270 street0CalledRaiseChance INT, 

2271 street0CalledRaiseDone INT, 

2272 street0_2BChance INT, 

2273 street0_2BDone INT, 

2274 street0_3BChance INT, 

2275 street0_3BDone INT, 

2276 street0_4BChance INT, 

2277 street0_4BDone INT, 

2278 street0_C4BChance INT, 

2279 street0_C4BDone INT, 

2280 street0_FoldTo2BChance INT, 

2281 street0_FoldTo2BDone INT, 

2282 street0_FoldTo3BChance INT, 

2283 street0_FoldTo3BDone INT, 

2284 street0_FoldTo4BChance INT, 

2285 street0_FoldTo4BDone INT, 

2286 street0_SqueezeChance INT, 

2287 street0_SqueezeDone INT, 

2288 raiseToStealChance INT, 

2289 raiseToStealDone INT, 

2290 stealChance INT, 

2291 stealDone INT, 

2292 success_Steal INT, 

2293 street1Seen INT, 

2294 street2Seen INT, 

2295 street3Seen INT, 

2296 street4Seen INT, 

2297 sawShowdown INT, 

2298 street1Aggr INT, 

2299 street2Aggr INT, 

2300 street3Aggr INT, 

2301 street4Aggr INT, 

2302 otherRaisedStreet0 INT, 

2303 otherRaisedStreet1 INT, 

2304 otherRaisedStreet2 INT, 

2305 otherRaisedStreet3 INT, 

2306 otherRaisedStreet4 INT, 

2307 foldToOtherRaisedStreet0 INT, 

2308 foldToOtherRaisedStreet1 INT, 

2309 foldToOtherRaisedStreet2 INT, 

2310 foldToOtherRaisedStreet3 INT, 

2311 foldToOtherRaisedStreet4 INT, 

2312 wonWhenSeenStreet1 INT, 

2313 wonWhenSeenStreet2 INT, 

2314 wonWhenSeenStreet3 INT, 

2315 wonWhenSeenStreet4 INT, 

2316 wonAtSD INT, 

2317 raiseFirstInChance INT, 

2318 raisedFirstIn INT, 

2319 foldBbToStealChance INT, 

2320 foldedBbToSteal INT, 

2321 foldSbToStealChance INT, 

2322 foldedSbToSteal INT, 

2323 street1CBChance INT, 

2324 street1CBDone INT, 

2325 street2CBChance INT, 

2326 street2CBDone INT, 

2327 street3CBChance INT, 

2328 street3CBDone INT, 

2329 street4CBChance INT, 

2330 street4CBDone INT, 

2331 foldToStreet1CBChance INT, 

2332 foldToStreet1CBDone INT, 

2333 foldToStreet2CBChance INT, 

2334 foldToStreet2CBDone INT, 

2335 foldToStreet3CBChance INT, 

2336 foldToStreet3CBDone INT, 

2337 foldToStreet4CBChance INT, 

2338 foldToStreet4CBDone INT, 

2339 common INT, 

2340 committed INT, 

2341 winnings INT, 

2342 rake INT, 

2343 rakeDealt decimal, 

2344 rakeContributed decimal, 

2345 rakeWeighted decimal, 

2346 totalProfit INT, 

2347 allInEV decimal, 

2348 showdownWinnings INT, 

2349 nonShowdownWinnings INT, 

2350 street1CheckCallRaiseChance INT, 

2351 street1CheckCallDone INT, 

2352 street1CheckRaiseDone INT, 

2353 street2CheckCallRaiseChance INT, 

2354 street2CheckCallDone INT, 

2355 street2CheckRaiseDone INT, 

2356 street3CheckCallRaiseChance INT, 

2357 street3CheckCallDone INT, 

2358 street3CheckRaiseDone INT, 

2359 street4CheckCallRaiseChance INT, 

2360 street4CheckCallDone INT, 

2361 street4CheckRaiseDone INT, 

2362 street0Calls INT, 

2363 street1Calls INT, 

2364 street2Calls INT, 

2365 street3Calls INT, 

2366 street4Calls INT, 

2367 street0Bets INT, 

2368 street1Bets INT, 

2369 street2Bets INT, 

2370 street3Bets INT, 

2371 street4Bets INT, 

2372 street0Raises INT, 

2373 street1Raises INT, 

2374 street2Raises INT, 

2375 street3Raises INT, 

2376 street4Raises INT, 

2377 street1Discards INT, 

2378 street2Discards INT, 

2379 street3Discards INT) 

2380 """ 

2381 

2382 ################################ 

2383 # Create PositionsCache 

2384 ################################ 

2385 

2386 if db_server == 'mysql': 

2387 self.query['createPositionsCacheTable'] = """CREATE TABLE PositionsCache ( 

2388 id BIGINT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

2389 weekId INT UNSIGNED, FOREIGN KEY (weekId) REFERENCES Weeks(id), 

2390 monthId INT UNSIGNED, FOREIGN KEY (monthId) REFERENCES Months(id), 

2391 gametypeId SMALLINT UNSIGNED, FOREIGN KEY (gametypeId) REFERENCES Gametypes(id), 

2392 tourneyTypeId SMALLINT UNSIGNED, FOREIGN KEY (tourneyTypeId) REFERENCES TourneyTypes(id), 

2393 playerId INT UNSIGNED NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

2394 seats SMALLINT NOT NULL, 

2395 maxPosition TINYINT NOT NULL, 

2396 position CHAR(1), 

2397 n INT NOT NULL,  

2398 street0VPIChance INT, 

2399 street0VPI INT, 

2400 street0AggrChance INT, 

2401 street0Aggr INT, 

2402 street0CalledRaiseChance INT, 

2403 street0CalledRaiseDone INT, 

2404 street0_2BChance INT, 

2405 street0_2BDone INT, 

2406 street0_3BChance INT, 

2407 street0_3BDone INT, 

2408 street0_4BChance INT, 

2409 street0_4BDone INT, 

2410 street0_C4BChance INT, 

2411 street0_C4BDone INT, 

2412 street0_FoldTo2BChance INT, 

2413 street0_FoldTo2BDone INT, 

2414 street0_FoldTo3BChance INT, 

2415 street0_FoldTo3BDone INT, 

2416 street0_FoldTo4BChance INT, 

2417 street0_FoldTo4BDone INT, 

2418 street0_SqueezeChance INT, 

2419 street0_SqueezeDone INT, 

2420 raiseToStealChance INT, 

2421 raiseToStealDone INT, 

2422 stealChance INT, 

2423 stealDone INT, 

2424 success_Steal INT, 

2425 street1Seen INT, 

2426 street2Seen INT, 

2427 street3Seen INT, 

2428 street4Seen INT, 

2429 sawShowdown INT,  

2430 street1Aggr INT, 

2431 street2Aggr INT, 

2432 street3Aggr INT, 

2433 street4Aggr INT, 

2434 otherRaisedStreet0 INT, 

2435 otherRaisedStreet1 INT, 

2436 otherRaisedStreet2 INT, 

2437 otherRaisedStreet3 INT, 

2438 otherRaisedStreet4 INT, 

2439 foldToOtherRaisedStreet0 INT, 

2440 foldToOtherRaisedStreet1 INT, 

2441 foldToOtherRaisedStreet2 INT, 

2442 foldToOtherRaisedStreet3 INT, 

2443 foldToOtherRaisedStreet4 INT, 

2444 wonWhenSeenStreet1 INT, 

2445 wonWhenSeenStreet2 INT, 

2446 wonWhenSeenStreet3 INT, 

2447 wonWhenSeenStreet4 INT, 

2448 wonAtSD INT,  

2449 raiseFirstInChance INT, 

2450 raisedFirstIn INT, 

2451 foldBbToStealChance INT, 

2452 foldedBbToSteal INT, 

2453 foldSbToStealChance INT, 

2454 foldedSbToSteal INT, 

2455 street1CBChance INT, 

2456 street1CBDone INT, 

2457 street2CBChance INT, 

2458 street2CBDone INT, 

2459 street3CBChance INT, 

2460 street3CBDone INT, 

2461 street4CBChance INT, 

2462 street4CBDone INT,  

2463 foldToStreet1CBChance INT, 

2464 foldToStreet1CBDone INT, 

2465 foldToStreet2CBChance INT, 

2466 foldToStreet2CBDone INT, 

2467 foldToStreet3CBChance INT, 

2468 foldToStreet3CBDone INT, 

2469 foldToStreet4CBChance INT, 

2470 foldToStreet4CBDone INT,  

2471 common BIGINT, 

2472 committed BIGINT, 

2473 winnings BIGINT, 

2474 rake BIGINT, 

2475 rakeDealt NUMERIC, 

2476 rakeContributed NUMERIC, 

2477 rakeWeighted NUMERIC, 

2478 totalProfit BIGINT, 

2479 allInEV NUMERIC, 

2480 showdownWinnings BIGINT, 

2481 nonShowdownWinnings BIGINT,  

2482 street1CheckCallRaiseChance INT, 

2483 street1CheckCallDone INT, 

2484 street1CheckRaiseDone INT, 

2485 street2CheckCallRaiseChance INT, 

2486 street2CheckCallDone INT, 

2487 street2CheckRaiseDone INT, 

2488 street3CheckCallRaiseChance INT, 

2489 street3CheckCallDone INT, 

2490 street3CheckRaiseDone INT, 

2491 street4CheckCallRaiseChance INT, 

2492 street4CheckCallDone INT, 

2493 street4CheckRaiseDone INT, 

2494 street0Calls INT, 

2495 street1Calls INT, 

2496 street2Calls INT, 

2497 street3Calls INT, 

2498 street4Calls INT, 

2499 street0Bets INT, 

2500 street1Bets INT, 

2501 street2Bets INT, 

2502 street3Bets INT, 

2503 street4Bets INT, 

2504 street0Raises INT, 

2505 street1Raises INT, 

2506 street2Raises INT, 

2507 street3Raises INT, 

2508 street4Raises INT, 

2509 street1Discards INT, 

2510 street2Discards INT, 

2511 street3Discards INT) 

2512 ENGINE=INNODB""" 

2513 elif db_server == 'postgresql': 

2514 self.query['createPositionsCacheTable'] = """CREATE TABLE PositionsCache ( 

2515 id BIGSERIAL, PRIMARY KEY (id), 

2516 weekId INT, FOREIGN KEY (weekId) REFERENCES Weeks(id), 

2517 monthId INT, FOREIGN KEY (monthId) REFERENCES Months(id), 

2518 gametypeId INT, FOREIGN KEY (gametypeId) REFERENCES Gametypes(id), 

2519 tourneyTypeId INT, FOREIGN KEY (tourneyTypeId) REFERENCES TourneyTypes(id), 

2520 playerId INT, FOREIGN KEY (playerId) REFERENCES Players(id), 

2521 seats SMALLINT, 

2522 maxPosition SMALLINT NOT NULL, 

2523 position CHAR(1), 

2524 n INT, 

2525 street0VPIChance INT, 

2526 street0VPI INT, 

2527 street0AggrChance INT, 

2528 street0Aggr INT, 

2529 street0CalledRaiseChance INT, 

2530 street0CalledRaiseDone INT, 

2531 street0_2BChance INT, 

2532 street0_2BDone INT, 

2533 street0_3BChance INT, 

2534 street0_3BDone INT, 

2535 street0_4BChance INT, 

2536 street0_4BDone INT, 

2537 street0_C4BChance INT, 

2538 street0_C4BDone INT, 

2539 street0_FoldTo2BChance INT, 

2540 street0_FoldTo2BDone INT, 

2541 street0_FoldTo3BChance INT, 

2542 street0_FoldTo3BDone INT, 

2543 street0_FoldTo4BChance INT, 

2544 street0_FoldTo4BDone INT, 

2545 street0_SqueezeChance INT, 

2546 street0_SqueezeDone INT, 

2547 raiseToStealChance INT, 

2548 raiseToStealDone INT, 

2549 stealChance INT, 

2550 stealDone INT, 

2551 success_Steal INT, 

2552 street1Seen INT, 

2553 street2Seen INT, 

2554 street3Seen INT, 

2555 street4Seen INT, 

2556 sawShowdown INT, 

2557 street1Aggr INT, 

2558 street2Aggr INT, 

2559 street3Aggr INT, 

2560 street4Aggr INT, 

2561 otherRaisedStreet0 INT, 

2562 otherRaisedStreet1 INT, 

2563 otherRaisedStreet2 INT, 

2564 otherRaisedStreet3 INT, 

2565 otherRaisedStreet4 INT, 

2566 foldToOtherRaisedStreet0 INT, 

2567 foldToOtherRaisedStreet1 INT, 

2568 foldToOtherRaisedStreet2 INT, 

2569 foldToOtherRaisedStreet3 INT, 

2570 foldToOtherRaisedStreet4 INT, 

2571 wonWhenSeenStreet1 INT, 

2572 wonWhenSeenStreet2 INT, 

2573 wonWhenSeenStreet3 INT, 

2574 wonWhenSeenStreet4 INT, 

2575 wonAtSD INT, 

2576 raiseFirstInChance INT, 

2577 raisedFirstIn INT, 

2578 foldBbToStealChance INT, 

2579 foldedBbToSteal INT, 

2580 foldSbToStealChance INT, 

2581 foldedSbToSteal INT, 

2582 street1CBChance INT, 

2583 street1CBDone INT, 

2584 street2CBChance INT, 

2585 street2CBDone INT, 

2586 street3CBChance INT, 

2587 street3CBDone INT, 

2588 street4CBChance INT, 

2589 street4CBDone INT, 

2590 foldToStreet1CBChance INT, 

2591 foldToStreet1CBDone INT, 

2592 foldToStreet2CBChance INT, 

2593 foldToStreet2CBDone INT, 

2594 foldToStreet3CBChance INT, 

2595 foldToStreet3CBDone INT, 

2596 foldToStreet4CBChance INT, 

2597 foldToStreet4CBDone INT, 

2598 common BIGINT, 

2599 committed BIGINT, 

2600 winnings BIGINT, 

2601 rake BIGINT, 

2602 rakeDealt NUMERIC, 

2603 rakeContributed NUMERIC, 

2604 rakeWeighted NUMERIC,  

2605 totalProfit BIGINT, 

2606 allInEV NUMERIC, 

2607 showdownWinnings BIGINT, 

2608 nonShowdownWinnings BIGINT, 

2609 street1CheckCallRaiseChance INT, 

2610 street1CheckCallDone INT, 

2611 street1CheckRaiseDone INT, 

2612 street2CheckCallRaiseChance INT, 

2613 street2CheckCallDone INT, 

2614 street2CheckRaiseDone INT, 

2615 street3CheckCallRaiseChance INT, 

2616 street3CheckCallDone INT, 

2617 street3CheckRaiseDone INT, 

2618 street4CheckCallRaiseChance INT, 

2619 street4CheckCallDone INT, 

2620 street4CheckRaiseDone INT, 

2621 street0Calls INT, 

2622 street1Calls INT, 

2623 street2Calls INT, 

2624 street3Calls INT, 

2625 street4Calls INT, 

2626 street0Bets INT, 

2627 street1Bets INT, 

2628 street2Bets INT, 

2629 street3Bets INT, 

2630 street4Bets INT, 

2631 street0Raises INT, 

2632 street1Raises INT, 

2633 street2Raises INT, 

2634 street3Raises INT, 

2635 street4Raises INT, 

2636 street1Discards INT, 

2637 street2Discards INT, 

2638 street3Discards INT) 

2639 """ 

2640 elif db_server == 'sqlite': 

2641 self.query['createPositionsCacheTable'] = """CREATE TABLE PositionsCache ( 

2642 id INTEGER PRIMARY KEY, 

2643 weekId INT, 

2644 monthId INT, 

2645 gametypeId INT, 

2646 tourneyTypeId INT, 

2647 playerId INT, 

2648 seats INT, 

2649 maxPosition INT NOT NULL, 

2650 position TEXT, 

2651 n INT, 

2652 street0VPIChance INT, 

2653 street0VPI INT, 

2654 street0AggrChance INT, 

2655 street0Aggr INT, 

2656 street0CalledRaiseChance INT, 

2657 street0CalledRaiseDone INT, 

2658 street0_2BChance INT, 

2659 street0_2BDone INT, 

2660 street0_3BChance INT, 

2661 street0_3BDone INT, 

2662 street0_4BChance INT, 

2663 street0_4BDone INT, 

2664 street0_C4BChance INT, 

2665 street0_C4BDone INT, 

2666 street0_FoldTo2BChance INT, 

2667 street0_FoldTo2BDone INT, 

2668 street0_FoldTo3BChance INT, 

2669 street0_FoldTo3BDone INT, 

2670 street0_FoldTo4BChance INT, 

2671 street0_FoldTo4BDone INT, 

2672 street0_SqueezeChance INT, 

2673 street0_SqueezeDone INT, 

2674 raiseToStealChance INT, 

2675 raiseToStealDone INT, 

2676 stealChance INT, 

2677 stealDone INT, 

2678 success_Steal INT, 

2679 street1Seen INT, 

2680 street2Seen INT, 

2681 street3Seen INT, 

2682 street4Seen INT, 

2683 sawShowdown INT, 

2684 street1Aggr INT, 

2685 street2Aggr INT, 

2686 street3Aggr INT, 

2687 street4Aggr INT, 

2688 otherRaisedStreet0 INT, 

2689 otherRaisedStreet1 INT, 

2690 otherRaisedStreet2 INT, 

2691 otherRaisedStreet3 INT, 

2692 otherRaisedStreet4 INT, 

2693 foldToOtherRaisedStreet0 INT, 

2694 foldToOtherRaisedStreet1 INT, 

2695 foldToOtherRaisedStreet2 INT, 

2696 foldToOtherRaisedStreet3 INT, 

2697 foldToOtherRaisedStreet4 INT, 

2698 wonWhenSeenStreet1 INT, 

2699 wonWhenSeenStreet2 INT, 

2700 wonWhenSeenStreet3 INT, 

2701 wonWhenSeenStreet4 INT, 

2702 wonAtSD INT, 

2703 raiseFirstInChance INT, 

2704 raisedFirstIn INT, 

2705 foldBbToStealChance INT, 

2706 foldedBbToSteal INT, 

2707 foldSbToStealChance INT, 

2708 foldedSbToSteal INT, 

2709 street1CBChance INT, 

2710 street1CBDone INT, 

2711 street2CBChance INT, 

2712 street2CBDone INT, 

2713 street3CBChance INT, 

2714 street3CBDone INT, 

2715 street4CBChance INT, 

2716 street4CBDone INT, 

2717 foldToStreet1CBChance INT, 

2718 foldToStreet1CBDone INT, 

2719 foldToStreet2CBChance INT, 

2720 foldToStreet2CBDone INT, 

2721 foldToStreet3CBChance INT, 

2722 foldToStreet3CBDone INT, 

2723 foldToStreet4CBChance INT, 

2724 foldToStreet4CBDone INT, 

2725 common INT, 

2726 committed INT, 

2727 winnings INT, 

2728 rake INT, 

2729 rakeDealt decimal, 

2730 rakeContributed decimal, 

2731 rakeWeighted decimal, 

2732 totalProfit INT, 

2733 allInEV decimal, 

2734 showdownWinnings INT, 

2735 nonShowdownWinnings INT, 

2736 street1CheckCallRaiseChance INT, 

2737 street1CheckCallDone INT, 

2738 street1CheckRaiseDone INT, 

2739 street2CheckCallRaiseChance INT, 

2740 street2CheckCallDone INT, 

2741 street2CheckRaiseDone INT, 

2742 street3CheckCallRaiseChance INT, 

2743 street3CheckCallDone INT, 

2744 street3CheckRaiseDone INT, 

2745 street4CheckCallRaiseChance INT, 

2746 street4CheckCallDone INT, 

2747 street4CheckRaiseDone INT, 

2748 street0Calls INT, 

2749 street1Calls INT, 

2750 street2Calls INT, 

2751 street3Calls INT, 

2752 street4Calls INT, 

2753 street0Bets INT, 

2754 street1Bets INT, 

2755 street2Bets INT, 

2756 street3Bets INT, 

2757 street4Bets INT, 

2758 street0Raises INT, 

2759 street1Raises INT, 

2760 street2Raises INT, 

2761 street3Raises INT, 

2762 street4Raises INT, 

2763 street1Discards INT, 

2764 street2Discards INT, 

2765 street3Discards INT) 

2766 """ 

2767 

2768 ################################ 

2769 # Create Weeks 

2770 ################################ 

2771 

2772 if db_server == 'mysql': 

2773 self.query['createWeeksTable'] = """CREATE TABLE Weeks ( 

2774 id INT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

2775 weekStart DATETIME NOT NULL) 

2776 ENGINE=INNODB 

2777 """ 

2778 

2779 elif db_server == 'postgresql': 

2780 self.query['createWeeksTable'] = """CREATE TABLE Weeks ( 

2781 id SERIAL, PRIMARY KEY (id), 

2782 weekStart timestamp without time zone NOT NULL) 

2783 """ 

2784 

2785 elif db_server == 'sqlite': 

2786 self.query['createWeeksTable'] = """CREATE TABLE Weeks ( 

2787 id INTEGER PRIMARY KEY, 

2788 weekStart timestamp NOT NULL) 

2789 """ 

2790 

2791 ################################ 

2792 # Create Months 

2793 ################################ 

2794 

2795 if db_server == 'mysql': 

2796 self.query['createMonthsTable'] = """CREATE TABLE Months ( 

2797 id INT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

2798 monthStart DATETIME NOT NULL) 

2799 ENGINE=INNODB 

2800 """ 

2801 

2802 elif db_server == 'postgresql': 

2803 self.query['createMonthsTable'] = """CREATE TABLE Months ( 

2804 id SERIAL, PRIMARY KEY (id), 

2805 monthStart timestamp without time zone NOT NULL) 

2806 """ 

2807 

2808 elif db_server == 'sqlite': 

2809 self.query['createMonthsTable'] = """CREATE TABLE Months ( 

2810 id INTEGER PRIMARY KEY, 

2811 monthStart timestamp NOT NULL) 

2812 """ 

2813 

2814 ################################ 

2815 # Create Sessions 

2816 ################################ 

2817 

2818 if db_server == 'mysql': 

2819 self.query['createSessionsTable'] = """CREATE TABLE Sessions ( 

2820 id INT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

2821 weekId INT UNSIGNED, FOREIGN KEY (weekId) REFERENCES Weeks(id), 

2822 monthId INT UNSIGNED, FOREIGN KEY (monthId) REFERENCES Months(id), 

2823 sessionStart DATETIME NOT NULL, 

2824 sessionEnd DATETIME NOT NULL) 

2825 ENGINE=INNODB 

2826 """ 

2827 

2828 elif db_server == 'postgresql': 

2829 self.query['createSessionsTable'] = """CREATE TABLE Sessions ( 

2830 id SERIAL, PRIMARY KEY (id), 

2831 weekId INT, FOREIGN KEY (weekId) REFERENCES Weeks(id), 

2832 monthId INT, FOREIGN KEY (monthId) REFERENCES Months(id), 

2833 sessionStart timestamp without time zone NOT NULL, 

2834 sessionEnd timestamp without time zone NOT NULL) 

2835 """ 

2836 

2837 elif db_server == 'sqlite': 

2838 self.query['createSessionsTable'] = """CREATE TABLE Sessions ( 

2839 id INTEGER PRIMARY KEY, 

2840 weekId INT, 

2841 monthId INT, 

2842 sessionStart timestamp NOT NULL, 

2843 sessionEnd timestamp NOT NULL) 

2844 """ 

2845 

2846 ################################ 

2847 # Create SessionsCache 

2848 ################################ 

2849 

2850 if db_server == 'mysql': 

2851 self.query['createSessionsCacheTable'] = """CREATE TABLE SessionsCache ( 

2852 id INT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

2853 sessionId INT UNSIGNED, FOREIGN KEY (sessionId) REFERENCES Sessions(id), 

2854 startTime DATETIME NOT NULL, 

2855 endTime DATETIME NOT NULL, 

2856 gametypeId SMALLINT UNSIGNED, FOREIGN KEY (gametypeId) REFERENCES Gametypes(id), 

2857 playerId INT UNSIGNED NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

2858 n INT NOT NULL,  

2859 street0VPIChance INT, 

2860 street0VPI INT, 

2861 street0AggrChance INT, 

2862 street0Aggr INT, 

2863 street0CalledRaiseChance INT, 

2864 street0CalledRaiseDone INT, 

2865 street0_2BChance INT, 

2866 street0_2BDone INT, 

2867 street0_3BChance INT, 

2868 street0_3BDone INT, 

2869 street0_4BChance INT, 

2870 street0_4BDone INT, 

2871 street0_C4BChance INT, 

2872 street0_C4BDone INT, 

2873 street0_FoldTo2BChance INT, 

2874 street0_FoldTo2BDone INT, 

2875 street0_FoldTo3BChance INT, 

2876 street0_FoldTo3BDone INT, 

2877 street0_FoldTo4BChance INT, 

2878 street0_FoldTo4BDone INT, 

2879 street0_SqueezeChance INT, 

2880 street0_SqueezeDone INT, 

2881 raiseToStealChance INT, 

2882 raiseToStealDone INT, 

2883 stealChance INT, 

2884 stealDone INT, 

2885 success_Steal INT, 

2886 street1Seen INT, 

2887 street2Seen INT, 

2888 street3Seen INT, 

2889 street4Seen INT, 

2890 sawShowdown INT,  

2891 street1Aggr INT, 

2892 street2Aggr INT, 

2893 street3Aggr INT, 

2894 street4Aggr INT, 

2895 otherRaisedStreet0 INT, 

2896 otherRaisedStreet1 INT, 

2897 otherRaisedStreet2 INT, 

2898 otherRaisedStreet3 INT, 

2899 otherRaisedStreet4 INT, 

2900 foldToOtherRaisedStreet0 INT, 

2901 foldToOtherRaisedStreet1 INT, 

2902 foldToOtherRaisedStreet2 INT, 

2903 foldToOtherRaisedStreet3 INT, 

2904 foldToOtherRaisedStreet4 INT,  

2905 wonWhenSeenStreet1 INT, 

2906 wonWhenSeenStreet2 INT, 

2907 wonWhenSeenStreet3 INT, 

2908 wonWhenSeenStreet4 INT, 

2909 wonAtSD INT,  

2910 raiseFirstInChance INT, 

2911 raisedFirstIn INT, 

2912 foldBbToStealChance INT, 

2913 foldedBbToSteal INT, 

2914 foldSbToStealChance INT, 

2915 foldedSbToSteal INT, 

2916 street1CBChance INT, 

2917 street1CBDone INT, 

2918 street2CBChance INT, 

2919 street2CBDone INT, 

2920 street3CBChance INT, 

2921 street3CBDone INT, 

2922 street4CBChance INT, 

2923 street4CBDone INT,  

2924 foldToStreet1CBChance INT, 

2925 foldToStreet1CBDone INT, 

2926 foldToStreet2CBChance INT, 

2927 foldToStreet2CBDone INT, 

2928 foldToStreet3CBChance INT, 

2929 foldToStreet3CBDone INT, 

2930 foldToStreet4CBChance INT, 

2931 foldToStreet4CBDone INT,  

2932 common BIGINT, 

2933 committed BIGINT, 

2934 winnings BIGINT, 

2935 rake BIGINT, 

2936 rakeDealt NUMERIC, 

2937 rakeContributed NUMERIC, 

2938 rakeWeighted NUMERIC, 

2939 totalProfit BIGINT, 

2940 allInEV NUMERIC, 

2941 showdownWinnings BIGINT, 

2942 nonShowdownWinnings BIGINT,  

2943 street1CheckCallRaiseChance INT, 

2944 street1CheckCallDone INT, 

2945 street1CheckRaiseDone INT, 

2946 street2CheckCallRaiseChance INT, 

2947 street2CheckCallDone INT, 

2948 street2CheckRaiseDone INT, 

2949 street3CheckCallRaiseChance INT, 

2950 street3CheckCallDone INT, 

2951 street3CheckRaiseDone INT, 

2952 street4CheckCallRaiseChance INT, 

2953 street4CheckCallDone INT, 

2954 street4CheckRaiseDone INT, 

2955 street0Calls INT, 

2956 street1Calls INT, 

2957 street2Calls INT, 

2958 street3Calls INT, 

2959 street4Calls INT, 

2960 street0Bets INT, 

2961 street1Bets INT, 

2962 street2Bets INT, 

2963 street3Bets INT, 

2964 street4Bets INT, 

2965 street0Raises INT, 

2966 street1Raises INT, 

2967 street2Raises INT, 

2968 street3Raises INT, 

2969 street4Raises INT, 

2970 street1Discards INT, 

2971 street2Discards INT, 

2972 street3Discards INT) 

2973 ENGINE=INNODB 

2974 """ 

2975 

2976 elif db_server == 'postgresql': 

2977 self.query['createSessionsCacheTable'] = """CREATE TABLE SessionsCache ( 

2978 id SERIAL, PRIMARY KEY (id), 

2979 sessionId INT, FOREIGN KEY (sessionId) REFERENCES Sessions(id), 

2980 startTime timestamp without time zone NOT NULL, 

2981 endTime timestamp without time zone NOT NULL, 

2982 gametypeId INT, FOREIGN KEY (gametypeId) REFERENCES Gametypes(id), 

2983 playerId INT, FOREIGN KEY (playerId) REFERENCES Players(id), 

2984 n INT,  

2985 street0VPIChance INT, 

2986 street0VPI INT, 

2987 street0AggrChance INT, 

2988 street0Aggr INT, 

2989 street0CalledRaiseChance INT, 

2990 street0CalledRaiseDone INT, 

2991 street0_2BChance INT, 

2992 street0_2BDone INT, 

2993 street0_3BChance INT, 

2994 street0_3BDone INT, 

2995 street0_4BChance INT, 

2996 street0_4BDone INT, 

2997 street0_C4BChance INT, 

2998 street0_C4BDone INT, 

2999 street0_FoldTo2BChance INT, 

3000 street0_FoldTo2BDone INT, 

3001 street0_FoldTo3BChance INT, 

3002 street0_FoldTo3BDone INT, 

3003 street0_FoldTo4BChance INT, 

3004 street0_FoldTo4BDone INT, 

3005 street0_SqueezeChance INT, 

3006 street0_SqueezeDone INT, 

3007 raiseToStealChance INT, 

3008 raiseToStealDone INT, 

3009 stealChance INT, 

3010 stealDone INT, 

3011 success_Steal INT, 

3012 street1Seen INT, 

3013 street2Seen INT, 

3014 street3Seen INT, 

3015 street4Seen INT, 

3016 sawShowdown INT, 

3017 street1Aggr INT, 

3018 street2Aggr INT, 

3019 street3Aggr INT, 

3020 street4Aggr INT, 

3021 otherRaisedStreet0 INT, 

3022 otherRaisedStreet1 INT, 

3023 otherRaisedStreet2 INT, 

3024 otherRaisedStreet3 INT, 

3025 otherRaisedStreet4 INT, 

3026 foldToOtherRaisedStreet0 INT, 

3027 foldToOtherRaisedStreet1 INT, 

3028 foldToOtherRaisedStreet2 INT, 

3029 foldToOtherRaisedStreet3 INT, 

3030 foldToOtherRaisedStreet4 INT,  

3031 wonWhenSeenStreet1 INT, 

3032 wonWhenSeenStreet2 INT, 

3033 wonWhenSeenStreet3 INT, 

3034 wonWhenSeenStreet4 INT, 

3035 wonAtSD INT, 

3036 raiseFirstInChance INT, 

3037 raisedFirstIn INT, 

3038 foldBbToStealChance INT, 

3039 foldedBbToSteal INT, 

3040 foldSbToStealChance INT, 

3041 foldedSbToSteal INT, 

3042 street1CBChance INT, 

3043 street1CBDone INT, 

3044 street2CBChance INT, 

3045 street2CBDone INT, 

3046 street3CBChance INT, 

3047 street3CBDone INT, 

3048 street4CBChance INT, 

3049 street4CBDone INT, 

3050 foldToStreet1CBChance INT, 

3051 foldToStreet1CBDone INT, 

3052 foldToStreet2CBChance INT, 

3053 foldToStreet2CBDone INT, 

3054 foldToStreet3CBChance INT, 

3055 foldToStreet3CBDone INT, 

3056 foldToStreet4CBChance INT, 

3057 foldToStreet4CBDone INT, 

3058 common BIGINT, 

3059 committed BIGINT, 

3060 winnings BIGINT, 

3061 rake BIGINT, 

3062 rakeDealt NUMERIC, 

3063 rakeContributed NUMERIC, 

3064 rakeWeighted NUMERIC, 

3065 totalProfit BIGINT, 

3066 allInEV NUMERIC, 

3067 showdownWinnings BIGINT, 

3068 nonShowdownWinnings BIGINT, 

3069 street1CheckCallRaiseChance INT, 

3070 street1CheckCallDone INT, 

3071 street1CheckRaiseDone INT, 

3072 street2CheckCallRaiseChance INT, 

3073 street2CheckCallDone INT, 

3074 street2CheckRaiseDone INT, 

3075 street3CheckCallRaiseChance INT, 

3076 street3CheckCallDone INT, 

3077 street3CheckRaiseDone INT, 

3078 street4CheckCallRaiseChance INT, 

3079 street4CheckCallDone INT, 

3080 street4CheckRaiseDone INT, 

3081 street0Calls INT, 

3082 street1Calls INT, 

3083 street2Calls INT, 

3084 street3Calls INT, 

3085 street4Calls INT, 

3086 street0Bets INT, 

3087 street1Bets INT, 

3088 street2Bets INT, 

3089 street3Bets INT, 

3090 street4Bets INT, 

3091 street0Raises INT, 

3092 street1Raises INT, 

3093 street2Raises INT, 

3094 street3Raises INT, 

3095 street4Raises INT, 

3096 street1Discards INT, 

3097 street2Discards INT, 

3098 street3Discards INT) 

3099 """ 

3100 

3101 elif db_server == 'sqlite': 

3102 self.query['createSessionsCacheTable'] = """CREATE TABLE SessionsCache ( 

3103 id INTEGER PRIMARY KEY, 

3104 sessionId INT, 

3105 startTime timestamp NOT NULL, 

3106 endTime timestamp NOT NULL, 

3107 gametypeId INT, 

3108 playerId INT, 

3109 n INT, 

3110 street0VPIChance INT, 

3111 street0VPI INT, 

3112 street0AggrChance INT, 

3113 street0Aggr INT, 

3114 street0CalledRaiseChance INT, 

3115 street0CalledRaiseDone INT, 

3116 street0_2BChance INT, 

3117 street0_2BDone INT, 

3118 street0_3BChance INT, 

3119 street0_3BDone INT, 

3120 street0_4BChance INT, 

3121 street0_4BDone INT, 

3122 street0_C4BChance INT, 

3123 street0_C4BDone INT, 

3124 street0_FoldTo2BChance INT, 

3125 street0_FoldTo2BDone INT, 

3126 street0_FoldTo3BChance INT, 

3127 street0_FoldTo3BDone INT, 

3128 street0_FoldTo4BChance INT, 

3129 street0_FoldTo4BDone INT, 

3130 street0_SqueezeChance INT, 

3131 street0_SqueezeDone INT, 

3132 raiseToStealChance INT, 

3133 raiseToStealDone INT, 

3134 stealChance INT, 

3135 stealDone INT, 

3136 success_Steal INT, 

3137 street1Seen INT, 

3138 street2Seen INT, 

3139 street3Seen INT, 

3140 street4Seen INT, 

3141 sawShowdown INT, 

3142 street1Aggr INT, 

3143 street2Aggr INT, 

3144 street3Aggr INT, 

3145 street4Aggr INT, 

3146 otherRaisedStreet0 INT, 

3147 otherRaisedStreet1 INT, 

3148 otherRaisedStreet2 INT, 

3149 otherRaisedStreet3 INT, 

3150 otherRaisedStreet4 INT, 

3151 foldToOtherRaisedStreet0 INT, 

3152 foldToOtherRaisedStreet1 INT, 

3153 foldToOtherRaisedStreet2 INT, 

3154 foldToOtherRaisedStreet3 INT, 

3155 foldToOtherRaisedStreet4 INT,  

3156 wonWhenSeenStreet1 INT, 

3157 wonWhenSeenStreet2 INT, 

3158 wonWhenSeenStreet3 INT, 

3159 wonWhenSeenStreet4 INT, 

3160 wonAtSD INT, 

3161 raiseFirstInChance INT, 

3162 raisedFirstIn INT, 

3163 foldBbToStealChance INT, 

3164 foldedBbToSteal INT, 

3165 foldSbToStealChance INT, 

3166 foldedSbToSteal INT, 

3167 street1CBChance INT, 

3168 street1CBDone INT, 

3169 street2CBChance INT, 

3170 street2CBDone INT, 

3171 street3CBChance INT, 

3172 street3CBDone INT, 

3173 street4CBChance INT, 

3174 street4CBDone INT, 

3175 foldToStreet1CBChance INT, 

3176 foldToStreet1CBDone INT, 

3177 foldToStreet2CBChance INT, 

3178 foldToStreet2CBDone INT, 

3179 foldToStreet3CBChance INT, 

3180 foldToStreet3CBDone INT, 

3181 foldToStreet4CBChance INT, 

3182 foldToStreet4CBDone INT, 

3183 common INT, 

3184 committed INT, 

3185 winnings INT, 

3186 rake INT, 

3187 rakeDealt decimal, 

3188 rakeContributed decimal, 

3189 rakeWeighted decimal, 

3190 totalProfit INT, 

3191 allInEV decimal, 

3192 showdownWinnings INT, 

3193 nonShowdownWinnings INT, 

3194 street1CheckCallRaiseChance INT, 

3195 street1CheckCallDone INT, 

3196 street1CheckRaiseDone INT, 

3197 street2CheckCallRaiseChance INT, 

3198 street2CheckCallDone INT, 

3199 street2CheckRaiseDone INT, 

3200 street3CheckCallRaiseChance INT, 

3201 street3CheckCallDone INT, 

3202 street3CheckRaiseDone INT, 

3203 street4CheckCallRaiseChance INT, 

3204 street4CheckCallDone INT, 

3205 street4CheckRaiseDone INT, 

3206 street0Calls INT, 

3207 street1Calls INT, 

3208 street2Calls INT, 

3209 street3Calls INT, 

3210 street4Calls INT, 

3211 street0Bets INT, 

3212 street1Bets INT, 

3213 street2Bets INT, 

3214 street3Bets INT, 

3215 street4Bets INT, 

3216 street0Raises INT, 

3217 street1Raises INT, 

3218 street2Raises INT, 

3219 street3Raises INT, 

3220 street4Raises INT, 

3221 street1Discards INT, 

3222 street2Discards INT, 

3223 street3Discards INT) 

3224 """ 

3225 

3226 ################################ 

3227 # Create TourneysCache 

3228 ################################ 

3229 

3230 if db_server == 'mysql': 

3231 self.query['createTourneysCacheTable'] = """CREATE TABLE TourneysCache ( 

3232 id INT UNSIGNED AUTO_INCREMENT NOT NULL, PRIMARY KEY (id), 

3233 sessionId INT UNSIGNED, FOREIGN KEY (sessionId) REFERENCES Sessions(id), 

3234 startTime DATETIME NOT NULL, 

3235 endTime DATETIME NOT NULL, 

3236 tourneyId INT UNSIGNED NOT NULL, FOREIGN KEY (tourneyId) REFERENCES Tourneys(id), 

3237 playerId INT UNSIGNED NOT NULL, FOREIGN KEY (playerId) REFERENCES Players(id), 

3238 n INT NOT NULL,  

3239 street0VPIChance INT, 

3240 street0VPI INT, 

3241 street0AggrChance INT, 

3242 street0Aggr INT, 

3243 street0CalledRaiseChance INT, 

3244 street0CalledRaiseDone INT, 

3245 street0_2BChance INT, 

3246 street0_2BDone INT, 

3247 street0_3BChance INT, 

3248 street0_3BDone INT, 

3249 street0_4BChance INT, 

3250 street0_4BDone INT, 

3251 street0_C4BChance INT, 

3252 street0_C4BDone INT, 

3253 street0_FoldTo2BChance INT, 

3254 street0_FoldTo2BDone INT, 

3255 street0_FoldTo3BChance INT, 

3256 street0_FoldTo3BDone INT, 

3257 street0_FoldTo4BChance INT, 

3258 street0_FoldTo4BDone INT, 

3259 street0_SqueezeChance INT, 

3260 street0_SqueezeDone INT, 

3261 raiseToStealChance INT, 

3262 raiseToStealDone INT, 

3263 stealChance INT, 

3264 stealDone INT, 

3265 success_Steal INT, 

3266 street1Seen INT, 

3267 street2Seen INT, 

3268 street3Seen INT, 

3269 street4Seen INT, 

3270 sawShowdown INT,  

3271 street1Aggr INT, 

3272 street2Aggr INT, 

3273 street3Aggr INT, 

3274 street4Aggr INT, 

3275 otherRaisedStreet0 INT, 

3276 otherRaisedStreet1 INT, 

3277 otherRaisedStreet2 INT, 

3278 otherRaisedStreet3 INT, 

3279 otherRaisedStreet4 INT, 

3280 foldToOtherRaisedStreet0 INT, 

3281 foldToOtherRaisedStreet1 INT, 

3282 foldToOtherRaisedStreet2 INT, 

3283 foldToOtherRaisedStreet3 INT, 

3284 foldToOtherRaisedStreet4 INT,  

3285 wonWhenSeenStreet1 INT, 

3286 wonWhenSeenStreet2 INT, 

3287 wonWhenSeenStreet3 INT, 

3288 wonWhenSeenStreet4 INT, 

3289 wonAtSD INT,  

3290 raiseFirstInChance INT, 

3291 raisedFirstIn INT, 

3292 foldBbToStealChance INT, 

3293 foldedBbToSteal INT, 

3294 foldSbToStealChance INT, 

3295 foldedSbToSteal INT, 

3296 street1CBChance INT, 

3297 street1CBDone INT, 

3298 street2CBChance INT, 

3299 street2CBDone INT, 

3300 street3CBChance INT, 

3301 street3CBDone INT, 

3302 street4CBChance INT, 

3303 street4CBDone INT,  

3304 foldToStreet1CBChance INT, 

3305 foldToStreet1CBDone INT, 

3306 foldToStreet2CBChance INT, 

3307 foldToStreet2CBDone INT, 

3308 foldToStreet3CBChance INT, 

3309 foldToStreet3CBDone INT, 

3310 foldToStreet4CBChance INT, 

3311 foldToStreet4CBDone INT,  

3312 common BIGINT, 

3313 committed BIGINT, 

3314 winnings BIGINT, 

3315 rake BIGINT, 

3316 rakeDealt NUMERIC, 

3317 rakeContributed NUMERIC, 

3318 rakeWeighted NUMERIC, 

3319 totalProfit BIGINT, 

3320 allInEV NUMERIC, 

3321 showdownWinnings BIGINT, 

3322 nonShowdownWinnings BIGINT,  

3323 street1CheckCallRaiseChance INT, 

3324 street1CheckCallDone INT, 

3325 street1CheckRaiseDone INT, 

3326 street2CheckCallRaiseChance INT, 

3327 street2CheckCallDone INT, 

3328 street2CheckRaiseDone INT, 

3329 street3CheckCallRaiseChance INT, 

3330 street3CheckCallDone INT, 

3331 street3CheckRaiseDone INT, 

3332 street4CheckCallRaiseChance INT, 

3333 street4CheckCallDone INT, 

3334 street4CheckRaiseDone INT, 

3335 street0Calls INT, 

3336 street1Calls INT, 

3337 street2Calls INT, 

3338 street3Calls INT, 

3339 street4Calls INT, 

3340 street0Bets INT, 

3341 street1Bets INT, 

3342 street2Bets INT, 

3343 street3Bets INT, 

3344 street4Bets INT, 

3345 street0Raises INT, 

3346 street1Raises INT, 

3347 street2Raises INT, 

3348 street3Raises INT, 

3349 street4Raises INT, 

3350 street1Discards INT, 

3351 street2Discards INT, 

3352 street3Discards INT) 

3353 ENGINE=INNODB 

3354 """ 

3355 

3356 elif db_server == 'postgresql': 

3357 self.query['createTourneysCacheTable'] = """CREATE TABLE TourneysCache ( 

3358 id SERIAL, PRIMARY KEY (id), 

3359 sessionId INT, FOREIGN KEY (sessionId) REFERENCES Sessions(id), 

3360 startTime timestamp without time zone NOT NULL, 

3361 endTime timestamp without time zone NOT NULL, 

3362 tourneyId INT, FOREIGN KEY (tourneyId) REFERENCES Tourneys(id), 

3363 playerId INT, FOREIGN KEY (playerId) REFERENCES Players(id), 

3364 n INT,  

3365 street0VPIChance INT, 

3366 street0VPI INT, 

3367 street0AggrChance INT, 

3368 street0Aggr INT, 

3369 street0CalledRaiseChance INT, 

3370 street0CalledRaiseDone INT, 

3371 street0_2BChance INT, 

3372 street0_2BDone INT, 

3373 street0_3BChance INT, 

3374 street0_3BDone INT, 

3375 street0_4BChance INT, 

3376 street0_4BDone INT, 

3377 street0_C4BChance INT, 

3378 street0_C4BDone INT, 

3379 street0_FoldTo2BChance INT, 

3380 street0_FoldTo2BDone INT, 

3381 street0_FoldTo3BChance INT, 

3382 street0_FoldTo3BDone INT, 

3383 street0_FoldTo4BChance INT, 

3384 street0_FoldTo4BDone INT, 

3385 street0_SqueezeChance INT, 

3386 street0_SqueezeDone INT, 

3387 raiseToStealChance INT, 

3388 raiseToStealDone INT, 

3389 stealChance INT, 

3390 stealDone INT, 

3391 success_Steal INT, 

3392 street1Seen INT, 

3393 street2Seen INT, 

3394 street3Seen INT, 

3395 street4Seen INT, 

3396 sawShowdown INT, 

3397 street1Aggr INT, 

3398 street2Aggr INT, 

3399 street3Aggr INT, 

3400 street4Aggr INT, 

3401 otherRaisedStreet0 INT, 

3402 otherRaisedStreet1 INT, 

3403 otherRaisedStreet2 INT, 

3404 otherRaisedStreet3 INT, 

3405 otherRaisedStreet4 INT, 

3406 foldToOtherRaisedStreet0 INT, 

3407 foldToOtherRaisedStreet1 INT, 

3408 foldToOtherRaisedStreet2 INT, 

3409 foldToOtherRaisedStreet3 INT, 

3410 foldToOtherRaisedStreet4 INT,  

3411 wonWhenSeenStreet1 INT, 

3412 wonWhenSeenStreet2 INT, 

3413 wonWhenSeenStreet3 INT, 

3414 wonWhenSeenStreet4 INT, 

3415 wonAtSD INT, 

3416 raiseFirstInChance INT, 

3417 raisedFirstIn INT, 

3418 foldBbToStealChance INT, 

3419 foldedBbToSteal INT, 

3420 foldSbToStealChance INT, 

3421 foldedSbToSteal INT, 

3422 street1CBChance INT, 

3423 street1CBDone INT, 

3424 street2CBChance INT, 

3425 street2CBDone INT, 

3426 street3CBChance INT, 

3427 street3CBDone INT, 

3428 street4CBChance INT, 

3429 street4CBDone INT, 

3430 foldToStreet1CBChance INT, 

3431 foldToStreet1CBDone INT, 

3432 foldToStreet2CBChance INT, 

3433 foldToStreet2CBDone INT, 

3434 foldToStreet3CBChance INT, 

3435 foldToStreet3CBDone INT, 

3436 foldToStreet4CBChance INT, 

3437 foldToStreet4CBDone INT, 

3438 common BIGINT, 

3439 committed BIGINT, 

3440 winnings BIGINT, 

3441 rake BIGINT, 

3442 rakeDealt NUMERIC, 

3443 rakeContributed NUMERIC, 

3444 rakeWeighted NUMERIC, 

3445 totalProfit BIGINT, 

3446 allInEV NUMERIC, 

3447 showdownWinnings BIGINT, 

3448 nonShowdownWinnings BIGINT, 

3449 street1CheckCallRaiseChance INT, 

3450 street1CheckCallDone INT, 

3451 street1CheckRaiseDone INT, 

3452 street2CheckCallRaiseChance INT, 

3453 street2CheckCallDone INT, 

3454 street2CheckRaiseDone INT, 

3455 street3CheckCallRaiseChance INT, 

3456 street3CheckCallDone INT, 

3457 street3CheckRaiseDone INT, 

3458 street4CheckCallRaiseChance INT, 

3459 street4CheckCallDone INT, 

3460 street4CheckRaiseDone INT, 

3461 street0Calls INT, 

3462 street1Calls INT, 

3463 street2Calls INT, 

3464 street3Calls INT, 

3465 street4Calls INT, 

3466 street0Bets INT, 

3467 street1Bets INT, 

3468 street2Bets INT, 

3469 street3Bets INT, 

3470 street4Bets INT, 

3471 street0Raises INT, 

3472 street1Raises INT, 

3473 street2Raises INT, 

3474 street3Raises INT, 

3475 street4Raises INT, 

3476 street1Discards INT, 

3477 street2Discards INT, 

3478 street3Discards INT) 

3479 """ 

3480 

3481 elif db_server == 'sqlite': 

3482 self.query['createTourneysCacheTable'] = """CREATE TABLE TourneysCache ( 

3483 id INTEGER PRIMARY KEY, 

3484 sessionId INT, 

3485 startTime timestamp NOT NULL, 

3486 endTime timestamp NOT NULL, 

3487 tourneyId INT, 

3488 playerId INT, 

3489 n INT, 

3490 street0VPIChance INT, 

3491 street0VPI INT, 

3492 street0AggrChance INT, 

3493 street0Aggr INT, 

3494 street0CalledRaiseChance INT, 

3495 street0CalledRaiseDone INT, 

3496 street0_2BChance INT, 

3497 street0_2BDone INT, 

3498 street0_3BChance INT, 

3499 street0_3BDone INT, 

3500 street0_4BChance INT, 

3501 street0_4BDone INT, 

3502 street0_C4BChance INT, 

3503 street0_C4BDone INT, 

3504 street0_FoldTo2BChance INT, 

3505 street0_FoldTo2BDone INT, 

3506 street0_FoldTo3BChance INT, 

3507 street0_FoldTo3BDone INT, 

3508 street0_FoldTo4BChance INT, 

3509 street0_FoldTo4BDone INT, 

3510 street0_SqueezeChance INT, 

3511 street0_SqueezeDone INT, 

3512 raiseToStealChance INT, 

3513 raiseToStealDone INT, 

3514 stealChance INT, 

3515 stealDone INT, 

3516 success_Steal INT, 

3517 street1Seen INT, 

3518 street2Seen INT, 

3519 street3Seen INT, 

3520 street4Seen INT, 

3521 sawShowdown INT, 

3522 street1Aggr INT, 

3523 street2Aggr INT, 

3524 street3Aggr INT, 

3525 street4Aggr INT, 

3526 otherRaisedStreet0 INT, 

3527 otherRaisedStreet1 INT, 

3528 otherRaisedStreet2 INT, 

3529 otherRaisedStreet3 INT, 

3530 otherRaisedStreet4 INT, 

3531 foldToOtherRaisedStreet0 INT, 

3532 foldToOtherRaisedStreet1 INT, 

3533 foldToOtherRaisedStreet2 INT, 

3534 foldToOtherRaisedStreet3 INT, 

3535 foldToOtherRaisedStreet4 INT,  

3536 wonWhenSeenStreet1 INT, 

3537 wonWhenSeenStreet2 INT, 

3538 wonWhenSeenStreet3 INT, 

3539 wonWhenSeenStreet4 INT, 

3540 wonAtSD INT, 

3541 raiseFirstInChance INT, 

3542 raisedFirstIn INT, 

3543 foldBbToStealChance INT, 

3544 foldedBbToSteal INT, 

3545 foldSbToStealChance INT, 

3546 foldedSbToSteal INT, 

3547 street1CBChance INT, 

3548 street1CBDone INT, 

3549 street2CBChance INT, 

3550 street2CBDone INT, 

3551 street3CBChance INT, 

3552 street3CBDone INT, 

3553 street4CBChance INT, 

3554 street4CBDone INT, 

3555 foldToStreet1CBChance INT, 

3556 foldToStreet1CBDone INT, 

3557 foldToStreet2CBChance INT, 

3558 foldToStreet2CBDone INT, 

3559 foldToStreet3CBChance INT, 

3560 foldToStreet3CBDone INT, 

3561 foldToStreet4CBChance INT, 

3562 foldToStreet4CBDone INT, 

3563 common INT, 

3564 committed INT, 

3565 winnings INT, 

3566 rake INT, 

3567 rakeDealt decimal, 

3568 rakeContributed decimal, 

3569 rakeWeighted decimal, 

3570 totalProfit INT, 

3571 allInEV decimal, 

3572 showdownWinnings INT, 

3573 nonShowdownWinnings INT, 

3574 street1CheckCallRaiseChance INT, 

3575 street1CheckCallDone INT, 

3576 street1CheckRaiseDone INT, 

3577 street2CheckCallRaiseChance INT, 

3578 street2CheckCallDone INT, 

3579 street2CheckRaiseDone INT, 

3580 street3CheckCallRaiseChance INT, 

3581 street3CheckCallDone INT, 

3582 street3CheckRaiseDone INT, 

3583 street4CheckCallRaiseChance INT, 

3584 street4CheckCallDone INT, 

3585 street4CheckRaiseDone INT, 

3586 street0Calls INT, 

3587 street1Calls INT, 

3588 street2Calls INT, 

3589 street3Calls INT, 

3590 street4Calls INT, 

3591 street0Bets INT, 

3592 street1Bets INT, 

3593 street2Bets INT, 

3594 street3Bets INT, 

3595 street4Bets INT, 

3596 street0Raises INT, 

3597 street1Raises INT, 

3598 street2Raises INT, 

3599 street3Raises INT, 

3600 street4Raises INT, 

3601 street1Discards INT, 

3602 street2Discards INT, 

3603 street3Discards INT) 

3604 """ 

3605 

3606 if db_server == 'mysql': 

3607 self.query['addTourneyIndex'] = """ALTER TABLE Tourneys ADD UNIQUE INDEX siteTourneyNo(siteTourneyNo, tourneyTypeId)""" 

3608 elif db_server == 'postgresql': 

3609 self.query['addTourneyIndex'] = """CREATE UNIQUE INDEX siteTourneyNo ON Tourneys (siteTourneyNo, tourneyTypeId)""" 

3610 elif db_server == 'sqlite': 

3611 self.query['addTourneyIndex'] = """CREATE UNIQUE INDEX siteTourneyNo ON Tourneys (siteTourneyNo, tourneyTypeId)""" 

3612 

3613 if db_server == 'mysql': 

3614 self.query['addHandsIndex'] = """ALTER TABLE Hands ADD UNIQUE INDEX siteHandNo(siteHandNo, gametypeId<heroseat>)""" 

3615 elif db_server == 'postgresql': 

3616 self.query['addHandsIndex'] = """CREATE UNIQUE INDEX siteHandNo ON Hands (siteHandNo, gametypeId<heroseat>)""" 

3617 elif db_server == 'sqlite': 

3618 self.query['addHandsIndex'] = """CREATE UNIQUE INDEX siteHandNo ON Hands (siteHandNo, gametypeId<heroseat>)""" 

3619 

3620 if db_server == 'mysql': 

3621 self.query['addPlayersSeat'] = """ALTER TABLE HandsPlayers ADD UNIQUE INDEX playerSeat_idx(handId, seatNo)""" 

3622 elif db_server == 'postgresql': 

3623 self.query['addPlayersSeat'] = """CREATE UNIQUE INDEX playerSeat_idx ON HandsPlayers (handId, seatNo)""" 

3624 elif db_server == 'sqlite': 

3625 self.query['addPlayersSeat'] = """CREATE UNIQUE INDEX playerSeat_idx ON HandsPlayers (handId, seatNo)""" 

3626 

3627 if db_server == 'mysql': 

3628 self.query['addHeroSeat'] = """ALTER TABLE Hands ADD UNIQUE INDEX heroSeat_idx(id, heroSeat)""" 

3629 elif db_server == 'postgresql': 

3630 self.query['addHeroSeat'] = """CREATE UNIQUE INDEX heroSeat_idx ON Hands (id, heroSeat)""" 

3631 elif db_server == 'sqlite': 

3632 self.query['addHeroSeat'] = """CREATE UNIQUE INDEX heroSeat_idx ON Hands (id, heroSeat)""" 

3633 

3634 if db_server == 'mysql': 

3635 self.query['addHandsPlayersSeat'] = """ALTER TABLE HandsPlayers ADD UNIQUE INDEX handsPlayerSeat_idx(handId, seatNo)""" 

3636 elif db_server == 'postgresql': 

3637 self.query['addHandsPlayersSeat'] = """CREATE UNIQUE INDEX handsPlayerSeat_idx ON Hands (handId, seatNo)""" 

3638 elif db_server == 'sqlite': 

3639 self.query['addHandsPlayersSeat'] = """CREATE UNIQUE INDEX handsPlayerSeat_idx ON Hands (handId, seatNo)""" 

3640 

3641 if db_server == 'mysql': 

3642 self.query['addPlayersIndex'] = """ALTER TABLE Players ADD UNIQUE INDEX name(name, siteId)""" 

3643 elif db_server == 'postgresql': 

3644 self.query['addPlayersIndex'] = """CREATE UNIQUE INDEX name ON Players (name, siteId)""" 

3645 elif db_server == 'sqlite': 

3646 self.query['addPlayersIndex'] = """CREATE UNIQUE INDEX name ON Players (name, siteId)""" 

3647 

3648 if db_server == 'mysql': 

3649 self.query['addTPlayersIndex'] = """ALTER TABLE TourneysPlayers ADD UNIQUE INDEX _tourneyId(tourneyId, playerId, entryId)""" 

3650 elif db_server == 'postgresql': 

3651 self.query['addTPlayersIndex'] = """CREATE UNIQUE INDEX tourneyId ON TourneysPlayers (tourneyId, playerId, entryId)""" 

3652 elif db_server == 'sqlite': 

3653 self.query['addTPlayersIndex'] = """CREATE UNIQUE INDEX tourneyId ON TourneysPlayers (tourneyId, playerId, entryId)""" 

3654 

3655 if db_server == 'mysql': 

3656 self.query['addStartCardsIndex'] = """ALTER TABLE StartCards ADD UNIQUE INDEX cards_idx (category, rank)""" 

3657 elif db_server == 'postgresql': 

3658 self.query['addStartCardsIndex'] = """CREATE UNIQUE INDEX cards_idx ON StartCards (category, rank)""" 

3659 elif db_server == 'sqlite': 

3660 self.query['addStartCardsIndex'] = """CREATE UNIQUE INDEX cards_idx ON StartCards (category, rank)""" 

3661 

3662 if db_server == 'mysql': 

3663 self.query['addSeatsIndex'] = """ALTER TABLE Hands ADD INDEX seats_idx (seats)""" 

3664 elif db_server == 'postgresql': 

3665 self.query['addSeatsIndex'] = """CREATE INDEX seats_idx ON Hands (seats)""" 

3666 elif db_server == 'sqlite': 

3667 self.query['addSeatsIndex'] = """CREATE INDEX seats_idx ON Hands (seats)""" 

3668 

3669 if db_server == 'mysql': 

3670 self.query['addPositionIndex'] = """ALTER TABLE HandsPlayers ADD INDEX position_idx (position)""" 

3671 elif db_server == 'postgresql': 

3672 self.query['addPositionIndex'] = """CREATE INDEX position_idx ON HandsPlayers (position)""" 

3673 elif db_server == 'sqlite': 

3674 self.query['addPositionIndex'] = """CREATE INDEX position_idx ON HandsPlayers (position)""" 

3675 

3676 if db_server == 'mysql': 

3677 self.query['addStartCashIndex'] = """ALTER TABLE HandsPlayers ADD INDEX cash_idx (startCash)""" 

3678 elif db_server == 'postgresql': 

3679 self.query['addStartCashIndex'] = """CREATE INDEX cash_idx ON HandsPlayers (startCash)""" 

3680 elif db_server == 'sqlite': 

3681 self.query['addStartCashIndex'] = """CREATE INDEX cash_idx ON HandsPlayers (startCash)""" 

3682 

3683 if db_server == 'mysql': 

3684 self.query['addEffStackIndex'] = """ALTER TABLE HandsPlayers ADD INDEX eff_stack_idx (effStack)""" 

3685 elif db_server == 'postgresql': 

3686 self.query['addEffStackIndex'] = """CREATE INDEX eff_stack_idx ON HandsPlayers (effStack)""" 

3687 elif db_server == 'sqlite': 

3688 self.query['addEffStackIndex'] = """CREATE INDEX eff_stack_idx ON HandsPlayers (effStack)""" 

3689 

3690 if db_server == 'mysql': 

3691 self.query['addTotalProfitIndex'] = """ALTER TABLE HandsPlayers ADD INDEX profit_idx (totalProfit)""" 

3692 elif db_server == 'postgresql': 

3693 self.query['addTotalProfitIndex'] = """CREATE INDEX profit_idx ON HandsPlayers (totalProfit)""" 

3694 elif db_server == 'sqlite': 

3695 self.query['addTotalProfitIndex'] = """CREATE INDEX profit_idx ON HandsPlayers (totalProfit)""" 

3696 

3697 if db_server == 'mysql': 

3698 self.query['addWinningsIndex'] = """ALTER TABLE HandsPlayers ADD INDEX winnings_idx (winnings)""" 

3699 elif db_server == 'postgresql': 

3700 self.query['addWinningsIndex'] = """CREATE INDEX winnings_idx ON HandsPlayers (winnings)""" 

3701 elif db_server == 'sqlite': 

3702 self.query['addWinningsIndex'] = """CREATE INDEX winnings_idx ON HandsPlayers (winnings)""" 

3703 

3704 if db_server == 'mysql': 

3705 self.query['addFinalPotIndex'] = """ALTER TABLE Hands ADD INDEX pot_idx (finalPot)""" 

3706 elif db_server == 'postgresql': 

3707 self.query['addFinalPotIndex'] = """CREATE INDEX pot_idx ON Hands (finalPot)""" 

3708 elif db_server == 'sqlite': 

3709 self.query['addFinalPotIndex'] = """CREATE INDEX pot_idx ON Hands (finalPot)""" 

3710 

3711 if db_server == 'mysql': 

3712 self.query['addStreetIndex'] = """ALTER TABLE HandsStove ADD INDEX street_idx (streetId, boardId)""" 

3713 elif db_server == 'postgresql': 

3714 self.query['addStreetIndex'] = """CREATE INDEX street_idx ON HandsStove (streetId, boardId)""" 

3715 elif db_server == 'sqlite': 

3716 self.query['addStreetIndex'] = """CREATE INDEX street_idx ON HandsStove (streetId, boardId)""" 

3717 

3718 self.query['addSessionsCacheCompundIndex'] = """CREATE INDEX SessionsCache_Compound_idx ON SessionsCache(gametypeId, playerId)""" 

3719 self.query['addTourneysCacheCompundIndex'] = """CREATE UNIQUE INDEX TourneysCache_Compound_idx ON TourneysCache(tourneyId, playerId)""" 

3720 self.query['addHudCacheCompundIndex'] = """CREATE UNIQUE INDEX HudCache_Compound_idx ON HudCache(gametypeId, playerId, seats, position, tourneyTypeId, styleKey)""" 

3721 

3722 self.query['addCardsCacheCompundIndex'] = """CREATE UNIQUE INDEX CardsCache_Compound_idx ON CardsCache(weekId, monthId, gametypeId, tourneyTypeId, playerId, startCards)""" 

3723 self.query['addPositionsCacheCompundIndex'] = """CREATE UNIQUE INDEX PositionsCache_Compound_idx ON PositionsCache(weekId, monthId, gametypeId, tourneyTypeId, playerId, seats, maxPosition, position)""" 

3724 

3725 # (left(file, 255)) is not valid syntax on postgres psycopg2 on windows (postgres v8.4) 

3726 # error thrown is HINT: "No function matches the given name and argument types. You might need to add explicit type casts." 

3727 # so we will just create the index with the full filename. 

3728 if db_server == 'mysql': 

3729 self.query['addFilesIndex'] = """CREATE UNIQUE INDEX index_file ON Files (file(255))""" 

3730 elif db_server == 'postgresql': 

3731 self.query['addFilesIndex'] = """CREATE UNIQUE INDEX index_file ON Files (file)""" 

3732 elif db_server == 'sqlite': 

3733 self.query['addFilesIndex'] = """CREATE UNIQUE INDEX index_file ON Files (file)""" 

3734 

3735 self.query['addTableNameIndex'] = """CREATE INDEX index_tableName ON Hands (tableName)""" 

3736 self.query['addPlayerNameIndex'] = """CREATE INDEX index_playerName ON Players (name)""" 

3737 self.query['addPlayerHeroesIndex'] = """CREATE INDEX player_heroes ON Players (hero)""" 

3738 

3739 self.query['get_last_hand'] = "select max(id) from Hands" 

3740 

3741 self.query['get_last_date'] = "SELECT MAX(startTime) FROM Hands" 

3742 

3743 self.query['get_first_date'] = "SELECT MIN(startTime) FROM Hands" 

3744 

3745 self.query['get_player_id'] = """ 

3746 select Players.id AS player_id  

3747 from Players, Sites 

3748 where Players.name = %s 

3749 and Sites.name = %s 

3750 and Players.siteId = Sites.id 

3751 """ 

3752 

3753 self.query['get_player_names'] = """ 

3754 select p.name 

3755 from Players p 

3756 where lower(p.name) like lower(%s) 

3757 and (p.siteId = %s or %s = -1) 

3758 """ 

3759 

3760 self.query['get_gameinfo_from_hid'] = """ 

3761 SELECT 

3762 s.name, 

3763 g.category, 

3764 g.base, 

3765 g.type, 

3766 g.limitType, 

3767 g.hilo, 

3768 round(g.smallBlind / 100.0,2), 

3769 round(g.bigBlind / 100.0,2), 

3770 round(g.smallBet / 100.0,2), 

3771 round(g.bigBet / 100.0,2), 

3772 g.currency, 

3773 h.gametypeId, 

3774 g.split 

3775 FROM 

3776 Hands as h, 

3777 Sites as s, 

3778 Gametypes as g, 

3779 HandsPlayers as hp, 

3780 Players as p 

3781 WHERE 

3782 h.id = %s 

3783 and g.id = h.gametypeId 

3784 and hp.handId = h.id 

3785 and p.id = hp.playerId 

3786 and s.id = p.siteId 

3787 limit 1 

3788 """ 

3789 

3790 self.query['get_stats_from_hand'] = """ 

3791 SELECT hc.playerId AS player_id, 

3792 hp.seatNo AS seat, 

3793 p.name AS screen_name, 

3794 sum(hc.n) AS n, 

3795 sum(hc.street0VPIChance) AS vpip_opp, 

3796 sum(hc.street0VPI) AS vpip, 

3797 sum(hc.street0AggrChance) AS pfr_opp, 

3798 sum(hc.street0Aggr) AS pfr, 

3799 sum(hc.street0CalledRaiseChance) AS CAR_opp_0, 

3800 sum(hc.street0CalledRaiseDone) AS CAR_0, 

3801 sum(hc.street0_3BChance) AS TB_opp_0, 

3802 sum(hc.street0_3BDone) AS TB_0, 

3803 sum(hc.street0_4BChance) AS FB_opp_0, 

3804 sum(hc.street0_4BDone) AS FB_0, 

3805 sum(hc.street0_C4BChance) AS CFB_opp_0, 

3806 sum(hc.street0_C4BDone) AS CFB_0, 

3807 sum(hc.street0_FoldTo3BChance) AS F3B_opp_0, 

3808 sum(hc.street0_FoldTo3BDone) AS F3B_0, 

3809 sum(hc.street0_FoldTo4BChance) AS F4B_opp_0, 

3810 sum(hc.street0_FoldTo4BDone) AS F4B_0, 

3811 sum(hc.street0_SqueezeChance) AS SQZ_opp_0, 

3812 sum(hc.street0_SqueezeDone) AS SQZ_0, 

3813 sum(hc.raiseToStealChance) AS RTS_opp, 

3814 sum(hc.raiseToStealDone) AS RTS, 

3815 sum(hc.success_Steal) AS SUC_ST, 

3816 sum(hc.street1Seen) AS saw_f, 

3817 sum(hc.street1Seen) AS saw_1, 

3818 sum(hc.street2Seen) AS saw_2, 

3819 sum(hc.street3Seen) AS saw_3, 

3820 sum(hc.street4Seen) AS saw_4, 

3821 sum(hc.sawShowdown) AS sd, 

3822 sum(hc.street1Aggr) AS aggr_1, 

3823 sum(hc.street2Aggr) AS aggr_2, 

3824 sum(hc.street3Aggr) AS aggr_3, 

3825 sum(hc.street4Aggr) AS aggr_4, 

3826 sum(hc.otherRaisedStreet1) AS was_raised_1, 

3827 sum(hc.otherRaisedStreet2) AS was_raised_2, 

3828 sum(hc.otherRaisedStreet3) AS was_raised_3, 

3829 sum(hc.otherRaisedStreet4) AS was_raised_4, 

3830 sum(hc.foldToOtherRaisedStreet1) AS f_freq_1, 

3831 sum(hc.foldToOtherRaisedStreet2) AS f_freq_2, 

3832 sum(hc.foldToOtherRaisedStreet3) AS f_freq_3, 

3833 sum(hc.foldToOtherRaisedStreet4) AS f_freq_4, 

3834 sum(hc.wonWhenSeenStreet1) AS w_w_s_1, 

3835 sum(hc.wonAtSD) AS wmsd, 

3836 sum(hc.stealChance) AS steal_opp, 

3837 sum(hc.stealDone) AS steal, 

3838 sum(hc.foldSbToStealChance) AS SBstolen, 

3839 sum(hc.foldedSbToSteal) AS SBnotDef, 

3840 sum(hc.foldBbToStealChance) AS BBstolen, 

3841 sum(hc.foldedBbToSteal) AS BBnotDef, 

3842 sum(hc.street1CBChance) AS CB_opp_1, 

3843 sum(hc.street1CBDone) AS CB_1, 

3844 sum(hc.street2CBChance) AS CB_opp_2, 

3845 sum(hc.street2CBDone) AS CB_2, 

3846 sum(hc.street3CBChance) AS CB_opp_3, 

3847 sum(hc.street3CBDone) AS CB_3, 

3848 sum(hc.street4CBChance) AS CB_opp_4, 

3849 sum(hc.street4CBDone) AS CB_4, 

3850 sum(hc.foldToStreet1CBChance) AS f_cb_opp_1, 

3851 sum(hc.foldToStreet1CBDone) AS f_cb_1, 

3852 sum(hc.foldToStreet2CBChance) AS f_cb_opp_2, 

3853 sum(hc.foldToStreet2CBDone) AS f_cb_2, 

3854 sum(hc.foldToStreet3CBChance) AS f_cb_opp_3, 

3855 sum(hc.foldToStreet3CBDone) AS f_cb_3, 

3856 sum(hc.foldToStreet4CBChance) AS f_cb_opp_4, 

3857 sum(hc.foldToStreet4CBDone) AS f_cb_4, 

3858 sum(hc.totalProfit) AS net, 

3859 sum(gt.bigblind * hc.n) AS bigblind, 

3860 sum(hc.street1CheckCallRaiseChance) AS ccr_opp_1, 

3861 sum(hc.street1CheckCallDone) AS cc_1, 

3862 sum(hc.street1CheckRaiseDone) AS cr_1, 

3863 sum(hc.street2CheckCallRaiseChance) AS ccr_opp_2, 

3864 sum(hc.street2CheckCallDone) AS cc_2, 

3865 sum(hc.street2CheckRaiseDone) AS cr_2, 

3866 sum(hc.street3CheckCallRaiseChance) AS ccr_opp_3, 

3867 sum(hc.street3CheckCallDone) AS cc_3, 

3868 sum(hc.street3CheckRaiseDone) AS cr_3, 

3869 sum(hc.street4CheckCallRaiseChance) AS ccr_opp_4, 

3870 sum(hc.street4CheckCallDone) AS cc_4 

3871 sum(hc.street4CheckRaiseDone) AS cr_4 

3872 sum(hc.street0Calls) AS call_0, 

3873 sum(hc.street1Calls) AS call_1, 

3874 sum(hc.street2Calls) AS call_2, 

3875 sum(hc.street3Calls) AS call_3, 

3876 sum(hc.street4Calls) AS call_4, 

3877 sum(hc.street0Bets) AS bet_0, 

3878 sum(hc.street1Bets) AS bet_1, 

3879 sum(hc.street2Bets) AS bet_2, 

3880 sum(hc.street3Bets) AS bet_3, 

3881 sum(hc.street4Bets) AS bet_4, 

3882 sum(hc.street0Raises) AS raise_0, 

3883 sum(hc.street1Raises) AS raise_1, 

3884 sum(hc.street2Raises) AS raise_2, 

3885 sum(hc.street3Raises) AS raise_3, 

3886 sum(hc.street4Raises) AS raise_4 

3887 FROM Hands h 

3888 INNER JOIN HandsPlayers hp ON (hp.handId = h.id) 

3889 INNER JOIN HudCache hc ON ( hc.PlayerId = hp.PlayerId+0 

3890 AND hc.gametypeId+0 = h.gametypeId+0) 

3891 INNER JOIN Players p ON (p.id = hp.PlayerId+0) 

3892 INNER JOIN Gametypes gt ON (gt.id = hc.gametypeId) 

3893 WHERE h.id = %s 

3894 AND hc.styleKey > %s 

3895 /* styleKey is currently 'd' (for date) followed by a yyyymmdd 

3896 date key. Set it to 0000000 or similar to get all records */ 

3897 /* also check activeseats here even if only 3 groups eg 2-3/4-6/7+  

3898 e.g. could use a multiplier: 

3899 AND h.seats > X / 1.25 and hp.seats < X * 1.25 

3900 where X is the number of active players at the current table (and 

3901 1.25 would be a config value so user could change it) 

3902 */ 

3903 GROUP BY hc.PlayerId, hp.seatNo, p.name 

3904 ORDER BY hc.PlayerId, hp.seatNo, p.name 

3905 """ 

3906 

3907# same as above except stats are aggregated for all blind/limit levels 

3908 self.query['get_stats_from_hand_aggregated'] = """ 

3909 /* explain query plan */ 

3910 SELECT hc.playerId AS player_id, 

3911 max(case when hc.gametypeId = h.gametypeId 

3912 then hp.seatNo 

3913 else -1 

3914 end) AS seat, 

3915 p.name AS screen_name, 

3916 sum(hc.n) AS n, 

3917 sum(hc.street0VPIChance) AS vpip_opp, 

3918 sum(hc.street0VPI) AS vpip, 

3919 sum(hc.street0AggrChance) AS pfr_opp, 

3920 sum(hc.street0Aggr) AS pfr, 

3921 sum(hc.street0CalledRaiseChance) AS CAR_opp_0, 

3922 sum(hc.street0CalledRaiseDone) AS CAR_0, 

3923 sum(hc.street0_3BChance) AS TB_opp_0, 

3924 sum(hc.street0_3BDone) AS TB_0, 

3925 sum(hc.street0_4BChance) AS FB_opp_0, 

3926 sum(hc.street0_4BDone) AS FB_0, 

3927 sum(hc.street0_C4BChance) AS CFB_opp_0, 

3928 sum(hc.street0_C4BDone) AS CFB_0, 

3929 sum(hc.street0_FoldTo3BChance) AS F3B_opp_0, 

3930 sum(hc.street0_FoldTo3BDone) AS F3B_0, 

3931 sum(hc.street0_FoldTo4BChance) AS F4B_opp_0, 

3932 sum(hc.street0_FoldTo4BDone) AS F4B_0, 

3933 sum(hc.street0_SqueezeChance) AS SQZ_opp_0, 

3934 sum(hc.street0_SqueezeDone) AS SQZ_0, 

3935 sum(hc.raiseToStealChance) AS RTS_opp, 

3936 sum(hc.raiseToStealDone) AS RTS, 

3937 sum(hc.success_Steal) AS SUC_ST, 

3938 sum(hc.street1Seen) AS saw_f, 

3939 sum(hc.street1Seen) AS saw_1, 

3940 sum(hc.street2Seen) AS saw_2, 

3941 sum(hc.street3Seen) AS saw_3, 

3942 sum(hc.street4Seen) AS saw_4, 

3943 sum(hc.sawShowdown) AS sd, 

3944 sum(hc.street1Aggr) AS aggr_1, 

3945 sum(hc.street2Aggr) AS aggr_2, 

3946 sum(hc.street3Aggr) AS aggr_3, 

3947 sum(hc.street4Aggr) AS aggr_4, 

3948 sum(hc.otherRaisedStreet1) AS was_raised_1, 

3949 sum(hc.otherRaisedStreet2) AS was_raised_2, 

3950 sum(hc.otherRaisedStreet3) AS was_raised_3, 

3951 sum(hc.otherRaisedStreet4) AS was_raised_4, 

3952 sum(hc.foldToOtherRaisedStreet1) AS f_freq_1, 

3953 sum(hc.foldToOtherRaisedStreet2) AS f_freq_2, 

3954 sum(hc.foldToOtherRaisedStreet3) AS f_freq_3, 

3955 sum(hc.foldToOtherRaisedStreet4) AS f_freq_4, 

3956 sum(hc.wonWhenSeenStreet1) AS w_w_s_1, 

3957 sum(hc.wonAtSD) AS wmsd, 

3958 sum(hc.stealChance) AS steal_opp, 

3959 sum(hc.stealDone) AS steal, 

3960 sum(hc.foldSbToStealChance) AS SBstolen, 

3961 sum(hc.foldedSbToSteal) AS SBnotDef, 

3962 sum(hc.foldBbToStealChance) AS BBstolen, 

3963 sum(hc.foldedBbToSteal) AS BBnotDef, 

3964 sum(hc.street1CBChance) AS CB_opp_1, 

3965 sum(hc.street1CBDone) AS CB_1, 

3966 sum(hc.street2CBChance) AS CB_opp_2, 

3967 sum(hc.street2CBDone) AS CB_2, 

3968 sum(hc.street3CBChance) AS CB_opp_3, 

3969 sum(hc.street3CBDone) AS CB_3, 

3970 sum(hc.street4CBChance) AS CB_opp_4, 

3971 sum(hc.street4CBDone) AS CB_4, 

3972 sum(hc.foldToStreet1CBChance) AS f_cb_opp_1, 

3973 sum(hc.foldToStreet1CBDone) AS f_cb_1, 

3974 sum(hc.foldToStreet2CBChance) AS f_cb_opp_2, 

3975 sum(hc.foldToStreet2CBDone) AS f_cb_2, 

3976 sum(hc.foldToStreet3CBChance) AS f_cb_opp_3, 

3977 sum(hc.foldToStreet3CBDone) AS f_cb_3, 

3978 sum(hc.foldToStreet4CBChance) AS f_cb_opp_4, 

3979 sum(hc.foldToStreet4CBDone) AS f_cb_4, 

3980 sum(hc.totalProfit) AS net, 

3981 sum(gt.bigblind * hc.n) AS bigblind, 

3982 sum(hc.street1CheckCallRaiseChance) AS ccr_opp_1, 

3983 sum(hc.street1CheckCallDone) AS cc_1, 

3984 sum(hc.street1CheckRaiseDone) AS cr_1, 

3985 sum(hc.street2CheckCallRaiseChance) AS ccr_opp_2, 

3986 sum(hc.street2CheckCallDone) AS cc_2, 

3987 sum(hc.street2CheckRaiseDone) AS cr_2, 

3988 sum(hc.street3CheckCallRaiseChance) AS ccr_opp_3, 

3989 sum(hc.street3CheckCallDone) AS cc_3, 

3990 sum(hc.street3CheckRaiseDone) AS cr_3, 

3991 sum(hc.street4CheckCallRaiseChance) AS ccr_opp_4, 

3992 sum(hc.street4CheckCallDone) AS cc_4, 

3993 sum(hc.street4CheckRaiseDone) AS cr_4, 

3994 sum(hc.street0Calls) AS call_0, 

3995 sum(hc.street1Calls) AS call_1, 

3996 sum(hc.street2Calls) AS call_2, 

3997 sum(hc.street3Calls) AS call_3, 

3998 sum(hc.street4Calls) AS call_4, 

3999 sum(hc.street0Bets) AS bet_0, 

4000 sum(hc.street1Bets) AS bet_1, 

4001 sum(hc.street2Bets) AS bet_2, 

4002 sum(hc.street3Bets) AS bet_3, 

4003 sum(hc.street4Bets) AS bet_4, 

4004 sum(hc.street0Raises) AS raise_0, 

4005 sum(hc.street1Raises) AS raise_1, 

4006 sum(hc.street2Raises) AS raise_2, 

4007 sum(hc.street3Raises) AS raise_3, 

4008 sum(hc.street4Raises) AS raise_4 

4009 FROM Hands h 

4010 INNER JOIN HandsPlayers hp ON (hp.handId = h.id) 

4011 INNER JOIN HudCache hc ON (hc.playerId = hp.playerId) 

4012 INNER JOIN Players p ON (p.id = hc.playerId) 

4013 INNER JOIN Gametypes gt ON (gt.id = hc.gametypeId) 

4014 WHERE h.id = %s 

4015 AND ( /* 2 separate parts for hero and opponents */ 

4016 ( hp.playerId != %s 

4017 AND hc.styleKey > %s 

4018 AND hc.gametypeId+0 in 

4019 (SELECT gt1.id from Gametypes gt1, Gametypes gt2 

4020 WHERE gt1.siteid = gt2.siteid /* find gametypes where these match: */ 

4021 AND gt1.type = gt2.type /* ring/tourney */ 

4022 AND gt1.category = gt2.category /* holdem/stud*/ 

4023 AND gt1.limittype = gt2.limittype /* fl/nl */ 

4024 AND gt1.bigblind <= gt2.bigblind * %s /* bigblind similar size */ 

4025 AND gt1.bigblind >= gt2.bigblind / %s 

4026 AND gt2.id = %s) 

4027 AND hc.seats between %s and %s 

4028 ) 

4029 OR 

4030 ( hp.playerId = %s 

4031 AND hc.styleKey > %s 

4032 AND hc.gametypeId+0 in 

4033 (SELECT gt1.id from Gametypes gt1, Gametypes gt2 

4034 WHERE gt1.siteid = gt2.siteid /* find gametypes where these match: */ 

4035 AND gt1.type = gt2.type /* ring/tourney */ 

4036 AND gt1.category = gt2.category /* holdem/stud*/ 

4037 AND gt1.limittype = gt2.limittype /* fl/nl */ 

4038 AND gt1.bigblind <= gt2.bigblind * %s /* bigblind similar size */ 

4039 AND gt1.bigblind >= gt2.bigblind / %s 

4040 AND gt2.id = %s) 

4041 AND hc.seats between %s and %s 

4042 ) 

4043 ) 

4044 GROUP BY hc.PlayerId, p.name 

4045 ORDER BY hc.PlayerId, p.name 

4046 """ 

4047 # NOTES on above cursor: 

4048 # - Do NOT include %s inside query in a comment - the db api thinks  

4049 # they are actual arguments. 

4050 # - styleKey is currently 'd' (for date) followed by a yyyymmdd 

4051 # date key. Set it to 0000000 or similar to get all records 

4052 # Could also check activeseats here even if only 3 groups eg 2-3/4-6/7+  

4053 # e.g. could use a multiplier: 

4054 # AND h.seats > %s / 1.25 and hp.seats < %s * 1.25 

4055 # where %s is the number of active players at the current table (and 

4056 # 1.25 would be a config value so user could change it) 

4057 

4058 if db_server == 'mysql': 

4059 self.query['get_stats_from_hand_session'] = """ 

4060 SELECT hp.playerId AS player_id, /* playerId and seats must */ 

4061 h.seats AS seats, /* be first and second field */ 

4062 hp.handId AS hand_id, 

4063 hp.seatNo AS seat, 

4064 p.name AS screen_name, 

4065 1 AS n, 

4066 cast(hp2.street0VPIChance as SIGNED) AS vpip_opp, 

4067 cast(hp2.street0VPI as SIGNED) AS vpip, 

4068 cast(hp2.street0AggrChance as SIGNED) AS pfr_opp, 

4069 cast(hp2.street0Aggr as SIGNED) AS pfr, 

4070 cast(hp2.street0CalledRaiseChance as SIGNED) AS CAR_opp_0, 

4071 cast(hp2.street0CalledRaiseDone as SIGNED) AS CAR_0, 

4072 cast(hp2.street0_3BChance as SIGNED) AS TB_opp_0, 

4073 cast(hp2.street0_3BDone as SIGNED) AS TB_0, 

4074 cast(hp2.street0_4BChance as SIGNED) AS FB_opp_0, 

4075 cast(hp2.street0_4BDone as SIGNED) AS FB_0, 

4076 cast(hp2.street0_C4BChance as SIGNED) AS CFB_opp_0, 

4077 cast(hp2.street0_C4BDone as SIGNED) AS CFB_0, 

4078 cast(hp2.street0_FoldTo3BChance as SIGNED) AS F3B_opp_0, 

4079 cast(hp2.street0_FoldTo3BDone as SIGNED) AS F3B_0, 

4080 cast(hp2.street0_FoldTo4BChance as SIGNED) AS F4B_opp_0, 

4081 cast(hp2.street0_FoldTo4BDone as SIGNED) AS F4B_0, 

4082 cast(hp2.street0_SqueezeChance as SIGNED) AS SQZ_opp_0, 

4083 cast(hp2.street0_SqueezeDone as SIGNED) AS SQZ_0, 

4084 cast(hp2.raiseToStealChance as SIGNED) AS RTS_opp, 

4085 cast(hp2.raiseToStealDone as SIGNED) AS RTS, 

4086 cast(hp2.success_Steal as SIGNED) AS SUC_ST, 

4087 cast(hp2.street1Seen as SIGNED) AS saw_f, 

4088 cast(hp2.street1Seen as SIGNED) AS saw_1, 

4089 cast(hp2.street2Seen as SIGNED) AS saw_2, 

4090 cast(hp2.street3Seen as SIGNED) AS saw_3, 

4091 cast(hp2.street4Seen as SIGNED) AS saw_4, 

4092 cast(hp2.sawShowdown as SIGNED) AS sd, 

4093 cast(hp2.street1Aggr as SIGNED) AS aggr_1, 

4094 cast(hp2.street2Aggr as SIGNED) AS aggr_2, 

4095 cast(hp2.street3Aggr as SIGNED) AS aggr_3, 

4096 cast(hp2.street4Aggr as SIGNED) AS aggr_4, 

4097 cast(hp2.otherRaisedStreet1 as SIGNED) AS was_raised_1, 

4098 cast(hp2.otherRaisedStreet2 as SIGNED) AS was_raised_2, 

4099 cast(hp2.otherRaisedStreet3 as SIGNED) AS was_raised_3, 

4100 cast(hp2.otherRaisedStreet4 as SIGNED) AS was_raised_4, 

4101 cast(hp2.foldToOtherRaisedStreet1 as SIGNED) AS f_freq_1, 

4102 cast(hp2.foldToOtherRaisedStreet2 as SIGNED) AS f_freq_2, 

4103 cast(hp2.foldToOtherRaisedStreet3 as SIGNED) AS f_freq_3, 

4104 cast(hp2.foldToOtherRaisedStreet4 as SIGNED) AS f_freq_4, 

4105 cast(hp2.wonWhenSeenStreet1 as SIGNED) AS w_w_s_1, 

4106 cast(hp2.wonAtSD as SIGNED) AS wmsd, 

4107 cast(hp2.stealChance as SIGNED) AS steal_opp, 

4108 cast(hp2.stealDone as SIGNED) AS steal, 

4109 cast(hp2.foldSbToStealChance as SIGNED) AS SBstolen, 

4110 cast(hp2.foldedSbToSteal as SIGNED) AS SBnotDef, 

4111 cast(hp2.foldBbToStealChance as SIGNED) AS BBstolen, 

4112 cast(hp2.foldedBbToSteal as SIGNED) AS BBnotDef, 

4113 cast(hp2.street1CBChance as SIGNED) AS CB_opp_1, 

4114 cast(hp2.street1CBDone as SIGNED) AS CB_1, 

4115 cast(hp2.street2CBChance as SIGNED) AS CB_opp_2, 

4116 cast(hp2.street2CBDone as SIGNED) AS CB_2, 

4117 cast(hp2.street3CBChance as SIGNED) AS CB_opp_3, 

4118 cast(hp2.street3CBDone as SIGNED) AS CB_3, 

4119 cast(hp2.street4CBChance as SIGNED) AS CB_opp_4, 

4120 cast(hp2.street4CBDone as SIGNED) AS CB_4, 

4121 cast(hp2.foldToStreet1CBChance as SIGNED) AS f_cb_opp_1, 

4122 cast(hp2.foldToStreet1CBDone as SIGNED) AS f_cb_1, 

4123 cast(hp2.foldToStreet2CBChance as SIGNED) AS f_cb_opp_2, 

4124 cast(hp2.foldToStreet2CBDone as SIGNED) AS f_cb_2, 

4125 cast(hp2.foldToStreet3CBChance as SIGNED) AS f_cb_opp_3, 

4126 cast(hp2.foldToStreet3CBDone as SIGNED) AS f_cb_3, 

4127 cast(hp2.foldToStreet4CBChance as SIGNED) AS f_cb_opp_4, 

4128 cast(hp2.foldToStreet4CBDone as SIGNED) AS f_cb_4, 

4129 cast(hp2.totalProfit as SIGNED) AS net, 

4130 cast(gt.bigblind as SIGNED) AS bigblind, 

4131 cast(hp2.street1CheckCallRaiseChance as SIGNED) AS ccr_opp_1, 

4132 cast(hp2.street1CheckCallDone as SIGNED) AS cc_1, 

4133 cast(hp2.street1CheckRaiseDone as SIGNED) AS cr_1, 

4134 cast(hp2.street2CheckCallRaiseChance as SIGNED) AS ccr_opp_2, 

4135 cast(hp2.street2CheckCallDone as SIGNED) AS cc_2, 

4136 cast(hp2.street2CheckRaiseDone as SIGNED) AS cr_2, 

4137 cast(hp2.street3CheckCallRaiseChance as SIGNED) AS ccr_opp_3, 

4138 cast(hp2.street3CheckCallDone as SIGNED) AS cc_3, 

4139 cast(hp2.street3CheckRaiseDone as SIGNED) AS cr_3, 

4140 cast(hp2.street4CheckCallRaiseChance as SIGNED) AS ccr_opp_4, 

4141 cast(hp2.street4CheckCallDone as SIGNED) AS cc_4, 

4142 cast(hp2.street4CheckRaiseDone as SIGNED) AS cr_4, 

4143 cast(hp2.street0Calls as SIGNED) AS call_0, 

4144 cast(hp2.street1Calls as SIGNED) AS call_1, 

4145 cast(hp2.street2Calls as SIGNED) AS call_2, 

4146 cast(hp2.street3Calls as SIGNED) AS call_3, 

4147 cast(hp2.street4Calls as SIGNED) AS call_4, 

4148 cast(hp2.street0Bets as SIGNED) AS bet_0, 

4149 cast(hp2.street1Bets as SIGNED) AS bet_1, 

4150 cast(hp2.street2Bets as SIGNED) AS bet_2, 

4151 cast(hp2.street3Bets as SIGNED) AS bet_3, 

4152 cast(hp2.street4Bets as SIGNED) AS bet_4, 

4153 cast(hp2.street0Raises as SIGNED) AS raise_0, 

4154 cast(hp2.street1Raises as SIGNED) AS raise_1, 

4155 cast(hp2.street2Raises as SIGNED) AS raise_2, 

4156 cast(hp2.street3Raises as SIGNED) AS raise_3, 

4157 cast(hp2.street4Raises as SIGNED) AS raise_4 

4158 FROM 

4159 Hands h 

4160 INNER JOIN Hands h2 ON (h2.id >= %s AND h2.tableName = h.tableName) 

4161 INNER JOIN HandsPlayers hp ON (h.id = hp.handId) /* players in this hand */ 

4162 INNER JOIN HandsPlayers hp2 ON (hp2.playerId+0 = hp.playerId+0 AND (hp2.handId = h2.id+0)) /* other hands by these players */ 

4163 INNER JOIN Players p ON (p.id = hp2.PlayerId+0) 

4164 INNER JOIN Gametypes gt ON (gt.id = h2.gametypeId) 

4165 WHERE hp.handId = %s 

4166 /* check activeseats once this data returned (don't want to do that here as it might 

4167 assume a session ended just because the number of seats dipped for a few hands) 

4168 */ 

4169 AND ( /* 2 separate parts for hero and opponents */ 

4170 ( hp2.playerId != %s 

4171 AND h2.seats between %s and %s 

4172 ) 

4173 OR 

4174 ( hp2.playerId = %s 

4175 AND h2.seats between %s and %s 

4176 ) 

4177 ) 

4178 ORDER BY h.startTime desc, hp2.PlayerId 

4179 /* order rows by handstart descending so that we can stop reading rows when 

4180 there's a gap over X minutes between hands (ie. when we get back to start of 

4181 the session */ 

4182 """ 

4183 elif db_server == 'postgresql': 

4184 self.query['get_stats_from_hand_session'] = """ 

4185 SELECT hp.playerId AS player_id, 

4186 hp.handId AS hand_id, 

4187 hp.seatNo AS seat, 

4188 p.name AS screen_name, 

4189 h.seats AS seats, 

4190 1 AS n, 

4191 cast(hp2.street0VPIChance as <signed>integer) AS vpip_opp, 

4192 cast(hp2.street0VPI as <signed>integer) AS vpip, 

4193 cast(hp2.street0AggrChance as <signed>integer) AS pfr_opp, 

4194 cast(hp2.street0Aggr as <signed>integer) AS pfr, 

4195 cast(hp2.street0CalledRaiseChance as <signed>integer) AS CAR_opp_0, 

4196 cast(hp2.street0CalledRaiseDone as <signed>integer) AS CAR_0, 

4197 cast(hp2.street0_3BChance as <signed>integer) AS TB_opp_0, 

4198 cast(hp2.street0_3BDone as <signed>integer) AS TB_0, 

4199 cast(hp2.street0_4BChance as <signed>integer) AS FB_opp_0, 

4200 cast(hp2.street0_4BDone as <signed>integer) AS FB_0, 

4201 cast(hp2.street0_C4BChance as <signed>integer) AS CFB_opp_0, 

4202 cast(hp2.street0_C4BDone as <signed>integer) AS CFB_0, 

4203 cast(hp2.street0_FoldTo3BChance as <signed>integer) AS F3B_opp_0, 

4204 cast(hp2.street0_FoldTo3BDone as <signed>integer) AS F3B_0, 

4205 cast(hp2.street0_FoldTo4BChance as <signed>integer) AS F4B_opp_0, 

4206 cast(hp2.street0_FoldTo4BDone as <signed>integer) AS F4B_0, 

4207 cast(hp2.street0_SqueezeChance as <signed>integer) AS SQZ_opp_0, 

4208 cast(hp2.street0_SqueezeDone as <signed>integer) AS SQZ_0, 

4209 cast(hp2.raiseToStealChance as <signed>integer) AS RTS_opp, 

4210 cast(hp2.raiseToStealDone as <signed>integer) AS RTS, 

4211 cast(hp2.success_Steal as <signed>integer) AS SUC_ST, 

4212 cast(hp2.street1Seen as <signed>integer) AS saw_f, 

4213 cast(hp2.street1Seen as <signed>integer) AS saw_1, 

4214 cast(hp2.street2Seen as <signed>integer) AS saw_2, 

4215 cast(hp2.street3Seen as <signed>integer) AS saw_3, 

4216 cast(hp2.street4Seen as <signed>integer) AS saw_4, 

4217 cast(hp2.sawShowdown as <signed>integer) AS sd, 

4218 cast(hp2.street1Aggr as <signed>integer) AS aggr_1, 

4219 cast(hp2.street2Aggr as <signed>integer) AS aggr_2, 

4220 cast(hp2.street3Aggr as <signed>integer) AS aggr_3, 

4221 cast(hp2.street4Aggr as <signed>integer) AS aggr_4, 

4222 cast(hp2.otherRaisedStreet1 as <signed>integer) AS was_raised_1, 

4223 cast(hp2.otherRaisedStreet2 as <signed>integer) AS was_raised_2, 

4224 cast(hp2.otherRaisedStreet3 as <signed>integer) AS was_raised_3, 

4225 cast(hp2.otherRaisedStreet4 as <signed>integer) AS was_raised_4, 

4226 cast(hp2.foldToOtherRaisedStreet1 as <signed>integer) AS f_freq_1, 

4227 cast(hp2.foldToOtherRaisedStreet2 as <signed>integer) AS f_freq_2, 

4228 cast(hp2.foldToOtherRaisedStreet3 as <signed>integer) AS f_freq_3, 

4229 cast(hp2.foldToOtherRaisedStreet4 as <signed>integer) AS f_freq_4, 

4230 cast(hp2.wonWhenSeenStreet1 as <signed>integer) AS w_w_s_1, 

4231 cast(hp2.wonAtSD as <signed>integer) AS wmsd, 

4232 cast(hp2.stealChance as <signed>integer) AS steal_opp, 

4233 cast(hp2.stealDone as <signed>integer) AS steal, 

4234 cast(hp2.foldSbToStealChance as <signed>integer) AS SBstolen, 

4235 cast(hp2.foldedSbToSteal as <signed>integer) AS SBnotDef, 

4236 cast(hp2.foldBbToStealChance as <signed>integer) AS BBstolen, 

4237 cast(hp2.foldedBbToSteal as <signed>integer) AS BBnotDef, 

4238 cast(hp2.street1CBChance as <signed>integer) AS CB_opp_1, 

4239 cast(hp2.street1CBDone as <signed>integer) AS CB_1, 

4240 cast(hp2.street2CBChance as <signed>integer) AS CB_opp_2, 

4241 cast(hp2.street2CBDone as <signed>integer) AS CB_2, 

4242 cast(hp2.street3CBChance as <signed>integer) AS CB_opp_3, 

4243 cast(hp2.street3CBDone as <signed>integer) AS CB_3, 

4244 cast(hp2.street4CBChance as <signed>integer) AS CB_opp_4, 

4245 cast(hp2.street4CBDone as <signed>integer) AS CB_4, 

4246 cast(hp2.foldToStreet1CBChance as <signed>integer) AS f_cb_opp_1, 

4247 cast(hp2.foldToStreet1CBDone as <signed>integer) AS f_cb_1, 

4248 cast(hp2.foldToStreet2CBChance as <signed>integer) AS f_cb_opp_2, 

4249 cast(hp2.foldToStreet2CBDone as <signed>integer) AS f_cb_2, 

4250 cast(hp2.foldToStreet3CBChance as <signed>integer) AS f_cb_opp_3, 

4251 cast(hp2.foldToStreet3CBDone as <signed>integer) AS f_cb_3, 

4252 cast(hp2.foldToStreet4CBChance as <signed>integer) AS f_cb_opp_4, 

4253 cast(hp2.foldToStreet4CBDone as <signed>integer) AS f_cb_4, 

4254 cast(hp2.totalProfit as <signed>bigint) AS net, 

4255 cast(gt.bigblind as <signed>bigint) AS bigblind, 

4256 cast(hp2.street1CheckCallRaiseChance as <signed>integer) AS ccr_opp_1, 

4257 cast(hp2.street1CheckCallDone as <signed>integer) AS cc_1, 

4258 cast(hp2.street1CheckRaiseDone as <signed>integer) AS cr_1, 

4259 cast(hp2.street2CheckCallRaiseChance as <signed>integer) AS ccr_opp_2, 

4260 cast(hp2.street2CheckCallDone as <signed>integer) AS cc_2, 

4261 cast(hp2.street2CheckRaiseDone as <signed>integer) AS cr_2, 

4262 cast(hp2.street3CheckCallRaiseChance as <signed>integer) AS ccr_opp_3, 

4263 cast(hp2.street3CheckCallDone as <signed>integer) AS cc_3, 

4264 cast(hp2.street3CheckRaiseDone as <signed>integer) AS cr_3, 

4265 cast(hp2.street4CheckCallRaiseChance as <signed>integer) AS ccr_opp_4, 

4266 cast(hp2.street4CheckCallDone as <signed>integer) AS cc_4, 

4267 cast(hp2.street4CheckRaiseDone as <signed>integer) AS cr_4, 

4268 cast(hp2.street0Calls as <signed>integer) AS call_0, 

4269 cast(hp2.street1Calls as <signed>integer) AS call_1, 

4270 cast(hp2.street2Calls as <signed>integer) AS call_2, 

4271 cast(hp2.street3Calls as <signed>integer) AS call_3, 

4272 cast(hp2.street4Calls as <signed>integer) AS call_4, 

4273 cast(hp2.street0Bets as <signed>integer) AS bet_0, 

4274 cast(hp2.street1Bets as <signed>integer) AS bet_1, 

4275 cast(hp2.street2Bets as <signed>integer) AS bet_2, 

4276 cast(hp2.street3Bets as <signed>integer) AS bet_3, 

4277 cast(hp2.street4Bets as <signed>integer) AS bet_4, 

4278 cast(hp2.street0Raises as <signed>integer) AS raise_0, 

4279 cast(hp2.street1Raises as <signed>integer) AS raise_1, 

4280 cast(hp2.street2Raises as <signed>integer) AS raise_2, 

4281 cast(hp2.street3Raises as <signed>integer) AS raise_3, 

4282 cast(hp2.street4Raises as <signed>integer) AS raise_4 

4283 FROM Hands h /* this hand */ 

4284 INNER JOIN Hands h2 ON ( h2.id >= %s /* other hands */ 

4285 AND h2.tableName = h.tableName) 

4286 INNER JOIN HandsPlayers hp ON (h.id = hp.handId) /* players in this hand */ 

4287 INNER JOIN HandsPlayers hp2 ON ( hp2.playerId+0 = hp.playerId+0 

4288 AND hp2.handId = h2.id) /* other hands by these players */ 

4289 INNER JOIN Players p ON (p.id = hp2.PlayerId+0) 

4290 INNER JOIN Gametypes gt ON (gt.id = h2.gametypeId) 

4291 WHERE h.id = %s 

4292 /* check activeseats once this data returned (don't want to do that here as it might 

4293 assume a session ended just because the number of seats dipped for a few hands) 

4294 */ 

4295 AND ( /* 2 separate parts for hero and opponents */ 

4296 ( hp2.playerId != %s 

4297 AND h2.seats between %s and %s 

4298 ) 

4299 OR 

4300 ( hp2.playerId = %s 

4301 AND h2.seats between %s and %s 

4302 ) 

4303 ) 

4304 ORDER BY h.startTime desc, hp2.PlayerId 

4305 /* order rows by handstart descending so that we can stop reading rows when 

4306 there's a gap over X minutes between hands (ie. when we get back to start of 

4307 the session */ 

4308 """ 

4309 elif db_server == 'sqlite': 

4310 self.query['get_stats_from_hand_session'] = """ 

4311 SELECT hp.playerId AS player_id, 

4312 hp.handId AS hand_id, 

4313 hp.seatNo AS seat, 

4314 p.name AS screen_name, 

4315 h.seats AS seats, 

4316 1 AS n, 

4317 cast(hp2.street0VPIChance as <signed>integer) AS vpip_opp, 

4318 cast(hp2.street0VPI as <signed>integer) AS vpip, 

4319 cast(hp2.street0AggrChance as <signed>integer) AS pfr_opp, 

4320 cast(hp2.street0Aggr as <signed>integer) AS pfr, 

4321 cast(hp2.street0CalledRaiseChance as <signed>integer) AS CAR_opp_0, 

4322 cast(hp2.street0CalledRaiseDone as <signed>integer) AS CAR_0, 

4323 cast(hp2.street0_3BChance as <signed>integer) AS TB_opp_0, 

4324 cast(hp2.street0_3BDone as <signed>integer) AS TB_0, 

4325 cast(hp2.street0_4BChance as <signed>integer) AS FB_opp_0, 

4326 cast(hp2.street0_4BDone as <signed>integer) AS FB_0, 

4327 cast(hp2.street0_C4BChance as <signed>integer) AS CFB_opp_0, 

4328 cast(hp2.street0_C4BDone as <signed>integer) AS CFB_0, 

4329 cast(hp2.street0_FoldTo3BChance as <signed>integer) AS F3B_opp_0, 

4330 cast(hp2.street0_FoldTo3BDone as <signed>integer) AS F3B_0, 

4331 cast(hp2.street0_FoldTo4BChance as <signed>integer) AS F4B_opp_0, 

4332 cast(hp2.street0_FoldTo4BDone as <signed>integer) AS F4B_0, 

4333 cast(hp2.street0_SqueezeChance as <signed>integer) AS SQZ_opp_0, 

4334 cast(hp2.street0_SqueezeDone as <signed>integer) AS SQZ_0, 

4335 cast(hp2.raiseToStealChance as <signed>integer) AS RTS_opp, 

4336 cast(hp2.raiseToStealDone as <signed>integer) AS RTS, 

4337 cast(hp2.success_Steal as <signed>integer) AS SUC_ST, 

4338 cast(hp2.street1Seen as <signed>integer) AS saw_f, 

4339 cast(hp2.street1Seen as <signed>integer) AS saw_1, 

4340 cast(hp2.street2Seen as <signed>integer) AS saw_2, 

4341 cast(hp2.street3Seen as <signed>integer) AS saw_3, 

4342 cast(hp2.street4Seen as <signed>integer) AS saw_4, 

4343 cast(hp2.sawShowdown as <signed>integer) AS sd, 

4344 cast(hp2.street1Aggr as <signed>integer) AS aggr_1, 

4345 cast(hp2.street2Aggr as <signed>integer) AS aggr_2, 

4346 cast(hp2.street3Aggr as <signed>integer) AS aggr_3, 

4347 cast(hp2.street4Aggr as <signed>integer) AS aggr_4, 

4348 cast(hp2.otherRaisedStreet1 as <signed>integer) AS was_raised_1, 

4349 cast(hp2.otherRaisedStreet2 as <signed>integer) AS was_raised_2, 

4350 cast(hp2.otherRaisedStreet3 as <signed>integer) AS was_raised_3, 

4351 cast(hp2.otherRaisedStreet4 as <signed>integer) AS was_raised_4, 

4352 cast(hp2.foldToOtherRaisedStreet1 as <signed>integer) AS f_freq_1, 

4353 cast(hp2.foldToOtherRaisedStreet2 as <signed>integer) AS f_freq_2, 

4354 cast(hp2.foldToOtherRaisedStreet3 as <signed>integer) AS f_freq_3, 

4355 cast(hp2.foldToOtherRaisedStreet4 as <signed>integer) AS f_freq_4, 

4356 cast(hp2.wonWhenSeenStreet1 as <signed>integer) AS w_w_s_1, 

4357 cast(hp2.wonAtSD as <signed>integer) AS wmsd, 

4358 cast(hp2.stealChance as <signed>integer) AS steal_opp, 

4359 cast(hp2.stealDone as <signed>integer) AS steal, 

4360 cast(hp2.foldSbToStealChance as <signed>integer) AS SBstolen, 

4361 cast(hp2.foldedSbToSteal as <signed>integer) AS SBnotDef, 

4362 cast(hp2.foldBbToStealChance as <signed>integer) AS BBstolen, 

4363 cast(hp2.foldedBbToSteal as <signed>integer) AS BBnotDef, 

4364 cast(hp2.street1CBChance as <signed>integer) AS CB_opp_1, 

4365 cast(hp2.street1CBDone as <signed>integer) AS CB_1, 

4366 cast(hp2.street2CBChance as <signed>integer) AS CB_opp_2, 

4367 cast(hp2.street2CBDone as <signed>integer) AS CB_2, 

4368 cast(hp2.street3CBChance as <signed>integer) AS CB_opp_3, 

4369 cast(hp2.street3CBDone as <signed>integer) AS CB_3, 

4370 cast(hp2.street4CBChance as <signed>integer) AS CB_opp_4, 

4371 cast(hp2.street4CBDone as <signed>integer) AS CB_4, 

4372 cast(hp2.foldToStreet1CBChance as <signed>integer) AS f_cb_opp_1, 

4373 cast(hp2.foldToStreet1CBDone as <signed>integer) AS f_cb_1, 

4374 cast(hp2.foldToStreet2CBChance as <signed>integer) AS f_cb_opp_2, 

4375 cast(hp2.foldToStreet2CBDone as <signed>integer) AS f_cb_2, 

4376 cast(hp2.foldToStreet3CBChance as <signed>integer) AS f_cb_opp_3, 

4377 cast(hp2.foldToStreet3CBDone as <signed>integer) AS f_cb_3, 

4378 cast(hp2.foldToStreet4CBChance as <signed>integer) AS f_cb_opp_4, 

4379 cast(hp2.foldToStreet4CBDone as <signed>integer) AS f_cb_4, 

4380 cast(hp2.totalProfit as <signed>integer) AS net, 

4381 cast(gt.bigblind as <signed>integer) AS bigblind, 

4382 cast(hp2.street1CheckCallRaiseChance as <signed>integer) AS ccr_opp_1, 

4383 cast(hp2.street1CheckCallDone as <signed>integer) AS cc_1, 

4384 cast(hp2.street1CheckRaiseDone as <signed>integer) AS cr_1, 

4385 cast(hp2.street2CheckCallRaiseChance as <signed>integer) AS ccr_opp_2, 

4386 cast(hp2.street2CheckCallDone as <signed>integer) AS cc_2, 

4387 cast(hp2.street2CheckRaiseDone as <signed>integer) AS cr_2, 

4388 cast(hp2.street3CheckCallRaiseChance as <signed>integer) AS ccr_opp_3, 

4389 cast(hp2.street3CheckCallDone as <signed>integer) AS cc_3, 

4390 cast(hp2.street3CheckRaiseDone as <signed>integer) AS cr_3, 

4391 cast(hp2.street4CheckCallRaiseChance as <signed>integer) AS ccr_opp_4, 

4392 cast(hp2.street4CheckCallDone as <signed>integer) AS cc_4, 

4393 cast(hp2.street4CheckRaiseDone as <signed>integer) AS cr_4, 

4394 cast(hp2.street0Calls as <signed>integer) AS call_0, 

4395 cast(hp2.street1Calls as <signed>integer) AS call_1, 

4396 cast(hp2.street2Calls as <signed>integer) AS call_2, 

4397 cast(hp2.street3Calls as <signed>integer) AS call_3, 

4398 cast(hp2.street4Calls as <signed>integer) AS call_4, 

4399 cast(hp2.street0Bets as <signed>integer) AS bet_0, 

4400 cast(hp2.street1Bets as <signed>integer) AS bet_1, 

4401 cast(hp2.street2Bets as <signed>integer) AS bet_2, 

4402 cast(hp2.street3Bets as <signed>integer) AS bet_3, 

4403 cast(hp2.street4Bets as <signed>integer) AS bet_4, 

4404 cast(hp2.street0Raises as <signed>integer) AS raise_0, 

4405 cast(hp2.street1Raises as <signed>integer) AS raise_1, 

4406 cast(hp2.street2Raises as <signed>integer) AS raise_2, 

4407 cast(hp2.street3Raises as <signed>integer) AS raise_3, 

4408 cast(hp2.street4Raises as <signed>integer) AS raise_4 

4409 FROM Hands h /* this hand */ 

4410 INNER JOIN Hands h2 ON ( h2.id >= %s /* other hands */ 

4411 AND h2.tableName = h.tableName) 

4412 INNER JOIN HandsPlayers hp ON (h.id = hp.handId) /* players in this hand */ 

4413 INNER JOIN HandsPlayers hp2 ON ( hp2.playerId+0 = hp.playerId+0 

4414 AND hp2.handId = h2.id) /* other hands by these players */ 

4415 INNER JOIN Players p ON (p.id = hp2.PlayerId+0) 

4416 INNER JOIN Gametypes gt ON (gt.id = h2.gametypeId) 

4417 WHERE h.id = %s 

4418 /* check activeseats once this data returned (don't want to do that here as it might 

4419 assume a session ended just because the number of seats dipped for a few hands) 

4420 */ 

4421 AND ( /* 2 separate parts for hero and opponents */ 

4422 ( hp2.playerId != %s 

4423 AND h2.seats between %s and %s 

4424 ) 

4425 OR 

4426 ( hp2.playerId = %s 

4427 AND h2.seats between %s and %s 

4428 ) 

4429 ) 

4430 ORDER BY h.startTime desc, hp2.PlayerId 

4431 /* order rows by handstart descending so that we can stop reading rows when 

4432 there's a gap over X minutes between hands (ie. when we get back to start of 

4433 the session */ 

4434 """ 

4435 

4436 self.query['get_players_from_hand'] = """ 

4437 SELECT HandsPlayers.playerId, seatNo, name 

4438 FROM HandsPlayers INNER JOIN Players ON (HandsPlayers.playerId = Players.id) 

4439 WHERE handId = %s 

4440 """ 

4441# WHERE handId = %s AND Players.id LIKE %s 

4442 

4443 self.query['get_winners_from_hand'] = """ 

4444 SELECT name, winnings 

4445 FROM HandsPlayers, Players 

4446 WHERE winnings > 0 

4447 AND Players.id = HandsPlayers.playerId 

4448 AND handId = %s; 

4449 """ 

4450 

4451 self.query['get_table_name'] = """ 

4452 SELECT h.tableName, gt.maxSeats, gt.category, gt.type, gt.fast, s.id, s.name 

4453 , count(1) as numseats 

4454 FROM Hands h, Gametypes gt, Sites s, HandsPlayers hp 

4455 WHERE h.id = %s 

4456 AND gt.id = h.gametypeId 

4457 AND s.id = gt.siteID 

4458 AND hp.handId = h.id 

4459 GROUP BY h.tableName, gt.maxSeats, gt.category, gt.type, gt.fast, s.id, s.name 

4460 """ 

4461 

4462 self.query['get_actual_seat'] = """ 

4463 select seatNo 

4464 from HandsPlayers 

4465 where HandsPlayers.handId = %s 

4466 and HandsPlayers.playerId = (select Players.id from Players 

4467 where Players.name = %s) 

4468 """ 

4469 

4470 self.query['get_cards'] = """ 

4471/* 

4472 changed to activate mucked card display in draw games 

4473 in draw games, card6->card20 contain 3 sets of 5 cards at each draw 

4474 

4475 CASE code searches from the highest card number (latest draw) and when 

4476 it finds a non-zero card, it returns that set of data 

4477*/ 

4478 SELECT 

4479 seatNo AS seat_number, 

4480 CASE Gametypes.base 

4481 when 'draw' then COALESCE(NULLIF(card16,0), NULLIF(card11,0), NULLIF(card6,0), card1) 

4482 else card1 

4483 end card1, 

4484 CASE Gametypes.base 

4485 when 'draw' then COALESCE(NULLIF(card17,0), NULLIF(card12,0), NULLIF(card7,0), card2) 

4486 else card2 

4487 end card2, 

4488 CASE Gametypes.base 

4489 when 'draw' then COALESCE(NULLIF(card18,0), NULLIF(card13,0), NULLIF(card8,0), card3) 

4490 else card3 

4491 end card3, 

4492 CASE Gametypes.base 

4493 when 'draw' then COALESCE(NULLIF(card19,0), NULLIF(card14,0), NULLIF(card9,0), card4) 

4494 else card4 

4495 end card4, 

4496 CASE Gametypes.base 

4497 when 'draw' then COALESCE(NULLIF(card20,0), NULLIF(card15,0), NULLIF(card10,0), card5) 

4498 else card5 

4499 end card5, 

4500 CASE Gametypes.base 

4501 when 'draw' then 0 

4502 else card6 

4503 end card6, 

4504 CASE Gametypes.base 

4505 when 'draw' then 0 

4506 else card7 

4507 end card7 

4508 

4509 FROM HandsPlayers, Hands, Gametypes 

4510 WHERE handID = %s 

4511 AND HandsPlayers.handId=Hands.id 

4512 AND Hands.gametypeId = Gametypes.id 

4513 ORDER BY seatNo 

4514 """ 

4515 

4516 self.query['get_common_cards'] = """ 

4517 select 

4518 boardcard1, 

4519 boardcard2, 

4520 boardcard3, 

4521 boardcard4, 

4522 boardcard5 

4523 from Hands 

4524 where Id = %s 

4525 """ 

4526 

4527 if db_server == 'mysql': 

4528 self.query['get_hand_1day_ago'] = """ 

4529 select coalesce(max(id),0) 

4530 from Hands 

4531 where startTime < date_sub(utc_timestamp(), interval '1' day)""" 

4532 elif db_server == 'postgresql': 

4533 self.query['get_hand_1day_ago'] = """ 

4534 select coalesce(max(id),0) 

4535 from Hands 

4536 where startTime < now() at time zone 'UTC' - interval '1 day'""" 

4537 elif db_server == 'sqlite': 

4538 self.query['get_hand_1day_ago'] = """ 

4539 select coalesce(max(id),0) 

4540 from Hands 

4541 where startTime < datetime(strftime('%J', 'now') - 1)""" 

4542 

4543 # not used yet ... 

4544 # gets a date, would need to use handsplayers (not hudcache) to get exact hand Id 

4545 if db_server == 'mysql': 

4546 self.query['get_date_nhands_ago'] = """ 

4547 select concat( 'd', date_format(max(h.startTime), '%Y%m%d') ) 

4548 from (select hp.playerId 

4549 ,coalesce(greatest(max(hp.handId)-%s,1),1) as maxminusx 

4550 from HandsPlayers hp 

4551 where hp.playerId = %s 

4552 group by hp.playerId) hp2 

4553 inner join HandsPlayers hp3 on ( hp3.handId <= hp2.maxminusx 

4554 and hp3.playerId = hp2.playerId) 

4555 inner join Hands h on (h.id = hp3.handId) 

4556 """ 

4557 elif db_server == 'postgresql': 

4558 self.query['get_date_nhands_ago'] = """ 

4559 select 'd' || to_char(max(h3.startTime), 'YYMMDD') 

4560 from (select hp.playerId 

4561 ,coalesce(greatest(max(hp.handId)-%s,1),1) as maxminusx 

4562 from HandsPlayers hp 

4563 where hp.playerId = %s 

4564 group by hp.playerId) hp2 

4565 inner join HandsPlayers hp3 on ( hp3.handId <= hp2.maxminusx 

4566 and hp3.playerId = hp2.playerId) 

4567 inner join Hands h on (h.id = hp3.handId) 

4568 """ 

4569 elif db_server == 'sqlite': # untested guess at query: 

4570 self.query['get_date_nhands_ago'] = """ 

4571 select 'd' || strftime(max(h3.startTime), 'YYMMDD') 

4572 from (select hp.playerId 

4573 ,coalesce(greatest(max(hp.handId)-%s,1),1) as maxminusx 

4574 from HandsPlayers hp 

4575 where hp.playerId = %s 

4576 group by hp.playerId) hp2 

4577 inner join HandsPlayers hp3 on ( hp3.handId <= hp2.maxminusx 

4578 and hp3.playerId = hp2.playerId) 

4579 inner join Hands h on (h.id = hp3.handId) 

4580 """ 

4581 

4582 # Used in *Filters: 

4583 #self.query['getLimits'] = already defined further up 

4584 self.query['getLimits2'] = """SELECT DISTINCT type, limitType, bigBlind  

4585 from Gametypes 

4586 ORDER by type, limitType DESC, bigBlind DESC""" 

4587 self.query['getLimits3'] = """select DISTINCT type 

4588 , gt.limitType 

4589 , case type 

4590 when 'ring' then bigBlind  

4591- else buyin 

4592- end as bb_or_buyin 

4593 from Gametypes gt 

4594 cross join TourneyTypes tt 

4595 order by type, gt.limitType DESC, bb_or_buyin DESC""" 

4596# self.query['getCashLimits'] = """select DISTINCT type 

4597# , limitType 

4598# , bigBlind as bb_or_buyin 

4599# from Gametypes gt 

4600# WHERE type = 'ring' 

4601# order by type, limitType DESC, bb_or_buyin DESC""" 

4602 

4603 self.query['getCashLimits'] = """select DISTINCT type 

4604 , limitType 

4605 , bigBlind as bb_or_buyin 

4606 from Gametypes gt 

4607 WHERE type = 'ring' 

4608 order by type, limitType DESC, bb_or_buyin DESC""" 

4609 

4610 self.query['getPositions'] = """select distinct position 

4611 from HandsPlayers gt 

4612 order by position""" 

4613 

4614 #FIXME: Some stats not added to DetailedStats (miss raise to steal) 

4615 if db_server == 'mysql': 

4616 self.query['playerDetailedStats'] = """ 

4617 select <hgametypeId> AS hgametypeid 

4618 ,<playerName> AS pname 

4619 ,gt.base 

4620 ,gt.category 

4621 ,upper(gt.limitType) AS limittype 

4622 ,s.name 

4623 ,min(gt.bigBlind) AS minbigblind 

4624 ,max(gt.bigBlind) AS maxbigblind 

4625 ,gt.ante AS ante 

4626 ,gt.currency AS currency 

4627 /*,<hcgametypeId> AS gtid*/ 

4628 ,<position> AS plposition 

4629 ,gt.fast AS fast 

4630 ,count(1) AS n 

4631 ,case when sum(cast(hp.street0VPIChance as SIGNED)) = 0 then -999 

4632 else 100.0*sum(cast(hp.street0VPI as SIGNED))/sum(cast(hp.street0VPIChance as SIGNED)) 

4633 end AS vpip 

4634 ,case when sum(cast(hp.street0AggrChance as SIGNED)) = 0 then -999 

4635 else 100.0*sum(cast(hp.street0Aggr as SIGNED))/sum(cast(hp.street0AggrChance as SIGNED)) 

4636 end AS pfr 

4637 ,case when sum(cast(hp.street0CalledRaiseChance as SIGNED)) = 0 then -999 

4638 else 100.0*sum(cast(hp.street0CalledRaiseDone as SIGNED))/sum(cast(hp.street0CalledRaiseChance as SIGNED)) 

4639 end AS car0 

4640 ,case when sum(cast(hp.street0_3Bchance as SIGNED)) = 0 then -999 

4641 else 100.0*sum(cast(hp.street0_3Bdone as SIGNED))/sum(cast(hp.street0_3Bchance as SIGNED)) 

4642 end AS pf3 

4643 ,case when sum(cast(hp.street0_4Bchance as SIGNED)) = 0 then -999 

4644 else 100.0*sum(cast(hp.street0_4Bdone as SIGNED))/sum(cast(hp.street0_4Bchance as SIGNED)) 

4645 end AS pf4 

4646 ,case when sum(cast(hp.street0_FoldTo3Bchance as SIGNED)) = 0 then -999 

4647 else 100.0*sum(cast(hp.street0_FoldTo3Bdone as SIGNED))/sum(cast(hp.street0_FoldTo3Bchance as SIGNED)) 

4648 end AS pff3 

4649 ,case when sum(cast(hp.street0_FoldTo4Bchance as SIGNED)) = 0 then -999 

4650 else 100.0*sum(cast(hp.street0_FoldTo4Bdone as SIGNED))/sum(cast(hp.street0_FoldTo4Bchance as SIGNED)) 

4651 end AS pff4 

4652 

4653 ,case when sum(cast(hp.raiseFirstInChance as SIGNED)) = 0 then -999 

4654 else 100.0 * sum(cast(hp.raisedFirstIn as SIGNED)) /  

4655 sum(cast(hp.raiseFirstInChance as SIGNED)) 

4656 end AS rfi 

4657 ,case when sum(cast(hp.stealChance as SIGNED)) = 0 then -999 

4658 else 100.0 * sum(cast(hp.stealDone as SIGNED)) /  

4659 sum(cast(hp.stealChance as SIGNED)) 

4660 end AS steals 

4661 ,case when sum(cast(hp.stealDone as SIGNED)) = 0 then -999 

4662 else 100.0 * sum(cast(hp.success_Steal as SIGNED)) /  

4663 sum(cast(hp.stealDone as SIGNED)) 

4664 end AS suc_steal 

4665 ,100.0*sum(cast(hp.street1Seen as SIGNED))/count(1) AS saw_f 

4666 ,100.0*sum(cast(hp.sawShowdown as SIGNED))/count(1) AS sawsd 

4667 ,case when sum(cast(hp.street1Seen as SIGNED)) = 0 then -999 

4668 else 100.0*sum(cast(hp.wonWhenSeenStreet1 as SIGNED))/sum(cast(hp.street1Seen as SIGNED)) 

4669 end AS wmsf 

4670 ,case when sum(cast(hp.street1Seen as SIGNED)) = 0 then -999 

4671 else 100.0*sum(cast(hp.sawShowdown as SIGNED))/sum(cast(hp.street1Seen as SIGNED)) 

4672 end AS wtsdwsf 

4673 ,case when sum(cast(hp.sawShowdown as SIGNED)) = 0 then -999 

4674 else 100.0*sum(cast(hp.wonAtSD as SIGNED))/sum(cast(hp.sawShowdown as SIGNED)) 

4675 end AS wmsd 

4676 ,case when sum(cast(hp.street1Seen as SIGNED)) = 0 then -999 

4677 else 100.0*sum(cast(hp.street1Aggr as SIGNED))/sum(cast(hp.street1Seen as SIGNED)) 

4678 end AS flafq 

4679 ,case when sum(cast(hp.street2Seen as SIGNED)) = 0 then -999 

4680 else 100.0*sum(cast(hp.street2Aggr as SIGNED))/sum(cast(hp.street2Seen as SIGNED)) 

4681 end AS tuafq 

4682 ,case when sum(cast(hp.street3Seen as SIGNED)) = 0 then -999 

4683 else 100.0*sum(cast(hp.street3Aggr as SIGNED))/sum(cast(hp.street3Seen as SIGNED)) 

4684 end AS rvafq 

4685 ,case when sum(cast(hp.street1Seen as SIGNED))+sum(cast(hp.street2Seen as SIGNED))+sum(cast(hp.street3Seen as SIGNED)) = 0 then -999 

4686 else 100.0*(sum(cast(hp.street1Aggr as SIGNED))+sum(cast(hp.street2Aggr as SIGNED))+sum(cast(hp.street3Aggr as SIGNED))) 

4687 /(sum(cast(hp.street1Seen as SIGNED))+sum(cast(hp.street2Seen as SIGNED))+sum(cast(hp.street3Seen as SIGNED))) 

4688 end AS pofafq 

4689 ,case when sum(cast(hp.street1Calls as SIGNED))+ sum(cast(hp.street2Calls as SIGNED))+ sum(cast(hp.street3Calls as SIGNED))+ sum(cast(hp.street4Calls as SIGNED)) = 0 then -999 

4690 else (sum(cast(hp.street1Aggr as SIGNED)) + sum(cast(hp.street2Aggr as SIGNED)) + sum(cast(hp.street3Aggr as SIGNED)) + sum(cast(hp.street4Aggr as SIGNED))) 

4691 /(0.0+sum(cast(hp.street1Calls as SIGNED))+ sum(cast(hp.street2Calls as SIGNED))+ sum(cast(hp.street3Calls as SIGNED))+ sum(cast(hp.street4Calls as SIGNED))) 

4692 end AS aggfac 

4693 ,100.0*(sum(cast(hp.street1Aggr as SIGNED)) + sum(cast(hp.street2Aggr as SIGNED)) + sum(cast(hp.street3Aggr as SIGNED)) + sum(cast(hp.street4Aggr as SIGNED)))  

4694 / ((sum(cast(hp.foldToOtherRaisedStreet1 as SIGNED))+ sum(cast(hp.foldToOtherRaisedStreet2 as SIGNED))+ sum(cast(hp.foldToOtherRaisedStreet3 as SIGNED))+ sum(cast(hp.foldToOtherRaisedStreet4 as SIGNED))) + 

4695 (sum(cast(hp.street1Calls as SIGNED))+ sum(cast(hp.street2Calls as SIGNED))+ sum(cast(hp.street3Calls as SIGNED))+ sum(cast(hp.street4Calls as SIGNED))) + 

4696 (sum(cast(hp.street1Aggr as SIGNED)) + sum(cast(hp.street2Aggr as SIGNED)) + sum(cast(hp.street3Aggr as SIGNED)) + sum(cast(hp.street4Aggr as SIGNED))) ) 

4697 AS aggfrq 

4698 ,100.0*(sum(cast(hp.street1CBDone as SIGNED)) + sum(cast(hp.street2CBDone as SIGNED)) + sum(cast(hp.street3CBDone as SIGNED)) + sum(cast(hp.street4CBDone as SIGNED)))  

4699 / (sum(cast(hp.street1CBChance as SIGNED))+ sum(cast(hp.street2CBChance as SIGNED))+ sum(cast(hp.street3CBChance as SIGNED))+ sum(cast(hp.street4CBChance as SIGNED)))  

4700 AS conbet 

4701 ,sum(hp.totalProfit)/100.0 AS net 

4702 ,sum(hp.rake)/100.0 AS rake 

4703 ,100.0*avg(hp.totalProfit/(gt.bigBlind+0.0)) AS bbper100 

4704 ,avg(hp.totalProfit)/100.0 AS profitperhand 

4705 ,100.0*avg((hp.totalProfit+hp.rake)/(gt.bigBlind+0.0)) AS bb100xr 

4706 ,avg((hp.totalProfit+hp.rake)/100.0) AS profhndxr 

4707 ,avg(h.seats+0.0) AS avgseats 

4708 ,variance(hp.totalProfit/100.0) AS variance 

4709 ,sqrt(variance(hp.totalProfit/100.0)) AS stddev 

4710 from HandsPlayers hp 

4711 inner join Hands h on (h.id = hp.handId) 

4712 inner join Gametypes gt on (gt.Id = h.gametypeId) 

4713 inner join Sites s on (s.Id = gt.siteId) 

4714 inner join Players p on (p.Id = hp.playerId) 

4715 where hp.playerId in <player_test> 

4716 <game_test> 

4717 <site_test> 

4718 <currency_test> 

4719 /*and hp.tourneysPlayersId IS NULL*/ 

4720 and h.seats <seats_test> 

4721 <flagtest> 

4722 <cardstest> 

4723 <gtbigBlind_test> 

4724 and date_format(h.startTime, '%Y-%m-%d %T') <datestest> 

4725 group by hgametypeId 

4726 ,pname 

4727 ,gt.base 

4728 ,gt.category 

4729 <groupbyseats> 

4730 ,plposition 

4731 ,upper(gt.limitType) 

4732 ,gt.fast 

4733 ,s.name 

4734 having 1 = 1 <havingclause> 

4735 order by pname 

4736 ,gt.base 

4737 ,gt.category 

4738 <orderbyseats> 

4739 ,case <position> when 'B' then 'B' 

4740 when 'S' then 'S' 

4741 else concat('Z', <position>) 

4742 end 

4743 <orderbyhgametypeId> 

4744 ,upper(gt.limitType) desc 

4745 ,maxbigblind desc 

4746 ,gt.fast 

4747 ,s.name 

4748 """ 

4749 elif db_server == 'postgresql': 

4750 self.query['playerDetailedStats'] = """ 

4751 select <hgametypeId> AS hgametypeid 

4752 ,<playerName> AS pname 

4753 ,gt.base 

4754 ,gt.category 

4755 ,upper(gt.limitType) AS limittype 

4756 ,s.name 

4757 ,min(gt.bigBlind) AS minbigblind 

4758 ,max(gt.bigBlind) AS maxbigblind 

4759 ,gt.ante AS ante 

4760 ,gt.currency AS currency 

4761 /*,<hcgametypeId> AS gtid*/ 

4762 ,<position> AS plposition 

4763 ,gt.fast AS fast 

4764 ,count(1) AS n 

4765 ,case when sum(cast(hp.street0VPIChance as <signed>integer)) = 0 then -999 

4766 else 100.0*sum(cast(hp.street0VPI as <signed>integer))/sum(cast(hp.street0VPIChance as <signed>integer)) 

4767 end AS vpip 

4768 ,case when sum(cast(hp.street0AggrChance as <signed>integer)) = 0 then -999 

4769 else 100.0*sum(cast(hp.street0Aggr as <signed>integer))/sum(cast(hp.street0AggrChance as <signed>integer)) 

4770 end AS pfr 

4771 ,case when sum(cast(hp.street0CalledRaiseChance as <signed>integer)) = 0 then -999 

4772 else 100.0*sum(cast(hp.street0CalledRaiseDone as <signed>integer))/sum(cast(hp.street0CalledRaiseChance as <signed>integer)) 

4773 end AS car0 

4774 ,case when sum(cast(hp.street0_3Bchance as <signed>integer)) = 0 then -999 

4775 else 100.0*sum(cast(hp.street0_3Bdone as <signed>integer))/sum(cast(hp.street0_3Bchance as <signed>integer)) 

4776 end AS pf3 

4777 ,case when sum(cast(hp.street0_4Bchance as <signed>integer)) = 0 then -999 

4778 else 100.0*sum(cast(hp.street0_4Bdone as <signed>integer))/sum(cast(hp.street0_4Bchance as <signed>integer)) 

4779 end AS pf4 

4780 ,case when sum(cast(hp.street0_FoldTo3Bchance as <signed>integer)) = 0 then -999 

4781 else 100.0*sum(cast(hp.street0_FoldTo3Bdone as <signed>integer))/sum(cast(hp.street0_FoldTo3Bchance as <signed>integer)) 

4782 end AS pff3 

4783 ,case when sum(cast(hp.street0_FoldTo4Bchance as <signed>integer)) = 0 then -999 

4784 else 100.0*sum(cast(hp.street0_FoldTo4Bdone as <signed>integer))/sum(cast(hp.street0_FoldTo4Bchance as <signed>integer)) 

4785 end AS pff4 

4786 ,case when sum(cast(hp.raiseFirstInChance as <signed>integer)) = 0 then -999 

4787 else 100.0 * sum(cast(hp.raisedFirstIn as <signed>integer)) /  

4788 sum(cast(hp.raiseFirstInChance as <signed>integer)) 

4789 end AS rfi 

4790 ,case when sum(cast(hp.stealChance as <signed>integer)) = 0 then -999 

4791 else 100.0 * sum(cast(hp.stealDone as <signed>integer)) /  

4792 sum(cast(hp.stealChance as <signed>integer)) 

4793 end AS steals 

4794 ,case when sum(cast(hp.stealDone as <signed>integer)) = 0 then -999 

4795 else 100.0 * sum(cast(hp.success_Steal as <signed>integer)) /  

4796 sum(cast(hp.stealDone as <signed>integer)) 

4797 end AS suc_steal 

4798 ,100.0*sum(cast(hp.street1Seen as <signed>integer))/count(1) AS saw_f 

4799 ,100.0*sum(cast(hp.sawShowdown as <signed>integer))/count(1) AS sawsd 

4800 ,case when sum(cast(hp.street1Seen as <signed>integer)) = 0 then -999 

4801 else 100.0*sum(cast(hp.wonWhenSeenStreet1 as <signed>integer))/sum(cast(hp.street1Seen as <signed>integer)) 

4802 end AS wmsf 

4803 ,case when sum(cast(hp.street1Seen as <signed>integer)) = 0 then -999 

4804 else 100.0*sum(cast(hp.sawShowdown as <signed>integer))/sum(cast(hp.street1Seen as <signed>integer)) 

4805 end AS wtsdwsf 

4806 ,case when sum(cast(hp.sawShowdown as <signed>integer)) = 0 then -999 

4807 else 100.0*sum(cast(hp.wonAtSD as <signed>integer))/sum(cast(hp.sawShowdown as <signed>integer)) 

4808 end AS wmsd 

4809 ,case when sum(cast(hp.street1Seen as <signed>integer)) = 0 then -999 

4810 else 100.0*sum(cast(hp.street1Aggr as <signed>integer))/sum(cast(hp.street1Seen as <signed>integer)) 

4811 end AS flafq 

4812 ,case when sum(cast(hp.street2Seen as <signed>integer)) = 0 then -999 

4813 else 100.0*sum(cast(hp.street2Aggr as <signed>integer))/sum(cast(hp.street2Seen as <signed>integer)) 

4814 end AS tuafq 

4815 ,case when sum(cast(hp.street3Seen as <signed>integer)) = 0 then -999 

4816 else 100.0*sum(cast(hp.street3Aggr as <signed>integer))/sum(cast(hp.street3Seen as <signed>integer)) 

4817 end AS rvafq 

4818 ,case when sum(cast(hp.street1Seen as <signed>integer))+sum(cast(hp.street2Seen as <signed>integer))+sum(cast(hp.street3Seen as <signed>integer)) = 0 then -999 

4819 else 100.0*(sum(cast(hp.street1Aggr as <signed>integer))+sum(cast(hp.street2Aggr as <signed>integer))+sum(cast(hp.street3Aggr as <signed>integer))) 

4820 /(sum(cast(hp.street1Seen as <signed>integer))+sum(cast(hp.street2Seen as <signed>integer))+sum(cast(hp.street3Seen as <signed>integer))) 

4821 end AS pofafq 

4822 ,case when sum(cast(hp.street1Calls as <signed>integer))+ sum(cast(hp.street2Calls as <signed>integer))+ sum(cast(hp.street3Calls as <signed>integer))+ sum(cast(hp.street4Calls as <signed>integer)) = 0 then -999 

4823 else (sum(cast(hp.street1Aggr as <signed>integer)) + sum(cast(hp.street2Aggr as <signed>integer)) + sum(cast(hp.street3Aggr as <signed>integer)) + sum(cast(hp.street4Aggr as <signed>integer))) 

4824 /(0.0+sum(cast(hp.street1Calls as <signed>integer))+ sum(cast(hp.street2Calls as <signed>integer))+ sum(cast(hp.street3Calls as <signed>integer))+ sum(cast(hp.street4Calls as <signed>integer))) 

4825 end AS aggfac 

4826 ,case when 

4827 sum(cast(hp.foldToOtherRaisedStreet1 as <signed>integer))+ sum(cast(hp.foldToOtherRaisedStreet2 as <signed>integer))+ sum(cast(hp.foldToOtherRaisedStreet3 as <signed>integer))+ sum(cast(hp.foldToOtherRaisedStreet4 as <signed>integer))+ 

4828 sum(cast(hp.street1Calls as <signed>integer))+ sum(cast(hp.street2Calls as <signed>integer))+ sum(cast(hp.street3Calls as <signed>integer))+ sum(cast(hp.street4Calls as <signed>integer))+ 

4829 sum(cast(hp.street1Aggr as <signed>integer))+ sum(cast(hp.street2Aggr as <signed>integer))+ sum(cast(hp.street3Aggr as <signed>integer))+ sum(cast(hp.street4Aggr as <signed>integer)) 

4830 = 0 then -999 

4831 else 

4832 100.0*(sum(cast(hp.street1Aggr as <signed>integer)) + sum(cast(hp.street2Aggr as <signed>integer)) + sum(cast(hp.street3Aggr as <signed>integer)) + sum(cast(hp.street4Aggr as <signed>integer)))  

4833 / ((sum(cast(hp.foldToOtherRaisedStreet1 as <signed>integer))+ sum(cast(hp.foldToOtherRaisedStreet2 as <signed>integer))+ sum(cast(hp.foldToOtherRaisedStreet3 as <signed>integer))+ sum(cast(hp.foldToOtherRaisedStreet4 as <signed>integer))) + 

4834 (sum(cast(hp.street1Calls as <signed>integer))+ sum(cast(hp.street2Calls as <signed>integer))+ sum(cast(hp.street3Calls as <signed>integer))+ sum(cast(hp.street4Calls as <signed>integer))) + 

4835 (sum(cast(hp.street1Aggr as <signed>integer)) + sum(cast(hp.street2Aggr as <signed>integer)) + sum(cast(hp.street3Aggr as <signed>integer)) + sum(cast(hp.street4Aggr as <signed>integer))) ) 

4836 end AS aggfrq 

4837 ,case when 

4838 sum(cast(hp.street1CBChance as <signed>integer))+ 

4839 sum(cast(hp.street2CBChance as <signed>integer))+ 

4840 sum(cast(hp.street3CBChance as <signed>integer))+ 

4841 sum(cast(hp.street4CBChance as <signed>integer)) = 0 then -999 

4842 else 

4843 100.0*(sum(cast(hp.street1CBDone as <signed>integer)) + sum(cast(hp.street2CBDone as <signed>integer)) + sum(cast(hp.street3CBDone as <signed>integer)) + sum(cast(hp.street4CBDone as <signed>integer)))  

4844 / (sum(cast(hp.street1CBChance as <signed>integer))+ sum(cast(hp.street2CBChance as <signed>integer))+ sum(cast(hp.street3CBChance as <signed>integer))+ sum(cast(hp.street4CBChance as <signed>integer)))  

4845 end AS conbet 

4846 ,sum(hp.totalProfit)/100.0 AS net 

4847 ,sum(hp.rake)/100.0 AS rake 

4848 ,100.0*avg(hp.totalProfit/(gt.bigBlind+0.0)) AS bbper100 

4849 ,avg(hp.totalProfit)/100.0 AS profitperhand 

4850 ,100.0*avg((hp.totalProfit+hp.rake)/(gt.bigBlind+0.0)) AS bb100xr 

4851 ,avg((hp.totalProfit+hp.rake)/100.0) AS profhndxr 

4852 ,avg(h.seats+0.0) AS avgseats 

4853 ,variance(hp.totalProfit/100.0) AS variance 

4854 ,sqrt(variance(hp.totalProfit/100.0)) AS stddev 

4855 from HandsPlayers hp 

4856 inner join Hands h on (h.id = hp.handId) 

4857 inner join Gametypes gt on (gt.Id = h.gametypeId) 

4858 inner join Sites s on (s.Id = gt.siteId) 

4859 inner join Players p on (p.Id = hp.playerId) 

4860 where hp.playerId in <player_test> 

4861 <game_test> 

4862 <site_test> 

4863 <currency_test> 

4864 /*and hp.tourneysPlayersId IS NULL*/ 

4865 and h.seats <seats_test> 

4866 <flagtest> 

4867 <cardstest> 

4868 <gtbigBlind_test> 

4869 and to_char(h.startTime, 'YYYY-MM-DD HH24:MI:SS') <datestest> 

4870 group by hgametypeId 

4871 ,pname 

4872 ,gt.base 

4873 ,gt.category 

4874 ,gt.ante 

4875 ,gt.currency 

4876 <groupbyseats> 

4877 ,plposition 

4878 ,upper(gt.limitType) 

4879 ,gt.fast 

4880 ,s.name 

4881 having 1 = 1 <havingclause> 

4882 order by pname 

4883 ,gt.base 

4884 ,gt.category 

4885 <orderbyseats> 

4886 ,case <position> when 'B' then 'B' 

4887 when 'S' then 'S' 

4888 when '0' then 'Y' 

4889 else 'Z'||<position> 

4890 end 

4891 <orderbyhgametypeId> 

4892 ,upper(gt.limitType) desc 

4893 ,maxbigblind desc 

4894 ,gt.fast 

4895 ,s.name 

4896 """ 

4897 elif db_server == 'sqlite': 

4898 self.query['playerDetailedStats'] = """ 

4899 select <hgametypeId> AS hgametypeid 

4900 ,<playerName> AS pname 

4901 ,gt.base 

4902 ,gt.category AS category 

4903 ,upper(gt.limitType) AS limittype 

4904 ,s.name AS name 

4905 ,min(gt.bigBlind) AS minbigblind 

4906 ,max(gt.bigBlind) AS maxbigblind 

4907 ,gt.ante AS ante 

4908 ,gt.currency AS currency 

4909 /*,<hcgametypeId> AS gtid*/ 

4910 ,<position> AS plposition 

4911 ,gt.fast AS fast 

4912 ,count(1) AS n 

4913 ,case when sum(cast(hp.street0VPIChance as <signed>integer)) = 0 then -999 

4914 else 100.0*sum(cast(hp.street0VPI as <signed>integer))/sum(cast(hp.street0VPIChance as <signed>integer)) 

4915 end AS vpip 

4916 ,case when sum(cast(hp.street0AggrChance as <signed>integer)) = 0 then -999 

4917 else 100.0*sum(cast(hp.street0Aggr as <signed>integer))/sum(cast(hp.street0AggrChance as <signed>integer)) 

4918 end AS pfr 

4919 ,case when sum(cast(hp.street0CalledRaiseChance as <signed>integer)) = 0 then -999 

4920 else 100.0*sum(cast(hp.street0CalledRaiseDone as <signed>integer))/sum(cast(hp.street0CalledRaiseChance as <signed>integer)) 

4921 end AS car0 

4922 ,case when sum(cast(hp.street0_3Bchance as <signed>integer)) = 0 then -999 

4923 else 100.0*sum(cast(hp.street0_3Bdone as <signed>integer))/sum(cast(hp.street0_3Bchance as <signed>integer)) 

4924 end AS pf3 

4925 ,case when sum(cast(hp.street0_4Bchance as <signed>integer)) = 0 then -999 

4926 else 100.0*sum(cast(hp.street0_4Bdone as <signed>integer))/sum(cast(hp.street0_4Bchance as <signed>integer)) 

4927 end AS pf4 

4928 ,case when sum(cast(hp.street0_FoldTo3Bchance as <signed>integer)) = 0 then -999 

4929 else 100.0*sum(cast(hp.street0_FoldTo3Bdone as <signed>integer))/sum(cast(hp.street0_FoldTo3Bchance as <signed>integer)) 

4930 end AS pff3 

4931 ,case when sum(cast(hp.street0_FoldTo4Bchance as <signed>integer)) = 0 then -999 

4932 else 100.0*sum(cast(hp.street0_FoldTo4Bdone as <signed>integer))/sum(cast(hp.street0_FoldTo4Bchance as <signed>integer)) 

4933 end AS pff4 

4934 ,case when sum(cast(hp.raiseFirstInChance as <signed>integer)) = 0 then -999 

4935 else 100.0 * sum(cast(hp.raisedFirstIn as <signed>integer)) /  

4936 sum(cast(hp.raiseFirstInChance as <signed>integer)) 

4937 end AS rfi 

4938 ,case when sum(cast(hp.stealChance as <signed>integer)) = 0 then -999 

4939 else 100.0 * sum(cast(hp.stealDone as <signed>integer)) /  

4940 sum(cast(hp.stealChance as <signed>integer)) 

4941 end AS steals 

4942 ,case when sum(cast(hp.stealDone as <signed>integer)) = 0 then -999 

4943 else 100.0 * sum(cast(hp.success_Steal as <signed>integer)) /  

4944 sum(cast(hp.stealDone as <signed>integer)) 

4945 end AS suc_steal 

4946 ,100.0*sum(cast(hp.street1Seen as <signed>integer))/count(1) AS saw_f 

4947 ,100.0*sum(cast(hp.sawShowdown as <signed>integer))/count(1) AS sawsd 

4948 ,case when sum(cast(hp.street1Seen as <signed>integer)) = 0 then -999 

4949 else 100.0*sum(cast(hp.wonWhenSeenStreet1 as <signed>integer))/sum(cast(hp.street1Seen as <signed>integer)) 

4950 end AS wmsf 

4951 ,case when sum(cast(hp.street1Seen as <signed>integer)) = 0 then -999 

4952 else 100.0*sum(cast(hp.sawShowdown as <signed>integer))/sum(cast(hp.street1Seen as <signed>integer)) 

4953 end AS wtsdwsf 

4954 ,case when sum(cast(hp.sawShowdown as <signed>integer)) = 0 then -999 

4955 else 100.0*sum(cast(hp.wonAtSD as <signed>integer))/sum(cast(hp.sawShowdown as <signed>integer)) 

4956 end AS wmsd 

4957 ,case when sum(cast(hp.street1Seen as <signed>integer)) = 0 then -999 

4958 else 100.0*sum(cast(hp.street1Aggr as <signed>integer))/sum(cast(hp.street1Seen as <signed>integer)) 

4959 end AS flafq 

4960 ,case when sum(cast(hp.street2Seen as <signed>integer)) = 0 then -999 

4961 else 100.0*sum(cast(hp.street2Aggr as <signed>integer))/sum(cast(hp.street2Seen as <signed>integer)) 

4962 end AS tuafq 

4963 ,case when sum(cast(hp.street3Seen as <signed>integer)) = 0 then -999 

4964 else 100.0*sum(cast(hp.street3Aggr as <signed>integer))/sum(cast(hp.street3Seen as <signed>integer)) 

4965 end AS rvafq 

4966 ,case when sum(cast(hp.street1Seen as <signed>integer))+sum(cast(hp.street2Seen as <signed>integer))+sum(cast(hp.street3Seen as <signed>integer)) = 0 then -999 

4967 else 100.0*(sum(cast(hp.street1Aggr as <signed>integer))+sum(cast(hp.street2Aggr as <signed>integer))+sum(cast(hp.street3Aggr as <signed>integer))) 

4968 /(sum(cast(hp.street1Seen as <signed>integer))+sum(cast(hp.street2Seen as <signed>integer))+sum(cast(hp.street3Seen as <signed>integer))) 

4969 end AS pofafq 

4970 ,case when sum(cast(hp.street1Calls as <signed>integer))+ sum(cast(hp.street2Calls as <signed>integer))+ sum(cast(hp.street3Calls as <signed>integer))+ sum(cast(hp.street4Calls as <signed>integer)) = 0 then -999 

4971 else (sum(cast(hp.street1Aggr as <signed>integer)) + sum(cast(hp.street2Aggr as <signed>integer)) + sum(cast(hp.street3Aggr as <signed>integer)) + sum(cast(hp.street4Aggr as <signed>integer))) 

4972 /(0.0+sum(cast(hp.street1Calls as <signed>integer))+ sum(cast(hp.street2Calls as <signed>integer))+ sum(cast(hp.street3Calls as <signed>integer))+ sum(cast(hp.street4Calls as <signed>integer))) 

4973 end AS aggfac 

4974 ,100.0*(sum(cast(hp.street1Aggr as <signed>integer)) + sum(cast(hp.street2Aggr as <signed>integer)) + sum(cast(hp.street3Aggr as <signed>integer)) + sum(cast(hp.street4Aggr as <signed>integer)))  

4975 / ((sum(cast(hp.foldToOtherRaisedStreet1 as <signed>integer))+ sum(cast(hp.foldToOtherRaisedStreet2 as <signed>integer))+ sum(cast(hp.foldToOtherRaisedStreet3 as <signed>integer))+ sum(cast(hp.foldToOtherRaisedStreet4 as <signed>integer))) + 

4976 (sum(cast(hp.street1Calls as <signed>integer))+ sum(cast(hp.street2Calls as <signed>integer))+ sum(cast(hp.street3Calls as <signed>integer))+ sum(cast(hp.street4Calls as <signed>integer))) + 

4977 (sum(cast(hp.street1Aggr as <signed>integer)) + sum(cast(hp.street2Aggr as <signed>integer)) + sum(cast(hp.street3Aggr as <signed>integer)) + sum(cast(hp.street4Aggr as <signed>integer))) ) 

4978 AS aggfrq 

4979 ,100.0*(sum(cast(hp.street1CBDone as <signed>integer)) + sum(cast(hp.street2CBDone as <signed>integer)) + sum(cast(hp.street3CBDone as <signed>integer)) + sum(cast(hp.street4CBDone as <signed>integer)))  

4980 / (sum(cast(hp.street1CBChance as <signed>integer))+ sum(cast(hp.street2CBChance as <signed>integer))+ sum(cast(hp.street3CBChance as <signed>integer))+ sum(cast(hp.street4CBChance as <signed>integer)))  

4981 AS conbet 

4982 ,sum(hp.totalProfit)/100.0 AS net 

4983 ,sum(hp.rake)/100.0 AS rake 

4984 ,100.0*avg(hp.totalProfit/(gt.bigBlind+0.0)) AS bbper100 

4985 ,avg(hp.totalProfit)/100.0 AS profitperhand 

4986 ,100.0*avg((hp.totalProfit+hp.rake)/(gt.bigBlind+0.0)) AS bb100xr 

4987 ,avg((hp.totalProfit+hp.rake)/100.0) AS profhndxr 

4988 ,avg(h.seats+0.0) AS avgseats 

4989 ,variance(hp.totalProfit/100.0) AS variance 

4990 ,sqrt(variance(hp.totalProfit/100.0)) AS stddev 

4991 from HandsPlayers hp 

4992 inner join Hands h on (h.id = hp.handId) 

4993 inner join Gametypes gt on (gt.Id = h.gametypeId) 

4994 inner join Sites s on (s.Id = gt.siteId) 

4995 inner join Players p on (p.Id = hp.playerId) 

4996 where hp.playerId in <player_test> 

4997 <game_test> 

4998 <site_test> 

4999 <currency_test> 

5000 /*and hp.tourneysPlayersId IS NULL*/ 

5001 and h.seats <seats_test> 

5002 <flagtest> 

5003 <cardstest> 

5004 <gtbigBlind_test> 

5005 and datetime(h.startTime) <datestest> 

5006 group by hgametypeId 

5007 ,hp.playerId 

5008 ,gt.base 

5009 ,gt.category 

5010 <groupbyseats> 

5011 ,plposition 

5012 ,upper(gt.limitType) 

5013 ,gt.fast 

5014 ,s.name 

5015 having 1 = 1 <havingclause> 

5016 order by hp.playerId 

5017 ,gt.base 

5018 ,gt.category 

5019 <orderbyseats> 

5020 ,case <position> when 'B' then 'B' 

5021 when 'S' then 'S' 

5022 when '0' then 'Y' 

5023 else 'Z'||<position> 

5024 end 

5025 <orderbyhgametypeId> 

5026 ,upper(gt.limitType) desc 

5027 ,max(gt.bigBlind) desc 

5028 ,gt.fast 

5029 ,s.name 

5030 """ 

5031 

5032 #FIXME: 3/4bet and foldTo don't added four tournaments yet 

5033 if db_server == 'mysql': 

5034 self.query['tourneyPlayerDetailedStats'] = """ 

5035 select s.name AS siteName 

5036 ,tt.currency AS currency 

5037 ,(CASE 

5038 WHEN tt.currency = 'play' THEN tt.buyIn 

5039 ELSE tt.buyIn/100.0 

5040 END) AS buyIn 

5041 ,tt.fee/100.0 AS fee 

5042 ,tt.category AS category 

5043 ,tt.limitType AS limitType 

5044 ,tt.speed AS speed 

5045 ,tt.maxSeats AS maxSeats 

5046 ,tt.knockout AS knockout 

5047 ,tt.reEntry AS reEntry 

5048 ,p.name AS playerName 

5049 ,COUNT(1) AS tourneyCount 

5050 ,SUM(CASE WHEN tp.rank > 0 THEN 0 ELSE 1 END) AS unknownRank 

5051 ,(CAST(SUM(CASE WHEN winnings > 0 THEN 1 ELSE 0 END) AS SIGNED)/CAST(COUNT(1) AS SIGNED))*100 AS itm 

5052 ,SUM(CASE WHEN rank = 1 THEN 1 ELSE 0 END) AS _1st 

5053 ,SUM(CASE WHEN rank = 2 THEN 1 ELSE 0 END) AS _2nd 

5054 ,SUM(CASE WHEN rank = 3 THEN 1 ELSE 0 END) AS _3rd 

5055 ,SUM(tp.winnings+COALESCE(tp.koCount*tt.koBounty,0))/100.0 AS won 

5056 ,SUM(CASE 

5057 WHEN tt.currency = 'play' THEN tt.buyIn 

5058 ELSE (tt.buyIn+tt.fee)/100.0 

5059 END) AS spent 

5060 ,SUM(tp.winnings+COALESCE(tp.koCount*tt.koBounty,0)-tt.buyIn-tt.fee)/100.0 AS net 

5061 ,(CAST(SUM(tp.winnings+COALESCE(tp.koCount*tt.koBounty,0) - tt.buyin - tt.fee) AS SIGNED)/ 

5062 CAST(SUM(tt.buyin+tt.fee) AS SIGNED))* 100.0 AS roi 

5063 ,SUM(tp.winnings+COALESCE(tp.koCount*tt.koBounty,0)-(tt.buyin+tt.fee))/100.0/(COUNT(1)-SUM(CASE WHEN tp.rank > 0 THEN 0 ELSE 1 END)) AS profitPerTourney 

5064 from TourneysPlayers tp 

5065 inner join Tourneys t on (t.id = tp.tourneyId) 

5066 inner join TourneyTypes tt on (tt.Id = t.tourneyTypeId) 

5067 inner join Sites s on (s.Id = tt.siteId) 

5068 inner join Players p on (p.Id = tp.playerId) 

5069 where tp.playerId in <nametest> <sitetest> 

5070 AND ((t.startTime > '<startdate_test>' AND t.startTime < '<enddate_test>') 

5071 OR t.startTime is NULL) 

5072 group by tourneyTypeId, playerName 

5073 order by tourneyTypeId 

5074 ,playerName 

5075 ,siteName""" 

5076 elif db_server == 'postgresql': 

5077 # sc: itm and profitPerTourney changed to "ELSE 0" to avoid divide by zero error as temp fix 

5078 # proper fix should use coalesce() or case ... when ... to work in all circumstances 

5079 self.query['tourneyPlayerDetailedStats'] = """ 

5080 select s.name AS "siteName" 

5081 ,tt.currency AS "currency" 

5082 ,(CASE 

5083 WHEN tt.currency = 'play' THEN tt.buyIn 

5084 ELSE tt.buyIn/100.0 

5085 END) AS "buyIn" 

5086 ,tt.fee/100.0 AS "fee" 

5087 ,tt.category AS "category" 

5088 ,tt.limitType AS "limitType" 

5089 ,tt.speed AS "speed" 

5090 ,tt.maxSeats AS "maxSeats" 

5091 ,tt.knockout AS "knockout" 

5092 ,tt.reEntry AS "reEntry" 

5093 ,p.name AS "playerName" 

5094 ,COUNT(1) AS "tourneyCount" 

5095 ,SUM(CASE WHEN tp.rank > 0 THEN 0 ELSE 1 END) AS "unknownRank" 

5096 ,(CAST(SUM(CASE WHEN winnings > 0 THEN 1 ELSE 0 END) AS BIGINT)/CAST(COUNT(1) AS BIGINT))*100 AS itm 

5097 ,SUM(CASE WHEN rank = 1 THEN 1 ELSE 0 END) AS "_1st" 

5098 ,SUM(CASE WHEN rank = 2 THEN 1 ELSE 0 END) AS "_2nd" 

5099 ,SUM(CASE WHEN rank = 3 THEN 1 ELSE 0 END) AS "_3rd" 

5100 ,SUM(tp.winnings+COALESCE(tp.koCount*tt.koBounty,0))/100.0 AS "won" 

5101 ,SUM(CASE 

5102 WHEN tt.currency = 'play' THEN tt.buyIn 

5103 ELSE (tt.buyIn+tt.fee)/100.0 

5104 END) AS "spent" 

5105 ,SUM(tp.winnings+COALESCE(tp.koCount*tt.koBounty,0)-tt.buyIn-tt.fee)/100.0 AS "net" 

5106 ,(CAST(SUM(tp.winnings+COALESCE(tp.koCount*tt.koBounty,0) - tt.buyin - tt.fee) AS BIGINT)/ 

5107 CAST(SUM(tt.buyin+tt.fee) AS BIGINT))* 100.0 AS "roi" 

5108 ,SUM(tp.winnings+COALESCE(tp.koCount*tt.koBounty,0)-(tt.buyin+tt.fee))/100.0 

5109 /(COUNT(1)-SUM(CASE WHEN tp.rank > 0 THEN 0 ELSE 0 END)) AS "profitPerTourney" 

5110 from TourneysPlayers tp 

5111 inner join Tourneys t on (t.id = tp.tourneyId) 

5112 inner join TourneyTypes tt on (tt.Id = t.tourneyTypeId) 

5113 inner join Sites s on (s.Id = tt.siteId) 

5114 inner join Players p on (p.Id = tp.playerId) 

5115 where tp.playerId in <nametest> <sitetest> 

5116 AND ((t.startTime > '<startdate_test>' AND t.startTime < '<enddate_test>') 

5117 OR t.startTime is NULL) 

5118 group by t.tourneyTypeId, s.name, p.name, tt.currency, tt.buyin, tt.fee 

5119 , tt.category, tt.limitType, tt.speed 

5120 order by t.tourneyTypeId 

5121 ,p.name 

5122 ,s.name""" 

5123 elif db_server == 'sqlite': 

5124 self.query['tourneyPlayerDetailedStats'] = """ 

5125 select s.name AS siteName 

5126 ,tt.currency AS currency 

5127 ,(CASE 

5128 WHEN tt.currency = 'play' THEN tt.buyIn 

5129 ELSE tt.buyIn/100.0 

5130 END) AS buyIn 

5131 ,tt.fee/100.0 AS fee 

5132 ,tt.category AS category 

5133 ,tt.limitType AS limitType 

5134 ,tt.speed AS speed 

5135 ,tt.maxSeats AS maxSeats 

5136 ,tt.knockout AS knockout 

5137 ,tt.reEntry AS reEntry 

5138 ,p.name AS playerName 

5139 ,COUNT(1) AS tourneyCount 

5140 ,SUM(CASE WHEN tp.rank > 0 THEN 0 ELSE 1 END) AS unknownRank 

5141 ,(CAST(SUM(CASE WHEN winnings > 0 THEN 1 ELSE 0 END) AS REAL)/CAST(COUNT(1) AS REAL))*100 AS itm 

5142 ,SUM(CASE WHEN rank = 1 THEN 1 ELSE 0 END) AS _1st 

5143 ,SUM(CASE WHEN rank = 2 THEN 1 ELSE 0 END) AS _2nd 

5144 ,SUM(CASE WHEN rank = 3 THEN 1 ELSE 0 END) AS _3rd 

5145 ,SUM(tp.winnings+COALESCE(tp.koCount*tt.koBounty,0))/100.0 AS won 

5146 ,SUM(CASE 

5147 WHEN tt.currency = 'play' THEN tt.buyIn 

5148 ELSE (tt.buyIn+tt.fee)/100.0 

5149 END) AS spent 

5150 ,SUM(tp.winnings+COALESCE(tp.koCount*tt.koBounty,0)-tt.buyIn-tt.fee)/100.0 AS net 

5151 ,(CAST(SUM(tp.winnings+COALESCE(tp.koCount*tt.koBounty,0) - tt.buyin - tt.fee) AS REAL)/ 

5152 CAST(SUM(tt.buyin+tt.fee) AS REAL))* 100.0 AS roi 

5153 ,SUM(tp.winnings+COALESCE(tp.koCount*tt.koBounty,0)-(tt.buyin+tt.fee))/100.0/(COUNT(1)-SUM(CASE WHEN tp.rank > 0 THEN 0 ELSE 1 END)) AS profitPerTourney 

5154 from TourneysPlayers tp 

5155 inner join Tourneys t on (t.id = tp.tourneyId) 

5156 inner join TourneyTypes tt on (tt.Id = t.tourneyTypeId) 

5157 inner join Sites s on (s.Id = tt.siteId) 

5158 inner join Players p on (p.Id = tp.playerId) 

5159 where tp.playerId in <nametest> <sitetest> 

5160 AND ((t.startTime > '<startdate_test>' AND t.startTime < '<enddate_test>') 

5161 OR t.startTime is NULL) 

5162 group by tourneyTypeId, playerName 

5163 order by tourneyTypeId 

5164 ,playerName 

5165 ,siteName""" 

5166 

5167 if db_server == 'mysql': 

5168 self.query['playerStats'] = """ 

5169 SELECT 

5170 concat(upper(stats.limitType), ' ' 

5171 ,concat(upper(substring(stats.category,1,1)),substring(stats.category,2) ), ' ' 

5172 ,stats.name, ' ' 

5173 ,cast(stats.bigBlindDesc as char) 

5174 ) AS Game 

5175 ,stats.n 

5176 ,stats.vpip 

5177 ,stats.pfr 

5178 ,stats.pf3 

5179 ,stats.pf4 

5180 ,stats.pff3 

5181 ,stats.pff4 

5182 ,stats.steals 

5183 ,stats.saw_f 

5184 ,stats.sawsd 

5185 ,stats.wtsdwsf 

5186 ,stats.wmsd 

5187 ,stats.FlAFq 

5188 ,stats.TuAFq 

5189 ,stats.RvAFq 

5190 ,stats.PoFAFq 

5191 ,stats.Net 

5192 ,stats.BBper100 

5193 ,stats.Profitperhand 

5194 ,case when hprof2.variance = -999 then '-' 

5195 else format(hprof2.variance, 2) 

5196 end AS Variance 

5197 ,case when hprof2.stddev = -999 then '-' 

5198 else format(hprof2.stddev, 2) 

5199 end AS Stddev 

5200 ,stats.AvgSeats 

5201 FROM 

5202 (select /* stats from hudcache */ 

5203 gt.base 

5204 ,gt.category 

5205 ,upper(gt.limitType) as limitType 

5206 ,s.name 

5207 ,<selectgt.bigBlind> AS bigBlindDesc 

5208 ,<hcgametypeId> AS gtId 

5209 ,sum(n) AS n 

5210 ,case when sum(street0VPIChance) = 0 then '0' 

5211 else format(100.0*sum(street0VPI)/sum(street0VPIChance),1) 

5212 end AS vpip 

5213 ,case when sum(street0AggrChance) = 0 then '0' 

5214 else format(100.0*sum(street0Aggr)/sum(street0AggrChance),1) 

5215 end AS pfr 

5216 ,case when sum(street0CalledRaiseChance) = 0 then '0' 

5217 else format(100.0*sum(street0CalledRaiseDone)/sum(street0CalledRaiseChance),1) 

5218 end AS car0 

5219 ,case when sum(street0_3Bchance) = 0 then '0' 

5220 else format(100.0*sum(street0_3Bdone)/sum(street0_3Bchance),1) 

5221 end AS pf3 

5222 ,case when sum(street0_4Bchance) = 0 then '0' 

5223 else format(100.0*sum(street0_4Bdone)/sum(street0_4Bchance),1) 

5224 end AS pf4 

5225 ,case when sum(street0_FoldTo3Bchance) = 0 then '0' 

5226 else format(100.0*sum(street0_FoldTo3Bdone)/sum(street0_FoldTo3Bchance),1) 

5227 end AS pff3 

5228 ,case when sum(street0_FoldTo4Bchance) = 0 then '0' 

5229 else format(100.0*sum(street0_FoldTo4Bdone)/sum(street0_FoldTo4Bchance),1) 

5230 end AS pff4 

5231 ,case when sum(raiseFirstInChance) = 0 then '-' 

5232 else format(100.0*sum(raisedFirstIn)/sum(raiseFirstInChance),1) 

5233 end AS steals 

5234 ,format(100.0*sum(street1Seen)/sum(n),1) AS saw_f 

5235 ,format(100.0*sum(sawShowdown)/sum(n),1) AS sawsd 

5236 ,case when sum(street1Seen) = 0 then '-' 

5237 else format(100.0*sum(sawShowdown)/sum(street1Seen),1) 

5238 end AS wtsdwsf 

5239 ,case when sum(sawShowdown) = 0 then '-' 

5240 else format(100.0*sum(wonAtSD)/sum(sawShowdown),1) 

5241 end AS wmsd 

5242 ,case when sum(street1Seen) = 0 then '-' 

5243 else format(100.0*sum(street1Aggr)/sum(street1Seen),1) 

5244 end AS FlAFq 

5245 ,case when sum(street2Seen) = 0 then '-' 

5246 else format(100.0*sum(street2Aggr)/sum(street2Seen),1) 

5247 end AS TuAFq 

5248 ,case when sum(street3Seen) = 0 then '-' 

5249 else format(100.0*sum(street3Aggr)/sum(street3Seen),1) 

5250 end AS RvAFq 

5251 ,case when sum(street1Seen)+sum(street2Seen)+sum(street3Seen) = 0 then '-' 

5252 else format(100.0*(sum(street1Aggr)+sum(street2Aggr)+sum(street3Aggr)) 

5253 /(sum(street1Seen)+sum(street2Seen)+sum(street3Seen)),1) 

5254 end AS PoFAFq 

5255 ,format(sum(totalProfit)/100.0,2) AS Net 

5256 ,format((sum(totalProfit/(gt.bigBlind+0.0))) / (sum(n)/100.0),2) 

5257 AS BBper100 

5258 ,format( (sum(totalProfit)/100.0) / sum(n), 4) AS Profitperhand 

5259 ,format( sum(seats*n)/(sum(n)+0.0), 2) AS AvgSeats 

5260 from Gametypes gt 

5261 inner join Sites s on s.Id = gt.siteId 

5262 inner join HudCache hc on hc.gametypeId = gt.Id 

5263 where hc.playerId in <player_test> 

5264 <gtbigBlind_test> 

5265 and hc.seats <seats_test> 

5266 and concat( '20', substring(hc.styleKey,2,2), '-', substring(hc.styleKey,4,2), '-' 

5267 , substring(hc.styleKey,6,2) ) <datestest> 

5268 group by gt.base 

5269 ,gt.category 

5270 ,upper(gt.limitType) 

5271 ,s.name 

5272 <groupbygt.bigBlind> 

5273 ,gtId 

5274 ) stats 

5275 inner join 

5276 ( select # profit from handsplayers/handsactions 

5277 hprof.gtId, sum(hprof.profit) sum_profit, 

5278 avg(hprof.profit/100.0) profitperhand, 

5279 case when hprof.gtId = -1 then -999 

5280 else variance(hprof.profit/100.0) 

5281 end as variance 

5282 ,sqrt(variance(hprof.profit/100.0)) AS stddev 

5283 from 

5284 (select hp.handId, <hgametypeId> as gtId, hp.totalProfit as profit 

5285 from HandsPlayers hp 

5286 inner join Hands h ON h.id = hp.handId 

5287 where hp.playerId in <player_test> 

5288 and hp.tourneysPlayersId IS NULL 

5289 and date_format(h.startTime, '%Y-%m-%d') <datestest> 

5290 group by hp.handId, gtId, hp.totalProfit 

5291 ) hprof 

5292 group by hprof.gtId 

5293 ) hprof2 

5294 on hprof2.gtId = stats.gtId 

5295 order by stats.category, stats.limittype, stats.bigBlindDesc desc <orderbyseats>""" 

5296 elif db_server == 'sqlite': 

5297 self.query['playerStats'] = """ 

5298 SELECT 

5299 upper(substr(stats.category,1,1)) || substr(stats.category,2) || ' ' || 

5300 stats.name || ' ' || 

5301 cast(stats.bigBlindDesc as char) || ' ' || stats.maxSeats || ' seat' AS Game 

5302 ,stats.n,stats.vpip,stats.pfr,stats.pf3,stats.pf4,stats.pff3,stats.pff4 

5303 ,stats.steals,stats.saw_f,stats.sawsd,stats.wtsdwsf,stats.wmsd,stats.FlAFq 

5304 ,stats.TuAFq,stats.RvAFq,stats.PoFAFq,stats.Net,stats.BBper100,stats.Profitperhand 

5305 ,case when hprof2.variance = -999 then '-' else round(hprof2.variance, 2) 

5306 end AS Variance 

5307 ,case when hprof2.stddev = -999 then '-' else round(hprof2.stddev, 2) 

5308 end AS Stddev 

5309 ,stats.AvgSeats 

5310 FROM 

5311 (select /* stats from hudcache */ 

5312 gt.base 

5313 ,gt.category,maxSeats,gt.bigBlind,gt.currency 

5314 ,upper(gt.limitType) AS limitType 

5315 ,s.name 

5316 ,<selectgt.bigBlind> AS bigBlindDesc 

5317 ,<hcgametypeId> AS gtId 

5318 ,sum(n) AS n 

5319 ,case when sum(street0VPIChance) = 0 then '0' 

5320 else round(100.0*sum(street0VPI)/sum(street0VPIChance),1) 

5321 end AS vpip 

5322 ,case when sum(street0AggrChance) = 0 then '0' 

5323 else round(100.0*sum(street0Aggr)/sum(street0AggrChance),1) 

5324 end AS pfr 

5325 ,case when sum(street0CalledRaiseChance) = 0 then '0' 

5326 else round(100.0*sum(street0CalledRaiseDone)/sum(street0CalledRaiseChance),1) 

5327 end AS car0 

5328 ,case when sum(street0_3Bchance) = 0 then '0' 

5329 else round(100.0*sum(street0_3Bdone)/sum(street0_3Bchance),1) 

5330 end AS pf3 

5331 ,case when sum(street0_4Bchance) = 0 then '0' 

5332 else round(100.0*sum(street0_4Bdone)/sum(street0_4Bchance),1) 

5333 end AS pf4 

5334 ,case when sum(street0_FoldTo3Bchance) = 0 then '0' 

5335 else round(100.0*sum(street0_FoldTo3Bdone)/sum(street0_FoldTo3Bchance),1) 

5336 end AS pff3 

5337 ,case when sum(street0_FoldTo4Bchance) = 0 then '0' 

5338 else round(100.0*sum(street0_FoldTo4Bdone)/sum(street0_FoldTo4Bchance),1) 

5339 end AS pff4 

5340 ,case when sum(raiseFirstInChance) = 0 then '-' 

5341 else round(100.0*sum(raisedFirstIn)/sum(raiseFirstInChance),1) 

5342 end AS steals 

5343 ,round(100.0*sum(street1Seen)/sum(n),1) AS saw_f 

5344 ,round(100.0*sum(sawShowdown)/sum(n),1) AS sawsd 

5345 ,case when sum(street1Seen) = 0 then '-' 

5346 else round(100.0*sum(sawShowdown)/sum(street1Seen),1) 

5347 end AS wtsdwsf 

5348 ,case when sum(sawShowdown) = 0 then '-' 

5349 else round(100.0*sum(wonAtSD)/sum(sawShowdown),1) 

5350 end AS wmsd 

5351 ,case when sum(street1Seen) = 0 then '-' 

5352 else round(100.0*sum(street1Aggr)/sum(street1Seen),1) 

5353 end AS FlAFq 

5354 ,case when sum(street2Seen) = 0 then '-' 

5355 else round(100.0*sum(street2Aggr)/sum(street2Seen),1) 

5356 end AS TuAFq 

5357 ,case when sum(street3Seen) = 0 then '-' 

5358 else round(100.0*sum(street3Aggr)/sum(street3Seen),1) 

5359 end AS RvAFq 

5360 ,case when sum(street1Seen)+sum(street2Seen)+sum(street3Seen) = 0 then '-' 

5361 else round(100.0*(sum(street1Aggr)+sum(street2Aggr)+sum(street3Aggr)) 

5362 /(sum(street1Seen)+sum(street2Seen)+sum(street3Seen)),1) 

5363 end AS PoFAFq 

5364 ,round(sum(totalProfit)/100.0,2) AS Net 

5365 ,round((sum(totalProfit/(gt.bigBlind+0.0))) / (sum(n)/100.0),2) 

5366 AS BBper100 

5367 ,round( (sum(totalProfit)/100.0) / sum(n), 4) AS Profitperhand 

5368 ,round( sum(seats*n)/(sum(n)+0.0), 2) AS AvgSeats 

5369 from Gametypes gt 

5370 inner join Sites s on s.Id = gt.siteId 

5371 inner join HudCache hc on hc.gametypeId = gt.Id 

5372 where hc.playerId in <player_test> 

5373 <gtbigBlind_test> 

5374 and hc.seats <seats_test> 

5375 and '20' || substr(hc.styleKey,2,2) || '-' || substr(hc.styleKey,4,2) || '-' || 

5376 substr(hc.styleKey,6,2) <datestest> 

5377 group by gt.base,gt.category,upper(gt.limitType),s.name <groupbygt.bigBlind>,gtId 

5378 ) stats 

5379 inner join 

5380 ( select /* profit from handsplayers/handsactions */ 

5381 hprof.gtId, sum(hprof.profit) sum_profit, 

5382 avg(hprof.profit/100.0) profitperhand, 

5383 case when hprof.gtId = -1 then -999 

5384 else variance(hprof.profit/100.0) 

5385 end as variance 

5386 ,case when hprof.gtId = -1 then -999 

5387 else sqrt(variance(hprof.profit/100.0)) 

5388 end as stddev 

5389 from 

5390 (select hp.handId, <hgametypeId> as gtId, hp.totalProfit as profit 

5391 from HandsPlayers hp 

5392 inner join Hands h ON h.id = hp.handId 

5393 where hp.playerId in <player_test> 

5394 and hp.tourneysPlayersId IS NULL 

5395 and datetime(h.startTime) <datestest> 

5396 group by hp.handId, gtId, hp.totalProfit 

5397 ) hprof 

5398 group by hprof.gtId 

5399 ) hprof2 

5400 on hprof2.gtId = stats.gtId 

5401 order by stats.category, stats.bigBlind, stats.limittype, stats.currency, stats.maxSeats <orderbyseats>""" 

5402 else: # assume postgres 

5403 self.query['playerStats'] = """ 

5404 SELECT upper(stats.limitType) || ' ' 

5405 || initcap(stats.category) || ' ' 

5406 || stats.name || ' ' 

5407 || stats.bigBlindDesc AS Game 

5408 ,stats.n 

5409 ,stats.vpip 

5410 ,stats.pfr 

5411 ,stats.pf3 

5412 ,stats.pf4 

5413 ,stats.pff3 

5414 ,stats.pff4 

5415 ,stats.steals 

5416 ,stats.saw_f 

5417 ,stats.sawsd 

5418 ,stats.wtsdwsf 

5419 ,stats.wmsd 

5420 ,stats.FlAFq 

5421 ,stats.TuAFq 

5422 ,stats.RvAFq 

5423 ,stats.PoFAFq 

5424 ,stats.Net 

5425 ,stats.BBper100 

5426 ,stats.Profitperhand 

5427 ,case when hprof2.variance = -999 then '-' 

5428 else to_char(hprof2.variance, '0D00') 

5429 end AS Variance 

5430 ,case when hprof2.stddev = -999 then '-' 

5431 else to_char(hprof2.stddev, '0D00') 

5432 end AS Stddev 

5433 ,AvgSeats 

5434 FROM 

5435 (select gt.base 

5436 ,gt.category 

5437 ,upper(gt.limitType) AS limitType 

5438 ,s.name 

5439 ,<selectgt.bigBlind> AS bigBlindDesc 

5440 ,<hcgametypeId> AS gtId 

5441 ,sum(n) AS n 

5442 ,case when sum(street0VPIChance) = 0 then '0' 

5443 else to_char(100.0*sum(street0VPI)/sum(street0VPIChance),'990D0') 

5444 end AS vpip 

5445 ,case when sum(street0AggrChance) = 0 then '0' 

5446 else to_char(100.0*sum(street0Aggr)/sum(street0AggrChance),'90D0') 

5447 end AS pfr 

5448 ,case when sum(street0CalledRaiseChance) = 0 then '0' 

5449 else to_char(100.0*sum(street0CalledRaiseDone)/sum(street0CalledRaiseChance),'90D0') 

5450 end AS car0 

5451 ,case when sum(street0_3Bchance) = 0 then '0' 

5452 else to_char(100.0*sum(street0_3Bdone)/sum(street0_3Bchance),'90D0') 

5453 end AS pf3 

5454 ,case when sum(street0_4Bchance) = 0 then '0' 

5455 else round(100.0*sum(street0_4Bdone)/sum(street0_4Bchance),1) 

5456 end AS pf4 

5457 ,case when sum(street0_FoldTo3Bchance) = 0 then '0' 

5458 else round(100.0*sum(street0_FoldTo3Bdone)/sum(street0_FoldTo3Bchance),1) 

5459 end AS pff3 

5460 ,case when sum(street0_FoldTo4Bchance) = 0 then '0' 

5461 else round(100.0*sum(street0_FoldTo4Bdone)/sum(street0_FoldTo4Bchance),1) 

5462 end AS pff4 

5463 ,case when sum(raiseFirstInChance) = 0 then '-' 

5464 else to_char(100.0*sum(raisedFirstIn)/sum(raiseFirstInChance),'90D0') 

5465 end AS steals 

5466 ,to_char(100.0*sum(street1Seen)/sum(n),'90D0') AS saw_f 

5467 ,to_char(100.0*sum(sawShowdown)/sum(n),'90D0') AS sawsd 

5468 ,case when sum(street1Seen) = 0 then '-' 

5469 else to_char(100.0*sum(sawShowdown)/sum(street1Seen),'90D0') 

5470 end AS wtsdwsf 

5471 ,case when sum(sawShowdown) = 0 then '-' 

5472 else to_char(100.0*sum(wonAtSD)/sum(sawShowdown),'90D0') 

5473 end AS wmsd 

5474 ,case when sum(street1Seen) = 0 then '-' 

5475 else to_char(100.0*sum(street1Aggr)/sum(street1Seen),'90D0') 

5476 end AS FlAFq 

5477 ,case when sum(street2Seen) = 0 then '-' 

5478 else to_char(100.0*sum(street2Aggr)/sum(street2Seen),'90D0') 

5479 end AS TuAFq 

5480 ,case when sum(street3Seen) = 0 then '-' 

5481 else to_char(100.0*sum(street3Aggr)/sum(street3Seen),'90D0') 

5482 end AS RvAFq 

5483 ,case when sum(street1Seen)+sum(street2Seen)+sum(street3Seen) = 0 then '-' 

5484 else to_char(100.0*(sum(street1Aggr)+sum(street2Aggr)+sum(street3Aggr)) 

5485 /(sum(street1Seen)+sum(street2Seen)+sum(street3Seen)),'90D0') 

5486 end AS PoFAFq 

5487 ,round(sum(totalProfit)/100.0,2) AS Net 

5488 ,to_char((sum(totalProfit/(gt.bigBlind+0.0))) / (sum(n)/100.0), '990D00') 

5489 AS BBper100 

5490 ,to_char(sum(totalProfit/100.0) / (sum(n)+0.0), '990D0000') AS Profitperhand 

5491 ,to_char(sum(seats*n)/(sum(n)+0.0),'90D00') AS AvgSeats 

5492 from Gametypes gt 

5493 inner join Sites s on s.Id = gt.siteId 

5494 inner join HudCache hc on hc.gametypeId = gt.Id 

5495 where hc.playerId in <player_test> 

5496 <gtbigBlind_test> 

5497 and hc.seats <seats_test> 

5498 and '20' || SUBSTR(hc.styleKey,2,2) || '-' || SUBSTR(hc.styleKey,4,2) || '-' 

5499 || SUBSTR(hc.styleKey,6,2) <datestest> 

5500 group by gt.base 

5501 ,gt.category 

5502 ,upper(gt.limitType) 

5503 ,s.name 

5504 <groupbygt.bigBlind> 

5505 ,gtId 

5506 ) stats 

5507 inner join 

5508 ( select 

5509 hprof.gtId, sum(hprof.profit) AS sum_profit, 

5510 avg(hprof.profit/100.0) AS profitperhand, 

5511 case when hprof.gtId = -1 then -999 

5512 else variance(hprof.profit/100.0) 

5513 end as variance 

5514 ,case when hprof.gtId = -1 then -999 

5515 else sqrt(variance(hprof.profit/100.0)) 

5516 end as stddev 

5517 from 

5518 (select hp.handId, <hgametypeId> as gtId, hp.totalProfit as profit 

5519 from HandsPlayers hp 

5520 inner join Hands h ON (h.id = hp.handId) 

5521 where hp.playerId in <player_test> 

5522 and hp.tourneysPlayersId IS NULL 

5523 and to_char(h.startTime, 'YYYY-MM-DD') <datestest> 

5524 group by hp.handId, gtId, hp.totalProfit 

5525 ) hprof 

5526 group by hprof.gtId 

5527 ) hprof2 

5528 on hprof2.gtId = stats.gtId 

5529 order by stats.base, stats.limittype, stats.bigBlindDesc desc <orderbyseats>""" 

5530 

5531 if db_server == 'mysql': 

5532 self.query['playerStatsByPosition'] = """ 

5533 SELECT 

5534 concat(upper(stats.limitType), ' ' 

5535 ,concat(upper(substring(stats.category,1,1)),substring(stats.category,2) ), ' ' 

5536 ,stats.name, ' ' 

5537 ,cast(stats.bigBlindDesc as char) 

5538 ) AS Game 

5539 ,case when stats.PlPosition = -2 then 'BB' 

5540 when stats.PlPosition = -1 then 'SB' 

5541 when stats.PlPosition = 0 then 'Btn' 

5542 when stats.PlPosition = 1 then 'CO' 

5543 when stats.PlPosition = 2 then 'MP' 

5544 when stats.PlPosition = 5 then 'EP' 

5545 else 'xx' 

5546 end AS PlPosition 

5547 ,stats.n 

5548 ,stats.vpip 

5549 ,stats.pfr 

5550 ,stats.car0 

5551 ,stats.pf3 

5552 ,stats.pf4 

5553 ,stats.pff3 

5554 ,stats.pff4 

5555 ,stats.steals 

5556 ,stats.saw_f 

5557 ,stats.sawsd 

5558 ,stats.wtsdwsf 

5559 ,stats.wmsd 

5560 ,stats.FlAFq 

5561 ,stats.TuAFq 

5562 ,stats.RvAFq 

5563 ,stats.PoFAFq 

5564 ,stats.Net 

5565 ,stats.BBper100 

5566 ,stats.Profitperhand 

5567 ,case when hprof2.variance = -999 then '-' 

5568 else format(hprof2.variance, 2) 

5569 end AS Variance 

5570 ,case when hprof2.stddev = -999 then '-' 

5571 else format(hprof2.stddev, 2) 

5572 end AS Stddev 

5573 ,stats.AvgSeats 

5574 FROM 

5575 (select /* stats from hudcache */ 

5576 gt.base 

5577 ,gt.category 

5578 ,upper(gt.limitType) AS limitType 

5579 ,s.name 

5580 ,<selectgt.bigBlind> AS bigBlindDesc 

5581 ,<hcgametypeId> AS gtId 

5582 ,case when hc.position = 'B' then -2 

5583 when hc.position = 'S' then -1 

5584 when hc.position = 'D' then 0 

5585 when hc.position = 'C' then 1 

5586 when hc.position = 'M' then 2 

5587 when hc.position = 'E' then 5 

5588 else 9 

5589 end as PlPosition 

5590 ,sum(n) AS n 

5591 ,case when sum(street0VPIChance) = 0 then '0' 

5592 else format(100.0*sum(street0VPI)/sum(street0VPIChance),1) 

5593 end AS vpip 

5594 ,case when sum(street0AggrChance) = 0 then '0' 

5595 else format(100.0*sum(street0Aggr)/sum(street0AggrChance),1) 

5596 end AS pfr 

5597 ,case when sum(street0CalledRaiseChance) = 0 then '0' 

5598 else format(100.0*sum(street0CalledRaiseDone)/sum(street0CalledRaiseChance),1) 

5599 end AS car0 

5600 ,case when sum(street0_3Bchance) = 0 then '0' 

5601 else format(100.0*sum(street0_3Bdone)/sum(street0_3Bchance),1) 

5602 end AS pf3 

5603 ,case when sum(street0_4Bchance) = 0 then '0' 

5604 else format(100.0*sum(street0_4Bdone)/sum(street0_4Bchance),1) 

5605 end AS pf4 

5606 ,case when sum(street0_FoldTo3Bchance) = 0 then '0' 

5607 else format(100.0*sum(street0_FoldTo3Bdone)/sum(street0_FoldTo3Bchance),1) 

5608 end AS pff3 

5609 ,case when sum(street0_FoldTo4Bchance) = 0 then '0' 

5610 else format(100.0*sum(street0_FoldTo4Bdone)/sum(street0_FoldTo4Bchance),1) 

5611 end AS pff4 

5612 ,case when sum(raiseFirstInChance) = 0 then '-' 

5613 else format(100.0*sum(raisedFirstIn)/sum(raiseFirstInChance),1) 

5614 end AS steals 

5615 ,format(100.0*sum(street1Seen)/sum(n),1) AS saw_f 

5616 ,format(100.0*sum(sawShowdown)/sum(n),1) AS sawsd 

5617 ,case when sum(street1Seen) = 0 then '-' 

5618 else format(100.0*sum(sawShowdown)/sum(street1Seen),1) 

5619 end AS wtsdwsf 

5620 ,case when sum(sawShowdown) = 0 then '-' 

5621 else format(100.0*sum(wonAtSD)/sum(sawShowdown),1) 

5622 end AS wmsd 

5623 ,case when sum(street1Seen) = 0 then '-' 

5624 else format(100.0*sum(street1Aggr)/sum(street1Seen),1) 

5625 end AS FlAFq 

5626 ,case when sum(street2Seen) = 0 then '-' 

5627 else format(100.0*sum(street2Aggr)/sum(street2Seen),1) 

5628 end AS TuAFq 

5629 ,case when sum(street3Seen) = 0 then '-' 

5630 else format(100.0*sum(street3Aggr)/sum(street3Seen),1) 

5631 end AS RvAFq 

5632 ,case when sum(street1Seen)+sum(street2Seen)+sum(street3Seen) = 0 then '-' 

5633 else format(100.0*(sum(street1Aggr)+sum(street2Aggr)+sum(street3Aggr)) 

5634 /(sum(street1Seen)+sum(street2Seen)+sum(street3Seen)),1) 

5635 end AS PoFAFq 

5636 ,format(sum(totalProfit)/100.0,2) AS Net 

5637 ,format((sum(totalProfit/(gt.bigBlind+0.0))) / (sum(n)/100.0),2) 

5638 AS BBper100 

5639 ,format( (sum(totalProfit)/100.0) / sum(n), 4) AS Profitperhand 

5640 ,format( sum(seats*n)/(sum(n)+0.0), 2) AS AvgSeats 

5641 from Gametypes gt 

5642 inner join Sites s on s.Id = gt.siteId 

5643 inner join HudCache hc on hc.gametypeId = gt.Id 

5644 where hc.playerId in <player_test> 

5645 <gtbigBlind_test> 

5646 and hc.seats <seats_test> 

5647 and concat( '20', substring(hc.styleKey,2,2), '-', substring(hc.styleKey,4,2), '-' 

5648 , substring(hc.styleKey,6,2) ) <datestest> 

5649 group by gt.base 

5650 ,gt.category 

5651 ,upper(gt.limitType) 

5652 ,s.name 

5653 <groupbygt.bigBlind> 

5654 ,gtId 

5655 <groupbyseats> 

5656 ,PlPosition 

5657 ) stats 

5658 inner join 

5659 ( select # profit from handsplayers/handsactions 

5660 hprof.gtId, 

5661 case when hprof.position = 'B' then -2 

5662 when hprof.position = 'S' then -1 

5663 when hprof.position in ('3','4') then 2 

5664 when hprof.position in ('6','7') then 5 

5665 else hprof.position 

5666 end as PlPosition, 

5667 sum(hprof.profit) as sum_profit, 

5668 avg(hprof.profit/100.0) as profitperhand, 

5669 case when hprof.gtId = -1 then -999 

5670 else variance(hprof.profit/100.0) 

5671 end as variance 

5672 ,case when hprof.gtId = -1 then -999 

5673 else sqrt(variance(hprof.profit/100.0)) 

5674 end as stddev 

5675 from 

5676 (select hp.handId, <hgametypeId> as gtId, hp.position 

5677 , hp.totalProfit as profit 

5678 from HandsPlayers hp 

5679 inner join Hands h ON (h.id = hp.handId) 

5680 where hp.playerId in <player_test> 

5681 and hp.tourneysPlayersId IS NULL 

5682 and date_format(h.startTime, '%Y-%m-%d') <datestest> 

5683 group by hp.handId, gtId, hp.position, hp.totalProfit 

5684 ) hprof 

5685 group by hprof.gtId, PlPosition 

5686 ) hprof2 

5687 on ( hprof2.gtId = stats.gtId 

5688 and hprof2.PlPosition = stats.PlPosition) 

5689 order by stats.category, stats.limitType, stats.bigBlindDesc desc 

5690 <orderbyseats>, cast(stats.PlPosition as signed) 

5691 """ 

5692 elif db_server == 'sqlite': 

5693 self.query['playerStatsByPosition'] = """ 

5694 SELECT 

5695 upper(substr(stats.category,1,1)) || substr(stats.category,2) || ' ' || 

5696 stats.name || ' ' || 

5697 cast(stats.bigBlindDesc as char) || ' ' || stats.maxSeats || ' seat' AS Game 

5698 ,case when stats.PlPosition = -2 then 'BB' 

5699 when stats.PlPosition = -1 then 'SB' 

5700 when stats.PlPosition = 0 then 'Btn' 

5701 when stats.PlPosition = 1 then 'CO' 

5702 when stats.PlPosition = 2 then 'MP' 

5703 when stats.PlPosition = 5 then 'EP' 

5704 else 'xx' 

5705 end AS PlPosition 

5706 ,stats.n,stats.vpip,stats.pfr,stats.pf3,stats.pf4,stats.pff3,stats.pff4 

5707 ,stats.steals,stats.saw_f,stats.sawsd,stats.wtsdwsf,stats.wmsd,stats.FlAFq 

5708 ,stats.TuAFq,stats.RvAFq,stats.PoFAFq,stats.Net,stats.BBper100,stats.Profitperhand 

5709 ,case when hprof2.variance = -999 then '-' 

5710 else round(hprof2.variance, 2) 

5711 end AS Variance 

5712 ,case when hprof2.variance = -999 then '-' 

5713 else round(hprof2.stddev, 2) 

5714 end AS Stddev 

5715 ,stats.AvgSeats 

5716 FROM 

5717 (select /* stats from hudcache */ 

5718 gt.base 

5719 ,gt.category,maxSeats,gt.bigBlind,gt.currency 

5720 ,upper(gt.limitType) AS limitType 

5721 ,s.name 

5722 ,<selectgt.bigBlind> AS bigBlindDesc 

5723 ,<hcgametypeId> AS gtId 

5724 ,case when hc.position = 'B' then -2 

5725 when hc.position = 'S' then -1 

5726 when hc.position = 'D' then 0 

5727 when hc.position = 'C' then 1 

5728 when hc.position = 'M' then 2 

5729 when hc.position = 'E' then 5 

5730 else 9 

5731 end AS PlPosition 

5732 ,sum(n) AS n 

5733 ,case when sum(street0VPIChance) = 0 then '0' 

5734 else round(100.0*sum(street0VPI)/sum(street0VPIChance),1) 

5735 end AS vpip 

5736 ,case when sum(street0AggrChance) = 0 then '0' 

5737 else round(100.0*sum(street0Aggr)/sum(street0AggrChance),1) 

5738 end AS pfr 

5739 ,case when sum(street0CalledRaiseChance) = 0 then '0' 

5740 else round(100.0*sum(street0CalledRaiseDone)/sum(street0CalledRaiseChance),1) 

5741 end AS car0 

5742 ,case when sum(street0_3Bchance) = 0 then '0' 

5743 else round(100.0*sum(street0_3Bdone)/sum(street0_3Bchance),1) 

5744 end AS pf3 

5745 ,case when sum(street0_4Bchance) = 0 then '0' 

5746 else round(100.0*sum(street0_4Bdone)/sum(street0_4Bchance),1) 

5747 end AS pf4 

5748 ,case when sum(street0_FoldTo3Bchance) = 0 then '0' 

5749 else round(100.0*sum(street0_FoldTo3Bdone)/sum(street0_FoldTo3Bchance),1) 

5750 end AS pff3 

5751 ,case when sum(street0_FoldTo4Bchance) = 0 then '0' 

5752 else round(100.0*sum(street0_FoldTo4Bdone)/sum(street0_FoldTo4Bchance),1) 

5753 end AS pff4 

5754 ,case when sum(raiseFirstInChance) = 0 then '-' 

5755 else round(100.0*sum(raisedFirstIn)/sum(raiseFirstInChance),1) 

5756 end AS steals 

5757 ,round(100.0*sum(street1Seen)/sum(n),1) AS saw_f 

5758 ,round(100.0*sum(sawShowdown)/sum(n),1) AS sawsd 

5759 ,case when sum(street1Seen) = 0 then '-' 

5760 else round(100.0*sum(sawShowdown)/sum(street1Seen),1) 

5761 end AS wtsdwsf 

5762 ,case when sum(sawShowdown) = 0 then '-' 

5763 else round(100.0*sum(wonAtSD)/sum(sawShowdown),1) 

5764 end AS wmsd 

5765 ,case when sum(street1Seen) = 0 then '-' 

5766 else round(100.0*sum(street1Aggr)/sum(street1Seen),1) 

5767 end AS FlAFq 

5768 ,case when sum(street2Seen) = 0 then '-' 

5769 else round(100.0*sum(street2Aggr)/sum(street2Seen),1) 

5770 end AS TuAFq 

5771 ,case when sum(street3Seen) = 0 then '-' 

5772 else round(100.0*sum(street3Aggr)/sum(street3Seen),1) 

5773 end AS RvAFq 

5774 ,case when sum(street1Seen)+sum(street2Seen)+sum(street3Seen) = 0 then '-' 

5775 else round(100.0*(sum(street1Aggr)+sum(street2Aggr)+sum(street3Aggr)) 

5776 /(sum(street1Seen)+sum(street2Seen)+sum(street3Seen)),1) 

5777 end AS PoFAFq 

5778 ,round(sum(totalProfit)/100.0,2) AS Net 

5779 ,round((sum(totalProfit/(gt.bigBlind+0.0))) / (sum(n)/100.0),2) 

5780 AS BBper100 

5781 ,round( (sum(totalProfit)/100.0) / sum(n), 4) AS Profitperhand 

5782 ,round( sum(seats*n)/(sum(n)+0.0), 2) AS AvgSeats 

5783 from Gametypes gt 

5784 inner join Sites s on s.Id = gt.siteId 

5785 inner join HudCache hc on hc.gametypeId = gt.Id 

5786 where hc.playerId in <player_test> 

5787 <gtbigBlind_test> 

5788 and hc.seats <seats_test> 

5789 and '20' || substr(hc.styleKey,2,2) || '-' || substr(hc.styleKey,4,2) || '-' || 

5790 substr(hc.styleKey,6,2) <datestest> 

5791 group by gt.base,gt.category,upper(gt.limitType),s.name 

5792 <groupbygt.bigBlind>,gtId<groupbyseats>,PlPosition 

5793 ) stats 

5794 inner join 

5795 ( select /* profit from handsplayers/handsactions */ 

5796 hprof.gtId, 

5797 cast(case when hprof.position = 'B' then -2 

5798 when hprof.position = 'S' then -1 

5799 when hprof.position in ('3','4') then 2 

5800 when hprof.position in ('6','7') then 5 

5801 else hprof.position 

5802 end as signed) as PlPosition, 

5803 sum(hprof.profit) as sum_profit, 

5804 avg(hprof.profit/100.0) as profitperhand, 

5805 case when hprof.gtId = -1 then -999 

5806 else variance(hprof.profit/100.0) 

5807 end as variance 

5808 ,case when hprof.gtId = -1 then -999 

5809 else sqrt(variance(hprof.profit/100.0)) 

5810 end as stddev 

5811 from 

5812 (select hp.handId, <hgametypeId> as gtId, hp.position 

5813 , hp.totalProfit as profit 

5814 from HandsPlayers hp 

5815 inner join Hands h ON (h.id = hp.handId) 

5816 where hp.playerId in <player_test> 

5817 and hp.tourneysPlayersId IS NULL 

5818 and datetime(h.startTime) <datestest> 

5819 group by hp.handId, gtId, hp.position, hp.totalProfit 

5820 ) hprof 

5821 group by hprof.gtId, PlPosition 

5822 ) hprof2 

5823 on ( hprof2.gtId = stats.gtId 

5824 and hprof2.PlPosition = stats.PlPosition) 

5825 order by stats.category, stats.bigBlind, stats.limitType, stats.currency, stats.maxSeats <orderbyseats> 

5826 ,cast(stats.PlPosition as signed) 

5827 """ 

5828 else: # assume postgresql 

5829 self.query['playerStatsByPosition'] = """ 

5830 select /* stats from hudcache */ 

5831 upper(stats.limitType) || ' ' 

5832 || upper(substr(stats.category,1,1)) || substr(stats.category,2) || ' ' 

5833 || stats.name || ' ' 

5834 || stats.bigBlindDesc AS Game 

5835 ,case when stats.PlPosition = -2 then 'BB' 

5836 when stats.PlPosition = -1 then 'SB' 

5837 when stats.PlPosition = 0 then 'Btn' 

5838 when stats.PlPosition = 1 then 'CO' 

5839 when stats.PlPosition = 2 then 'MP' 

5840 when stats.PlPosition = 5 then 'EP' 

5841 else 'xx' 

5842 end AS PlPosition 

5843 ,stats.n 

5844 ,stats.vpip 

5845 ,stats.pfr 

5846 ,stats.pf3 

5847 ,stats.pf4 

5848 ,stats.pff3 

5849 ,stats.pff4 

5850 ,stats.steals 

5851 ,stats.saw_f 

5852 ,stats.sawsd 

5853 ,stats.wtsdwsf 

5854 ,stats.wmsd 

5855 ,stats.FlAFq 

5856 ,stats.TuAFq 

5857 ,stats.RvAFq 

5858 ,stats.PoFAFq 

5859 ,stats.Net 

5860 ,stats.BBper100 

5861 ,stats.Profitperhand 

5862 ,case when hprof2.variance = -999 then '-' 

5863 else to_char(hprof2.variance, '0D00') 

5864 end AS Variance 

5865 ,case when hprof2.stddev = -999 then '-' 

5866 else to_char(hprof2.stddev, '0D00') 

5867 end AS Stddev 

5868 ,stats.AvgSeats 

5869 FROM 

5870 (select /* stats from hudcache */ 

5871 gt.base 

5872 ,gt.category 

5873 ,upper(gt.limitType) AS limitType 

5874 ,s.name 

5875 ,<selectgt.bigBlind> AS bigBlindDesc 

5876 ,<hcgametypeId> AS gtId 

5877 ,case when hc.position = 'B' then -2 

5878 when hc.position = 'S' then -1 

5879 when hc.position = 'D' then 0 

5880 when hc.position = 'C' then 1 

5881 when hc.position = 'M' then 2 

5882 when hc.position = 'E' then 5 

5883 else 9 

5884 end AS PlPosition 

5885 ,sum(n) AS n 

5886 ,case when sum(street0VPIChance) = 0 then '0' 

5887 else to_char(100.0*sum(street0VPI)/sum(street0VPIChance),'990D0') 

5888 end AS vpip 

5889 ,case when sum(street0AggrChance) = 0 then '0' 

5890 else to_char(100.0*sum(street0Aggr)/sum(street0AggrChance),'90D0') 

5891 end AS pfr 

5892 ,case when sum(street0CalledRaiseChance) = 0 then '0' 

5893 else to_char(100.0*sum(street0CalledRaiseDone)/sum(street0CalledRaiseChance),'90D0') 

5894 end AS car0 

5895 ,case when sum(street0_3Bchance) = 0 then '0' 

5896 else to_char(100.0*sum(street0_3Bdone)/sum(street0_3Bchance),'90D0') 

5897 end AS pf3 

5898 ,case when sum(street0_4Bchance) = 0 then '0' 

5899 else to_char(100.0*sum(street0_4Bdone)/sum(street0_4Bchance),'90D0') 

5900 end AS pf4 

5901 ,case when sum(street0_FoldTo3Bchance) = 0 then '0' 

5902 else to_char(100.0*sum(street0_FoldTo3Bdone)/sum(street0_FoldTo3Bchance),'90D0') 

5903 end AS pff3 

5904 ,case when sum(street0_FoldTo4Bchance) = 0 then '0' 

5905 else to_char(100.0*sum(street0_FoldTo4Bdone)/sum(street0_FoldTo4Bchance),'90D0') 

5906 end AS pff4 

5907 ,case when sum(raiseFirstInChance) = 0 then '-' 

5908 else to_char(100.0*sum(raisedFirstIn)/sum(raiseFirstInChance),'90D0') 

5909 end AS steals 

5910 ,to_char(round(100.0*sum(street1Seen)/sum(n)),'90D0') AS saw_f 

5911 ,to_char(round(100.0*sum(sawShowdown)/sum(n)),'90D0') AS sawsd 

5912 ,case when sum(street1Seen) = 0 then '-' 

5913 else to_char(round(100.0*sum(sawShowdown)/sum(street1Seen)),'90D0') 

5914 end AS wtsdwsf 

5915 ,case when sum(sawShowdown) = 0 then '-' 

5916 else to_char(round(100.0*sum(wonAtSD)/sum(sawShowdown)),'90D0') 

5917 end AS wmsd 

5918 ,case when sum(street1Seen) = 0 then '-' 

5919 else to_char(round(100.0*sum(street1Aggr)/sum(street1Seen)),'90D0') 

5920 end AS FlAFq 

5921 ,case when sum(street2Seen) = 0 then '-' 

5922 else to_char(round(100.0*sum(street2Aggr)/sum(street2Seen)),'90D0') 

5923 end AS TuAFq 

5924 ,case when sum(street3Seen) = 0 then '-' 

5925 else to_char(round(100.0*sum(street3Aggr)/sum(street3Seen)),'90D0') 

5926 end AS RvAFq 

5927 ,case when sum(street1Seen)+sum(street2Seen)+sum(street3Seen) = 0 then '-' 

5928 else to_char(round(100.0*(sum(street1Aggr)+sum(street2Aggr)+sum(street3Aggr)) 

5929 /(sum(street1Seen)+sum(street2Seen)+sum(street3Seen))),'90D0') 

5930 end AS PoFAFq 

5931 ,to_char(sum(totalProfit)/100.0,'9G999G990D00') AS Net 

5932 ,case when sum(n) = 0 then '0' 

5933 else to_char(sum(totalProfit/(gt.bigBlind+0.0)) / (sum(n)/100.0), '990D00') 

5934 end AS BBper100 

5935 ,case when sum(n) = 0 then '0' 

5936 else to_char( (sum(totalProfit)/100.0) / sum(n), '90D0000') 

5937 end AS Profitperhand 

5938 ,to_char(sum(seats*n)/(sum(n)+0.0),'90D00') AS AvgSeats 

5939 from Gametypes gt 

5940 inner join Sites s on (s.Id = gt.siteId) 

5941 inner join HudCache hc on (hc.gametypeId = gt.Id) 

5942 where hc.playerId in <player_test> 

5943 <gtbigBlind_test> 

5944 and hc.seats <seats_test> 

5945 and '20' || SUBSTR(hc.styleKey,2,2) || '-' || SUBSTR(hc.styleKey,4,2) || '-' 

5946 || SUBSTR(hc.styleKey,6,2) <datestest> 

5947 group by gt.base 

5948 ,gt.category 

5949 ,upper(gt.limitType) 

5950 ,s.name 

5951 <groupbygt.bigBlind> 

5952 ,gtId 

5953 <groupbyseats> 

5954 ,PlPosition 

5955 ) stats 

5956 inner join 

5957 ( select /* profit from handsplayers/handsactions */ 

5958 hprof.gtId, 

5959 case when hprof.position = 'B' then -2 

5960 when hprof.position = 'S' then -1 

5961 when hprof.position in ('3','4') then 2 

5962 when hprof.position in ('6','7') then 5 

5963 else cast(hprof.position as smallint) 

5964 end as PlPosition, 

5965 sum(hprof.profit) as sum_profit, 

5966 avg(hprof.profit/100.0) as profitperhand, 

5967 case when hprof.gtId = -1 then -999 

5968 else variance(hprof.profit/100.0) 

5969 end as variance 

5970 ,case when hprof.gtId = -1 then -999 

5971 else sqrt(variance(hprof.profit/100.0)) 

5972 end as stddev 

5973 from 

5974 (select hp.handId, <hgametypeId> as gtId, hp.position 

5975 , hp.totalProfit as profit 

5976 from HandsPlayers hp 

5977 inner join Hands h ON (h.id = hp.handId) 

5978 where hp.playerId in <player_test> 

5979 and hp.tourneysPlayersId IS NULL 

5980 and to_char(h.startTime, 'YYYY-MM-DD') <datestest> 

5981 group by hp.handId, gametypeId, hp.position, hp.totalProfit 

5982 ) hprof 

5983 group by hprof.gtId, PlPosition 

5984 ) hprof2 

5985 on ( hprof2.gtId = stats.gtId 

5986 and hprof2.PlPosition = stats.PlPosition) 

5987 order by stats.category, stats.limitType, stats.bigBlindDesc desc 

5988 <orderbyseats>, cast(stats.PlPosition as smallint) 

5989 """ 

5990 

5991 #################################### 

5992 # Cash Game Graph query 

5993 #################################### 

5994 self.query['getRingProfitAllHandsPlayerIdSite'] = """ 

5995 SELECT hp.handId, hp.totalProfit, hp.sawShowdown 

5996 FROM HandsPlayers hp 

5997 INNER JOIN Players pl ON (pl.id = hp.playerId) 

5998 INNER JOIN Hands h ON (h.id = hp.handId) 

5999 INNER JOIN Gametypes gt ON (gt.id = h.gametypeId) 

6000 WHERE pl.id in <player_test> 

6001 AND pl.siteId in <site_test> 

6002 AND h.startTime > '<startdate_test>' 

6003 AND h.startTime < '<enddate_test>' 

6004 <limit_test> 

6005 <game_test> 

6006 AND gt.type = 'ring' 

6007 GROUP BY h.startTime, hp.handId, hp.sawShowdown, hp.totalProfit 

6008 ORDER BY h.startTime""" 

6009 

6010 self.query['getRingProfitAllHandsPlayerIdSiteInBB'] = """ 

6011 SELECT hp.handId, ( hp.totalProfit / ( gt.bigBlind * 2.0 ) ) * 100 , hp.sawShowdown, ( hp.allInEV / ( gt.bigBlind * 2.0 ) ) * 100 

6012 FROM HandsPlayers hp 

6013 INNER JOIN Players pl ON (pl.id = hp.playerId) 

6014 INNER JOIN Hands h ON (h.id = hp.handId) 

6015 INNER JOIN Gametypes gt ON (gt.id = h.gametypeId) 

6016 WHERE pl.id in <player_test> 

6017 AND pl.siteId in <site_test> 

6018 AND h.startTime > '<startdate_test>' 

6019 AND h.startTime < '<enddate_test>' 

6020 <limit_test> 

6021 <game_test> 

6022 <currency_test> 

6023 AND hp.tourneysPlayersId IS NULL 

6024 GROUP BY h.startTime, hp.handId, hp.sawShowdown, hp.totalProfit, hp.allInEV, gt.bigBlind 

6025 ORDER BY h.startTime""" 

6026 

6027 self.query['getRingProfitAllHandsPlayerIdSiteInDollars'] = """ 

6028 SELECT hp.handId, hp.totalProfit, hp.sawShowdown, hp.allInEV 

6029 FROM HandsPlayers hp 

6030 INNER JOIN Players pl ON (pl.id = hp.playerId) 

6031 INNER JOIN Hands h ON (h.id = hp.handId) 

6032 INNER JOIN Gametypes gt ON (gt.id = h.gametypeId) 

6033 WHERE pl.id in <player_test> 

6034 AND pl.siteId in <site_test> 

6035 AND h.startTime > '<startdate_test>' 

6036 AND h.startTime < '<enddate_test>' 

6037 <limit_test> 

6038 <game_test> 

6039 <currency_test> 

6040 AND hp.tourneysPlayersId IS NULL 

6041 GROUP BY h.startTime, hp.handId, hp.sawShowdown, hp.totalProfit, hp.allInEV 

6042 ORDER BY h.startTime""" 

6043 

6044 #################################### 

6045 # Tourney Results query 

6046 #################################### 

6047 self.query['tourneyResults'] = """ 

6048 SELECT tp.tourneyId, (coalesce(tp.winnings,0) - coalesce(tt.buyIn,0) - coalesce(tt.fee,0)) as profit, tp.koCount, tp.rebuyCount, tp.addOnCount, tt.buyIn, tt.fee, t.siteTourneyNo 

6049 FROM TourneysPlayers tp 

6050 INNER JOIN Players pl ON (pl.id = tp.playerId) 

6051 INNER JOIN Tourneys t ON (t.id = tp.tourneyId) 

6052 INNER JOIN TourneyTypes tt ON (tt.id = t.tourneyTypeId) 

6053 WHERE pl.id in <player_test> 

6054 AND pl.siteId in <site_test> 

6055 AND ((t.startTime > '<startdate_test>' AND t.startTime < '<enddate_test>') 

6056 OR t.startTime is NULL) 

6057 GROUP BY t.startTime, tp.tourneyId, tp.winningsCurrency, 

6058 tp.winnings, tp.koCount, 

6059 tp.rebuyCount, tp.addOnCount, 

6060 tt.buyIn, tt.fee, t.siteTourneyNo 

6061 ORDER BY t.startTime""" 

6062 

6063 #AND gt.type = 'ring' 

6064 #<limit_test> 

6065 #<game_test> 

6066 

6067 #################################### 

6068 # Tourney Graph query 

6069 # FIXME this is a horrible hack to prevent nonsense data 

6070 # being graphed - needs proper fix mantis #180 +#182 

6071 #################################### 

6072 self.query['tourneyGraph'] = """ 

6073 SELECT tp.tourneyId, (coalesce(tp.winnings,0) - coalesce(tt.buyIn,0) - coalesce(tt.fee,0)) as profit, tp.koCount, tp.rebuyCount, tp.addOnCount, tt.buyIn, tt.fee, t.siteTourneyNo 

6074 FROM TourneysPlayers tp 

6075 INNER JOIN Players pl ON (pl.id = tp.playerId) 

6076 INNER JOIN Tourneys t ON (t.id = tp.tourneyId) 

6077 INNER JOIN TourneyTypes tt ON (tt.id = t.tourneyTypeId) 

6078 WHERE pl.id in <player_test> 

6079 AND pl.siteId in <site_test> 

6080 AND (t.startTime > '<startdate_test>' AND t.startTime < '<enddate_test>') 

6081 <currency_test> 

6082 GROUP BY t.startTime, tp.tourneyId, tp.winningsCurrency, 

6083 tp.winnings, tp.koCount, 

6084 tp.rebuyCount, tp.addOnCount, 

6085 tt.buyIn, tt.fee, t.siteTourneyNo 

6086 ORDER BY t.startTime""" 

6087 

6088 #AND gt.type = 'ring' 

6089 #<limit_test> 

6090 #<game_test> 

6091 #################################### 

6092 # Tourney Graph query with tourneytypefilter 

6093 # FIXME this is a horrible hack to prevent nonsense data 

6094 # being graphed - needs proper fix mantis #180 +#182 

6095 #################################### 

6096 self.query['tourneyGraphType'] = """ 

6097 SELECT tp.tourneyId, (coalesce(tp.winnings,0) - coalesce(tt.buyIn,0) - coalesce(tt.fee,0)) as profit, tp.koCount, tp.rebuyCount, tp.addOnCount, tt.buyIn, tt.fee, t.siteTourneyNo 

6098 FROM TourneysPlayers tp 

6099 INNER JOIN Players pl ON (pl.id = tp.playerId) 

6100 INNER JOIN Tourneys t ON (t.id = tp.tourneyId) 

6101 INNER JOIN TourneyTypes tt ON (tt.id = t.tourneyTypeId) 

6102 WHERE pl.id in <player_test> 

6103 AND pl.siteId in <site_test> 

6104 AND tt.category in <tourney_cat> 

6105 AND tt.limitType in <tourney_lim> 

6106 AND tt.buyin in <tourney_buyin> 

6107 AND (t.startTime > '<startdate_test>' AND t.startTime < '<enddate_test>') 

6108 <currency_test> 

6109 GROUP BY t.startTime, tp.tourneyId, tp.winningsCurrency, 

6110 tp.winnings, tp.koCount, 

6111 tp.rebuyCount, tp.addOnCount, 

6112 tt.buyIn, tt.fee, t.siteTourneyNo 

6113 ORDER BY t.startTime""" 

6114 

6115 #AND gt.type = 'ring' 

6116 #<limit_test> 

6117 #<game_test>  

6118 

6119 #################################### 

6120 # Session stats query 

6121 #################################### 

6122 if db_server == 'mysql': 

6123 self.query['sessionStats'] = """ 

6124 SELECT UNIX_TIMESTAMP(h.startTime) as time, hp.totalProfit 

6125 FROM HandsPlayers hp 

6126 INNER JOIN Hands h on (h.id = hp.handId) 

6127 INNER JOIN Gametypes gt on (gt.Id = h.gametypeId) 

6128 INNER JOIN Sites s on (s.Id = gt.siteId) 

6129 INNER JOIN Players p on (p.Id = hp.playerId) 

6130 WHERE hp.playerId in <player_test> 

6131 AND date_format(h.startTime, '%Y-%m-%d') <datestest> 

6132 AND gt.type LIKE 'ring' 

6133 <limit_test> 

6134 <game_test> 

6135 <seats_test> 

6136 <currency_test> 

6137 ORDER by time""" 

6138 elif db_server == 'postgresql': 

6139 self.query['sessionStats'] = """ 

6140 SELECT EXTRACT(epoch from h.startTime) as time, hp.totalProfit 

6141 FROM HandsPlayers hp 

6142 INNER JOIN Hands h on (h.id = hp.handId) 

6143 INNER JOIN Gametypes gt on (gt.Id = h.gametypeId) 

6144 INNER JOIN Sites s on (s.Id = gt.siteId) 

6145 INNER JOIN Players p on (p.Id = hp.playerId) 

6146 WHERE hp.playerId in <player_test> 

6147 AND h.startTime <datestest> 

6148 AND gt.type LIKE 'ring' 

6149 <limit_test> 

6150 <game_test> 

6151 <seats_test> 

6152 <currency_test> 

6153 ORDER by time""" 

6154 elif db_server == 'sqlite': 

6155 self.query['sessionStats'] = """ 

6156 SELECT STRFTIME('<ampersand_s>', h.startTime) as time, hp.totalProfit 

6157 FROM HandsPlayers hp 

6158 INNER JOIN Hands h on (h.id = hp.handId) 

6159 INNER JOIN Gametypes gt on (gt.Id = h.gametypeId) 

6160 INNER JOIN Sites s on (s.Id = gt.siteId) 

6161 INNER JOIN Players p on (p.Id = hp.playerId) 

6162 WHERE hp.playerId in <player_test> 

6163 AND h.startTime <datestest> 

6164 AND gt.type is 'ring' 

6165 <limit_test> 

6166 <game_test> 

6167 <seats_test> 

6168 <currency_test> 

6169 ORDER by time""" 

6170 

6171 #################################### 

6172 # Querry to get all hands in a date range 

6173 #################################### 

6174 self.query['handsInRange'] = """ 

6175 select h.id 

6176 from Hands h 

6177 join HandsPlayers hp on h.id = hp.handId 

6178 join Gametypes gt on gt.id = h.gametypeId 

6179 where h.startTime <datetest> 

6180 and hp.playerId in <player_test> 

6181 <game_test> 

6182 <limit_test> 

6183 <position_test>""" 

6184 

6185 #################################### 

6186 # Querry to get all hands in a date range for cash games session 

6187 #################################### 

6188 self.query['handsInRangeSession'] = """ 

6189 select h.id 

6190 from Hands h 

6191  

6192 where h.startTime <datetest> 

6193 """ 

6194 

6195 

6196 #################################### 

6197 # Querry to get all hands in a date range for cash games session variation filter 

6198 #################################### 

6199 self.query['handsInRangeSessionFilter'] = """ 

6200 select h.id 

6201 from Hands h 

6202 join Gametypes gt on h.gametypeId = gt.id 

6203 join HandsPlayers hp on h.id = hp.handId -- utilisation de HandsPlayers 

6204 where h.startTime <datetest> 

6205 <game_test> 

6206 <limit_test> 

6207 <player_test> 

6208 <position_test> 

6209 """ 

6210 

6211 self.query['getPlayerId'] = """ 

6212 SELECT id  

6213 FROM Players  

6214 WHERE siteId = %s  

6215 AND name = %s 

6216 """ 

6217 

6218 #################################### 

6219 # Query to get a single hand for the replayer 

6220 #################################### 

6221 self.query['singleHand'] = """ 

6222 SELECT h.* 

6223 FROM Hands h 

6224 WHERE id = %s""" 

6225 

6226 #################################### 

6227 # Query to get run it twice boards for the replayer 

6228 #################################### 

6229 self.query['singleHandBoards'] = """ 

6230 SELECT b.* 

6231 FROM Boards b 

6232 WHERE handId = %s""" 

6233 

6234 #################################### 

6235 # Query to get a single player hand for the replayer 

6236 #################################### 

6237 self.query['playerHand'] = """ 

6238 SELECT 

6239 hp.seatno, 

6240 round(hp.winnings / 100.0,2) as winnings, 

6241 p.name, 

6242 round(hp.startCash / 100.0,2) as chips, 

6243 hp.card1,hp.card2,hp.card3,hp.card4,hp.card5, 

6244 hp.card6,hp.card7,hp.card8,hp.card9,hp.card10, 

6245 hp.card11,hp.card12,hp.card13,hp.card14,hp.card15, 

6246 hp.card16,hp.card17,hp.card18,hp.card19,hp.card20, 

6247 hp.position, 

6248 round(hp.startBounty / 100.0,2) as bounty, 

6249 hp.sitout 

6250 FROM 

6251 HandsPlayers as hp, 

6252 Players as p 

6253 WHERE 

6254 hp.handId = %s 

6255 and p.id = hp.playerId 

6256 ORDER BY 

6257 hp.seatno 

6258 """ 

6259 

6260 #################################### 

6261 # Query for the actions of a hand 

6262 #################################### 

6263 self.query['handActions'] = """ 

6264 SELECT 

6265 ha.actionNo, 

6266 p.name, 

6267 ha.street, 

6268 ha.actionId, 

6269 ha.allIn, 

6270 round(ha.amount / 100.0,2) as bet, 

6271 ha.numDiscarded, 

6272 ha.cardsDiscarded 

6273 FROM 

6274 HandsActions as ha, 

6275 Players as p, 

6276 Hands as h 

6277 WHERE 

6278 h.id = %s 

6279 AND ha.handId = h.id 

6280 AND ha.playerId = p.id 

6281 ORDER BY 

6282 ha.id ASC 

6283 """ 

6284 

6285 #################################### 

6286 # Queries to rebuild/modify hudcache 

6287 #################################### 

6288 

6289 self.query['clearHudCache'] = """DELETE FROM HudCache""" 

6290 self.query['clearCardsCache'] = """DELETE FROM CardsCache""" 

6291 self.query['clearPositionsCache'] = """DELETE FROM PositionsCache""" 

6292 

6293 self.query['clearHudCacheTourneyType'] = """DELETE FROM HudCache WHERE tourneyTypeId = %s""" 

6294 self.query['clearCardsCacheTourneyType'] = """DELETE FROM CardsCache WHERE tourneyTypeId = %s""" 

6295 self.query['clearPositionsCacheTourneyType'] = """DELETE FROM PositionsCache WHERE tourneyTypeId = %s""" 

6296 

6297 self.query['fetchNewHudCacheTourneyTypeIds'] = """SELECT TT.id 

6298 FROM TourneyTypes TT 

6299 LEFT OUTER JOIN HudCache HC ON (TT.id = HC.tourneyTypeId) 

6300 WHERE HC.tourneyTypeId is NULL 

6301 """ 

6302 

6303 self.query['fetchNewCardsCacheTourneyTypeIds'] = """SELECT TT.id 

6304 FROM TourneyTypes TT 

6305 LEFT OUTER JOIN CardsCache CC ON (TT.id = CC.tourneyTypeId) 

6306 WHERE CC.tourneyTypeId is NULL 

6307 """ 

6308 

6309 self.query['fetchNewPositionsCacheTourneyTypeIds'] = """SELECT TT.id 

6310 FROM TourneyTypes TT 

6311 LEFT OUTER JOIN PositionsCache PC ON (TT.id = PC.tourneyTypeId) 

6312 WHERE PC.tourneyTypeId is NULL 

6313 """ 

6314 

6315 self.query['clearCardsCacheWeeksMonths'] = """DELETE FROM CardsCache WHERE weekId = %s AND monthId = %s""" 

6316 self.query['clearPositionsCacheWeeksMonths'] = """DELETE FROM PositionsCache WHERE weekId = %s AND monthId = %s""" 

6317 

6318 self.query['selectSessionWithWeekId'] = """SELECT id FROM Sessions WHERE weekId = %s""" 

6319 self.query['selectSessionWithMonthId'] = """SELECT id FROM Sessions WHERE monthId = %s""" 

6320 

6321 self.query['deleteWeekId'] = """DELETE FROM Weeks WHERE id = %s""" 

6322 self.query['deleteMonthId'] = """DELETE FROM Months WHERE id = %s""" 

6323 

6324 self.query['fetchNewCardsCacheWeeksMonths'] = """SELECT SCG.weekId, SCG.monthId 

6325 FROM (SELECT DISTINCT weekId, monthId FROM Sessions) SCG 

6326 LEFT OUTER JOIN CardsCache CC ON (SCG.weekId = CC.weekId AND SCG.monthId = CC.monthId) 

6327 WHERE CC.weekId is NULL OR CC.monthId is NULL 

6328 """ 

6329 

6330 self.query['fetchNewPositionsCacheWeeksMonths'] = """SELECT SCG.weekId, SCG.monthId 

6331 FROM (SELECT DISTINCT weekId, monthId FROM Sessions) SCG 

6332 LEFT OUTER JOIN PositionsCache PC ON (SCG.weekId = PC.weekId AND SCG.monthId = PC.monthId) 

6333 WHERE PC.weekId is NULL OR PC.monthId is NULL 

6334 """ 

6335 

6336 

6337 

6338 if db_server == 'mysql': 

6339 self.query['rebuildCache'] = """insert into <insert> 

6340 ,n 

6341 ,street0VPIChance 

6342 ,street0VPI 

6343 ,street0AggrChance 

6344 ,street0Aggr 

6345 ,street0CalledRaiseChance 

6346 ,street0CalledRaiseDone 

6347 ,street0_2BChance 

6348 ,street0_2BDone 

6349 ,street0_3BChance 

6350 ,street0_3BDone 

6351 ,street0_4BChance 

6352 ,street0_4BDone 

6353 ,street0_C4BChance 

6354 ,street0_C4BDone 

6355 ,street0_FoldTo2BChance 

6356 ,street0_FoldTo2BDone 

6357 ,street0_FoldTo3BChance 

6358 ,street0_FoldTo3BDone 

6359 ,street0_FoldTo4BChance 

6360 ,street0_FoldTo4BDone 

6361 ,street0_SqueezeChance 

6362 ,street0_SqueezeDone 

6363 ,raiseToStealChance 

6364 ,raiseToStealDone 

6365 ,stealChance 

6366 ,stealDone 

6367 ,success_Steal 

6368 ,street1Seen 

6369 ,street2Seen 

6370 ,street3Seen 

6371 ,street4Seen 

6372 ,sawShowdown 

6373 ,street1Aggr 

6374 ,street2Aggr 

6375 ,street3Aggr 

6376 ,street4Aggr 

6377 ,otherRaisedStreet0 

6378 ,otherRaisedStreet1 

6379 ,otherRaisedStreet2 

6380 ,otherRaisedStreet3 

6381 ,otherRaisedStreet4 

6382 ,foldToOtherRaisedStreet0 

6383 ,foldToOtherRaisedStreet1 

6384 ,foldToOtherRaisedStreet2 

6385 ,foldToOtherRaisedStreet3 

6386 ,foldToOtherRaisedStreet4 

6387 ,wonWhenSeenStreet1 

6388 ,wonWhenSeenStreet2 

6389 ,wonWhenSeenStreet3 

6390 ,wonWhenSeenStreet4 

6391 ,wonAtSD 

6392 ,raiseFirstInChance 

6393 ,raisedFirstIn 

6394 ,foldBbToStealChance 

6395 ,foldedBbToSteal 

6396 ,foldSbToStealChance 

6397 ,foldedSbToSteal 

6398 ,street1CBChance 

6399 ,street1CBDone 

6400 ,street2CBChance 

6401 ,street2CBDone 

6402 ,street3CBChance 

6403 ,street3CBDone 

6404 ,street4CBChance 

6405 ,street4CBDone 

6406 ,foldToStreet1CBChance 

6407 ,foldToStreet1CBDone 

6408 ,foldToStreet2CBChance 

6409 ,foldToStreet2CBDone 

6410 ,foldToStreet3CBChance 

6411 ,foldToStreet3CBDone 

6412 ,foldToStreet4CBChance 

6413 ,foldToStreet4CBDone 

6414 ,common 

6415 ,committed 

6416 ,winnings 

6417 ,rake 

6418 ,rakeDealt 

6419 ,rakeContributed 

6420 ,rakeWeighted 

6421 ,totalProfit 

6422 ,allInEV 

6423 ,showdownWinnings 

6424 ,nonShowdownWinnings 

6425 ,street1CheckCallRaiseChance 

6426 ,street1CheckCallDone 

6427 ,street1CheckRaiseDone 

6428 ,street2CheckCallRaiseChance 

6429 ,street2CheckCallDone 

6430 ,street2CheckRaiseDone 

6431 ,street3CheckCallRaiseChance 

6432 ,street3CheckCallDone 

6433 ,street3CheckRaiseDone 

6434 ,street4CheckCallRaiseChance 

6435 ,street4CheckCallDone 

6436 ,street4CheckRaiseDone 

6437 ,street0Calls 

6438 ,street1Calls 

6439 ,street2Calls 

6440 ,street3Calls 

6441 ,street4Calls 

6442 ,street0Bets 

6443 ,street1Bets 

6444 ,street2Bets 

6445 ,street3Bets 

6446 ,street4Bets 

6447 ,street0Raises 

6448 ,street1Raises 

6449 ,street2Raises 

6450 ,street3Raises 

6451 ,street4Raises 

6452 ,street1Discards 

6453 ,street2Discards 

6454 ,street3Discards 

6455 ) 

6456 SELECT <select> 

6457 ,count(1) 

6458 ,sum(street0VPIChance) 

6459 ,sum(street0VPI) 

6460 ,sum(street0AggrChance) 

6461 ,sum(street0Aggr) 

6462 ,sum(street0CalledRaiseChance) 

6463 ,sum(street0CalledRaiseDone) 

6464 ,sum(street0_2BChance) 

6465 ,sum(street0_2BDone) 

6466 ,sum(street0_3BChance) 

6467 ,sum(street0_3BDone) 

6468 ,sum(street0_4BChance) 

6469 ,sum(street0_4BDone) 

6470 ,sum(street0_C4BChance) 

6471 ,sum(street0_C4BDone) 

6472 ,sum(street0_FoldTo2BChance) 

6473 ,sum(street0_FoldTo2BDone) 

6474 ,sum(street0_FoldTo3BChance) 

6475 ,sum(street0_FoldTo3BDone) 

6476 ,sum(street0_FoldTo4BChance) 

6477 ,sum(street0_FoldTo4BDone) 

6478 ,sum(street0_SqueezeChance) 

6479 ,sum(street0_SqueezeDone) 

6480 ,sum(raiseToStealChance) 

6481 ,sum(raiseToStealDone) 

6482 ,sum(stealChance) 

6483 ,sum(stealDone) 

6484 ,sum(success_Steal) 

6485 ,sum(street1Seen) 

6486 ,sum(street2Seen) 

6487 ,sum(street3Seen) 

6488 ,sum(street4Seen) 

6489 ,sum(sawShowdown) 

6490 ,sum(street1Aggr) 

6491 ,sum(street2Aggr) 

6492 ,sum(street3Aggr) 

6493 ,sum(street4Aggr) 

6494 ,sum(otherRaisedStreet0) 

6495 ,sum(otherRaisedStreet1) 

6496 ,sum(otherRaisedStreet2) 

6497 ,sum(otherRaisedStreet3) 

6498 ,sum(otherRaisedStreet4) 

6499 ,sum(foldToOtherRaisedStreet0) 

6500 ,sum(foldToOtherRaisedStreet1) 

6501 ,sum(foldToOtherRaisedStreet2) 

6502 ,sum(foldToOtherRaisedStreet3) 

6503 ,sum(foldToOtherRaisedStreet4) 

6504 ,sum(wonWhenSeenStreet1) 

6505 ,sum(wonWhenSeenStreet2) 

6506 ,sum(wonWhenSeenStreet3) 

6507 ,sum(wonWhenSeenStreet4) 

6508 ,sum(wonAtSD) 

6509 ,sum(raiseFirstInChance) 

6510 ,sum(raisedFirstIn) 

6511 ,sum(foldBbToStealChance) 

6512 ,sum(foldedBbToSteal) 

6513 ,sum(foldSbToStealChance) 

6514 ,sum(foldedSbToSteal) 

6515 ,sum(street1CBChance) 

6516 ,sum(street1CBDone) 

6517 ,sum(street2CBChance) 

6518 ,sum(street2CBDone) 

6519 ,sum(street3CBChance) 

6520 ,sum(street3CBDone) 

6521 ,sum(street4CBChance) 

6522 ,sum(street4CBDone) 

6523 ,sum(foldToStreet1CBChance) 

6524 ,sum(foldToStreet1CBDone) 

6525 ,sum(foldToStreet2CBChance) 

6526 ,sum(foldToStreet2CBDone) 

6527 ,sum(foldToStreet3CBChance) 

6528 ,sum(foldToStreet3CBDone) 

6529 ,sum(foldToStreet4CBChance) 

6530 ,sum(foldToStreet4CBDone) 

6531 ,sum(common) 

6532 ,sum(committed) 

6533 ,sum(winnings) 

6534 ,sum(rake) 

6535 ,sum(rakeDealt) 

6536 ,sum(rakeContributed) 

6537 ,sum(rakeWeighted) 

6538 ,sum(totalProfit) 

6539 ,sum(allInEV) 

6540 ,sum(case when sawShowdown = 1 then totalProfit else 0 end) 

6541 ,sum(case when sawShowdown = 0 then totalProfit else 0 end) 

6542 ,sum(street1CheckCallRaiseChance) 

6543 ,sum(street1CheckCallDone) 

6544 ,sum(street1CheckRaiseDone) 

6545 ,sum(street2CheckCallRaiseChance) 

6546 ,sum(street2CheckCallDone) 

6547 ,sum(street2CheckRaiseDone) 

6548 ,sum(street3CheckCallRaiseChance) 

6549 ,sum(street3CheckCallDone) 

6550 ,sum(street3CheckRaiseDone) 

6551 ,sum(street4CheckCallRaiseChance) 

6552 ,sum(street4CheckCallDone) 

6553 ,sum(street4CheckRaiseDone) 

6554 ,sum(street0Calls) 

6555 ,sum(street1Calls) 

6556 ,sum(street2Calls) 

6557 ,sum(street3Calls) 

6558 ,sum(street4Calls) 

6559 ,sum(street0Bets) 

6560 ,sum(street1Bets) 

6561 ,sum(street2Bets) 

6562 ,sum(street3Bets) 

6563 ,sum(street4Bets) 

6564 ,sum(hp.street0Raises) 

6565 ,sum(hp.street1Raises) 

6566 ,sum(hp.street2Raises) 

6567 ,sum(hp.street3Raises) 

6568 ,sum(hp.street4Raises) 

6569 ,sum(street1Discards) 

6570 ,sum(street2Discards) 

6571 ,sum(street3Discards) 

6572 FROM Hands h 

6573 INNER JOIN HandsPlayers hp ON (h.id = hp.handId<hero_join>) 

6574 INNER JOIN Gametypes g ON (h.gametypeId = g.id) 

6575 <sessions_join_clause> 

6576 <tourney_join_clause> 

6577 <where_clause> 

6578 GROUP BY <group> 

6579""" 

6580 elif db_server == 'postgresql': 

6581 self.query['rebuildCache'] = """insert into <insert> 

6582 ,n 

6583 ,street0VPIChance 

6584 ,street0VPI 

6585 ,street0AggrChance 

6586 ,street0Aggr 

6587 ,street0CalledRaiseChance 

6588 ,street0CalledRaiseDone 

6589 ,street0_2BChance 

6590 ,street0_2BDone 

6591 ,street0_3BChance 

6592 ,street0_3BDone 

6593 ,street0_4BChance 

6594 ,street0_4BDone 

6595 ,street0_C4BChance 

6596 ,street0_C4BDone 

6597 ,street0_FoldTo2BChance 

6598 ,street0_FoldTo2BDone 

6599 ,street0_FoldTo3BChance 

6600 ,street0_FoldTo3BDone 

6601 ,street0_FoldTo4BChance 

6602 ,street0_FoldTo4BDone 

6603 ,street0_SqueezeChance 

6604 ,street0_SqueezeDone 

6605 ,raiseToStealChance 

6606 ,raiseToStealDone 

6607 ,stealChance 

6608 ,stealDone 

6609 ,success_Steal 

6610 ,street1Seen 

6611 ,street2Seen 

6612 ,street3Seen 

6613 ,street4Seen 

6614 ,sawShowdown 

6615 ,street1Aggr 

6616 ,street2Aggr 

6617 ,street3Aggr 

6618 ,street4Aggr 

6619 ,otherRaisedStreet0 

6620 ,otherRaisedStreet1 

6621 ,otherRaisedStreet2 

6622 ,otherRaisedStreet3 

6623 ,otherRaisedStreet4 

6624 ,foldToOtherRaisedStreet0 

6625 ,foldToOtherRaisedStreet1 

6626 ,foldToOtherRaisedStreet2 

6627 ,foldToOtherRaisedStreet3 

6628 ,foldToOtherRaisedStreet4  

6629 ,wonWhenSeenStreet1 

6630 ,wonWhenSeenStreet2 

6631 ,wonWhenSeenStreet3 

6632 ,wonWhenSeenStreet4 

6633 ,wonAtSD 

6634 ,raiseFirstInChance 

6635 ,raisedFirstIn 

6636 ,foldBbToStealChance 

6637 ,foldedBbToSteal 

6638 ,foldSbToStealChance 

6639 ,foldedSbToSteal 

6640 ,street1CBChance 

6641 ,street1CBDone 

6642 ,street2CBChance 

6643 ,street2CBDone 

6644 ,street3CBChance 

6645 ,street3CBDone 

6646 ,street4CBChance 

6647 ,street4CBDone 

6648 ,foldToStreet1CBChance 

6649 ,foldToStreet1CBDone 

6650 ,foldToStreet2CBChance 

6651 ,foldToStreet2CBDone 

6652 ,foldToStreet3CBChance 

6653 ,foldToStreet3CBDone 

6654 ,foldToStreet4CBChance 

6655 ,foldToStreet4CBDone 

6656 ,common 

6657 ,committed 

6658 ,winnings 

6659 ,rake 

6660 ,rakeDealt 

6661 ,rakeContributed 

6662 ,rakeWeighted 

6663 ,totalProfit 

6664 ,allInEV 

6665 ,showdownWinnings 

6666 ,nonShowdownWinnings 

6667 ,street1CheckCallRaiseChance 

6668 ,street1CheckCallDone 

6669 ,street1CheckRaiseDone 

6670 ,street2CheckCallRaiseChance 

6671 ,street2CheckCallDone 

6672 ,street2CheckRaiseDone 

6673 ,street3CheckCallRaiseChance 

6674 ,street3CheckCallDone 

6675 ,street3CheckRaiseDone 

6676 ,street4CheckCallRaiseChance 

6677 ,street4CheckCallDone 

6678 ,street4CheckRaiseDone 

6679 ,street0Calls 

6680 ,street1Calls 

6681 ,street2Calls 

6682 ,street3Calls 

6683 ,street4Calls 

6684 ,street0Bets 

6685 ,street1Bets 

6686 ,street2Bets 

6687 ,street3Bets 

6688 ,street4Bets 

6689 ,street0Raises 

6690 ,street1Raises 

6691 ,street2Raises 

6692 ,street3Raises 

6693 ,street4Raises 

6694 ,street1Discards 

6695 ,street2Discards 

6696 ,street3Discards 

6697 ) 

6698 SELECT <select> 

6699 ,count(1) 

6700 ,sum(CAST(street0VPIChance as integer)) 

6701 ,sum(CAST(street0VPI as integer)) 

6702 ,sum(CAST(street0AggrChance as integer)) 

6703 ,sum(CAST(street0Aggr as integer)) 

6704 ,sum(CAST(street0CalledRaiseChance as integer)) 

6705 ,sum(CAST(street0CalledRaiseDone as integer)) 

6706 ,sum(CAST(street0_2BChance as integer)) 

6707 ,sum(CAST(street0_2BDone as integer)) 

6708 ,sum(CAST(street0_3BChance as integer)) 

6709 ,sum(CAST(street0_3BDone as integer)) 

6710 ,sum(CAST(street0_4BChance as integer)) 

6711 ,sum(CAST(street0_4BDone as integer)) 

6712 ,sum(CAST(street0_C4BChance as integer)) 

6713 ,sum(CAST(street0_C4BDone as integer)) 

6714 ,sum(CAST(street0_FoldTo2BChance as integer)) 

6715 ,sum(CAST(street0_FoldTo2BDone as integer)) 

6716 ,sum(CAST(street0_FoldTo3BChance as integer)) 

6717 ,sum(CAST(street0_FoldTo3BDone as integer)) 

6718 ,sum(CAST(street0_FoldTo4BChance as integer)) 

6719 ,sum(CAST(street0_FoldTo4BDone as integer)) 

6720 ,sum(CAST(street0_SqueezeChance as integer)) 

6721 ,sum(CAST(street0_SqueezeDone as integer)) 

6722 ,sum(CAST(raiseToStealChance as integer)) 

6723 ,sum(CAST(raiseToStealDone as integer)) 

6724 ,sum(CAST(stealChance as integer)) 

6725 ,sum(CAST(stealDone as integer)) 

6726 ,sum(CAST(success_Steal as integer)) 

6727 ,sum(CAST(street1Seen as integer)) 

6728 ,sum(CAST(street2Seen as integer)) 

6729 ,sum(CAST(street3Seen as integer)) 

6730 ,sum(CAST(street4Seen as integer)) 

6731 ,sum(CAST(sawShowdown as integer)) 

6732 ,sum(CAST(street1Aggr as integer)) 

6733 ,sum(CAST(street2Aggr as integer)) 

6734 ,sum(CAST(street3Aggr as integer)) 

6735 ,sum(CAST(street4Aggr as integer)) 

6736 ,sum(CAST(otherRaisedStreet0 as integer)) 

6737 ,sum(CAST(otherRaisedStreet1 as integer)) 

6738 ,sum(CAST(otherRaisedStreet2 as integer)) 

6739 ,sum(CAST(otherRaisedStreet3 as integer)) 

6740 ,sum(CAST(otherRaisedStreet4 as integer)) 

6741 ,sum(CAST(foldToOtherRaisedStreet0 as integer)) 

6742 ,sum(CAST(foldToOtherRaisedStreet1 as integer)) 

6743 ,sum(CAST(foldToOtherRaisedStreet2 as integer)) 

6744 ,sum(CAST(foldToOtherRaisedStreet3 as integer)) 

6745 ,sum(CAST(foldToOtherRaisedStreet4 as integer))  

6746 ,sum(CAST(wonWhenSeenStreet1 as integer)) 

6747 ,sum(CAST(wonWhenSeenStreet2 as integer)) 

6748 ,sum(CAST(wonWhenSeenStreet3 as integer)) 

6749 ,sum(CAST(wonWhenSeenStreet4 as integer)) 

6750 ,sum(CAST(wonAtSD as integer)) 

6751 ,sum(CAST(raiseFirstInChance as integer)) 

6752 ,sum(CAST(raisedFirstIn as integer)) 

6753 ,sum(CAST(foldBbToStealChance as integer)) 

6754 ,sum(CAST(foldedBbToSteal as integer)) 

6755 ,sum(CAST(foldSbToStealChance as integer)) 

6756 ,sum(CAST(foldedSbToSteal as integer)) 

6757 ,sum(CAST(street1CBChance as integer)) 

6758 ,sum(CAST(street1CBDone as integer)) 

6759 ,sum(CAST(street2CBChance as integer)) 

6760 ,sum(CAST(street2CBDone as integer)) 

6761 ,sum(CAST(street3CBChance as integer)) 

6762 ,sum(CAST(street3CBDone as integer)) 

6763 ,sum(CAST(street4CBChance as integer)) 

6764 ,sum(CAST(street4CBDone as integer)) 

6765 ,sum(CAST(foldToStreet1CBChance as integer)) 

6766 ,sum(CAST(foldToStreet1CBDone as integer)) 

6767 ,sum(CAST(foldToStreet2CBChance as integer)) 

6768 ,sum(CAST(foldToStreet2CBDone as integer)) 

6769 ,sum(CAST(foldToStreet3CBChance as integer)) 

6770 ,sum(CAST(foldToStreet3CBDone as integer)) 

6771 ,sum(CAST(foldToStreet4CBChance as integer)) 

6772 ,sum(CAST(foldToStreet4CBDone as integer)) 

6773 ,sum(common) 

6774 ,sum(committed) 

6775 ,sum(winnings) 

6776 ,sum(rake) 

6777 ,sum(rakeDealt) 

6778 ,sum(rakeContributed) 

6779 ,sum(rakeWeighted) 

6780 ,sum(totalProfit) 

6781 ,sum(allInEV) 

6782 ,sum(case when sawShowdown then totalProfit else 0 end) 

6783 ,sum(case when sawShowdown then 0 else totalProfit end) 

6784 ,sum(CAST(street1CheckCallRaiseChance as integer)) 

6785 ,sum(CAST(street1CheckCallDone as integer)) 

6786 ,sum(CAST(street1CheckRaiseDone as integer)) 

6787 ,sum(CAST(street2CheckCallRaiseChance as integer)) 

6788 ,sum(CAST(street2CheckCallDone as integer)) 

6789 ,sum(CAST(street2CheckRaiseDone as integer)) 

6790 ,sum(CAST(street3CheckCallRaiseChance as integer)) 

6791 ,sum(CAST(street3CheckCallDone as integer)) 

6792 ,sum(CAST(street3CheckRaiseDone as integer)) 

6793 ,sum(CAST(street4CheckCallRaiseChance as integer)) 

6794 ,sum(CAST(street4CheckCallDone as integer)) 

6795 ,sum(CAST(street4CheckRaiseDone as integer)) 

6796 ,sum(CAST(street0Calls as integer)) 

6797 ,sum(CAST(street1Calls as integer)) 

6798 ,sum(CAST(street2Calls as integer)) 

6799 ,sum(CAST(street3Calls as integer)) 

6800 ,sum(CAST(street4Calls as integer)) 

6801 ,sum(CAST(street0Bets as integer)) 

6802 ,sum(CAST(street1Bets as integer)) 

6803 ,sum(CAST(street2Bets as integer)) 

6804 ,sum(CAST(street3Bets as integer)) 

6805 ,sum(CAST(street4Bets as integer)) 

6806 ,sum(CAST(hp.street0Raises as integer)) 

6807 ,sum(CAST(hp.street1Raises as integer)) 

6808 ,sum(CAST(hp.street2Raises as integer)) 

6809 ,sum(CAST(hp.street3Raises as integer)) 

6810 ,sum(CAST(hp.street4Raises as integer)) 

6811 ,sum(CAST(street1Discards as integer)) 

6812 ,sum(CAST(street2Discards as integer)) 

6813 ,sum(CAST(street3Discards as integer)) 

6814 FROM Hands h 

6815 INNER JOIN HandsPlayers hp ON (h.id = hp.handId<hero_join>) 

6816 INNER JOIN Gametypes g ON (h.gametypeId = g.id) 

6817 <sessions_join_clause> 

6818 <tourney_join_clause> 

6819 <where_clause> 

6820 GROUP BY <group> 

6821""" 

6822 elif db_server == 'sqlite': 

6823 self.query['rebuildCache'] = """insert into <insert> 

6824 ,n 

6825 ,street0VPIChance 

6826 ,street0VPI 

6827 ,street0AggrChance 

6828 ,street0Aggr 

6829 ,street0CalledRaiseChance 

6830 ,street0CalledRaiseDone 

6831 ,street0_2BChance 

6832 ,street0_2BDone 

6833 ,street0_3BChance 

6834 ,street0_3BDone 

6835 ,street0_4BChance 

6836 ,street0_4BDone 

6837 ,street0_C4BChance 

6838 ,street0_C4BDone 

6839 ,street0_FoldTo2BChance 

6840 ,street0_FoldTo2BDone 

6841 ,street0_FoldTo3BChance 

6842 ,street0_FoldTo3BDone 

6843 ,street0_FoldTo4BChance 

6844 ,street0_FoldTo4BDone 

6845 ,street0_SqueezeChance 

6846 ,street0_SqueezeDone 

6847 ,raiseToStealChance 

6848 ,raiseToStealDone 

6849 ,stealChance 

6850 ,stealDone 

6851 ,success_Steal 

6852 ,street1Seen 

6853 ,street2Seen 

6854 ,street3Seen 

6855 ,street4Seen 

6856 ,sawShowdown 

6857 ,street1Aggr 

6858 ,street2Aggr 

6859 ,street3Aggr 

6860 ,street4Aggr 

6861 ,otherRaisedStreet0 

6862 ,otherRaisedStreet1 

6863 ,otherRaisedStreet2 

6864 ,otherRaisedStreet3 

6865 ,otherRaisedStreet4 

6866 ,foldToOtherRaisedStreet0 

6867 ,foldToOtherRaisedStreet1 

6868 ,foldToOtherRaisedStreet2 

6869 ,foldToOtherRaisedStreet3 

6870 ,foldToOtherRaisedStreet4 

6871 ,wonWhenSeenStreet1 

6872 ,wonWhenSeenStreet2 

6873 ,wonWhenSeenStreet3 

6874 ,wonWhenSeenStreet4 

6875 ,wonAtSD 

6876 ,raiseFirstInChance 

6877 ,raisedFirstIn 

6878 ,foldBbToStealChance 

6879 ,foldedBbToSteal 

6880 ,foldSbToStealChance 

6881 ,foldedSbToSteal 

6882 ,street1CBChance 

6883 ,street1CBDone 

6884 ,street2CBChance 

6885 ,street2CBDone 

6886 ,street3CBChance 

6887 ,street3CBDone 

6888 ,street4CBChance 

6889 ,street4CBDone 

6890 ,foldToStreet1CBChance 

6891 ,foldToStreet1CBDone 

6892 ,foldToStreet2CBChance 

6893 ,foldToStreet2CBDone 

6894 ,foldToStreet3CBChance 

6895 ,foldToStreet3CBDone 

6896 ,foldToStreet4CBChance 

6897 ,foldToStreet4CBDone 

6898 ,common 

6899 ,committed 

6900 ,winnings 

6901 ,rake 

6902 ,rakeDealt 

6903 ,rakeContributed 

6904 ,rakeWeighted 

6905 ,totalProfit 

6906 ,allInEV 

6907 ,showdownWinnings 

6908 ,nonShowdownWinnings 

6909 ,street1CheckCallRaiseChance 

6910 ,street1CheckCallDone 

6911 ,street1CheckRaiseDone 

6912 ,street2CheckCallRaiseChance 

6913 ,street2CheckCallDone 

6914 ,street2CheckRaiseDone 

6915 ,street3CheckCallRaiseChance 

6916 ,street3CheckCallDone 

6917 ,street3CheckRaiseDone 

6918 ,street4CheckCallRaiseChance 

6919 ,street4CheckCallDone 

6920 ,street4CheckRaiseDone 

6921 ,street0Calls 

6922 ,street1Calls 

6923 ,street2Calls 

6924 ,street3Calls 

6925 ,street4Calls 

6926 ,street0Bets 

6927 ,street1Bets 

6928 ,street2Bets 

6929 ,street3Bets 

6930 ,street4Bets 

6931 ,street0Raises 

6932 ,street1Raises 

6933 ,street2Raises 

6934 ,street3Raises 

6935 ,street4Raises 

6936 ,street1Discards 

6937 ,street2Discards 

6938 ,street3Discards 

6939 ) 

6940 SELECT <select> 

6941 ,count(1) 

6942 ,sum(CAST(street0VPIChance as integer)) 

6943 ,sum(CAST(street0VPI as integer)) 

6944 ,sum(CAST(street0AggrChance as integer)) 

6945 ,sum(CAST(street0Aggr as integer)) 

6946 ,sum(CAST(street0CalledRaiseChance as integer)) 

6947 ,sum(CAST(street0CalledRaiseDone as integer)) 

6948 ,sum(CAST(street0_2BChance as integer)) 

6949 ,sum(CAST(street0_2BDone as integer)) 

6950 ,sum(CAST(street0_3BChance as integer)) 

6951 ,sum(CAST(street0_3BDone as integer)) 

6952 ,sum(CAST(street0_4BChance as integer)) 

6953 ,sum(CAST(street0_4BDone as integer)) 

6954 ,sum(CAST(street0_C4BChance as integer)) 

6955 ,sum(CAST(street0_C4BDone as integer)) 

6956 ,sum(CAST(street0_FoldTo2BChance as integer)) 

6957 ,sum(CAST(street0_FoldTo2BDone as integer)) 

6958 ,sum(CAST(street0_FoldTo3BChance as integer)) 

6959 ,sum(CAST(street0_FoldTo3BDone as integer)) 

6960 ,sum(CAST(street0_FoldTo4BChance as integer)) 

6961 ,sum(CAST(street0_FoldTo4BDone as integer)) 

6962 ,sum(CAST(street0_SqueezeChance as integer)) 

6963 ,sum(CAST(street0_SqueezeDone as integer)) 

6964 ,sum(CAST(raiseToStealChance as integer)) 

6965 ,sum(CAST(raiseToStealDone as integer)) 

6966 ,sum(CAST(stealChance as integer)) 

6967 ,sum(CAST(stealDone as integer)) 

6968 ,sum(CAST(success_Steal as integer)) 

6969 ,sum(CAST(street1Seen as integer)) 

6970 ,sum(CAST(street2Seen as integer)) 

6971 ,sum(CAST(street3Seen as integer)) 

6972 ,sum(CAST(street4Seen as integer)) 

6973 ,sum(CAST(sawShowdown as integer)) 

6974 ,sum(CAST(street1Aggr as integer)) 

6975 ,sum(CAST(street2Aggr as integer)) 

6976 ,sum(CAST(street3Aggr as integer)) 

6977 ,sum(CAST(street4Aggr as integer)) 

6978 ,sum(CAST(otherRaisedStreet0 as integer)) 

6979 ,sum(CAST(otherRaisedStreet1 as integer)) 

6980 ,sum(CAST(otherRaisedStreet2 as integer)) 

6981 ,sum(CAST(otherRaisedStreet3 as integer)) 

6982 ,sum(CAST(otherRaisedStreet4 as integer)) 

6983 ,sum(CAST(foldToOtherRaisedStreet0 as integer)) 

6984 ,sum(CAST(foldToOtherRaisedStreet1 as integer)) 

6985 ,sum(CAST(foldToOtherRaisedStreet2 as integer)) 

6986 ,sum(CAST(foldToOtherRaisedStreet3 as integer)) 

6987 ,sum(CAST(foldToOtherRaisedStreet4 as integer)) 

6988 ,sum(CAST(wonWhenSeenStreet1 as integer)) 

6989 ,sum(CAST(wonWhenSeenStreet2 as integer)) 

6990 ,sum(CAST(wonWhenSeenStreet3 as integer)) 

6991 ,sum(CAST(wonWhenSeenStreet4 as integer)) 

6992 ,sum(CAST(wonAtSD as integer)) 

6993 ,sum(CAST(raiseFirstInChance as integer)) 

6994 ,sum(CAST(raisedFirstIn as integer)) 

6995 ,sum(CAST(foldBbToStealChance as integer)) 

6996 ,sum(CAST(foldedBbToSteal as integer)) 

6997 ,sum(CAST(foldSbToStealChance as integer)) 

6998 ,sum(CAST(foldedSbToSteal as integer)) 

6999 ,sum(CAST(street1CBChance as integer)) 

7000 ,sum(CAST(street1CBDone as integer)) 

7001 ,sum(CAST(street2CBChance as integer)) 

7002 ,sum(CAST(street2CBDone as integer)) 

7003 ,sum(CAST(street3CBChance as integer)) 

7004 ,sum(CAST(street3CBDone as integer)) 

7005 ,sum(CAST(street4CBChance as integer)) 

7006 ,sum(CAST(street4CBDone as integer)) 

7007 ,sum(CAST(foldToStreet1CBChance as integer)) 

7008 ,sum(CAST(foldToStreet1CBDone as integer)) 

7009 ,sum(CAST(foldToStreet2CBChance as integer)) 

7010 ,sum(CAST(foldToStreet2CBDone as integer)) 

7011 ,sum(CAST(foldToStreet3CBChance as integer)) 

7012 ,sum(CAST(foldToStreet3CBDone as integer)) 

7013 ,sum(CAST(foldToStreet4CBChance as integer)) 

7014 ,sum(CAST(foldToStreet4CBDone as integer)) 

7015 ,sum(CAST(common as integer)) 

7016 ,sum(CAST(committed as integer)) 

7017 ,sum(CAST(winnings as integer)) 

7018 ,sum(CAST(rake as integer)) 

7019 ,sum(CAST(rakeDealt as integer)) 

7020 ,sum(CAST(rakeContributed as integer)) 

7021 ,sum(CAST(rakeWeighted as integer)) 

7022 ,sum(CAST(totalProfit as integer)) 

7023 ,sum(allInEV) 

7024 ,sum(CAST(case when sawShowdown = 1 then totalProfit else 0 end as integer)) 

7025 ,sum(CAST(case when sawShowdown = 0 then totalProfit else 0 end as integer)) 

7026 ,sum(CAST(street1CheckCallRaiseChance as integer)) 

7027 ,sum(CAST(street1CheckCallDone as integer)) 

7028 ,sum(CAST(street1CheckRaiseDone as integer)) 

7029 ,sum(CAST(street2CheckCallRaiseChance as integer)) 

7030 ,sum(CAST(street2CheckCallDone as integer)) 

7031 ,sum(CAST(street2CheckRaiseDone as integer)) 

7032 ,sum(CAST(street3CheckCallRaiseChance as integer)) 

7033 ,sum(CAST(street3CheckCallDone as integer)) 

7034 ,sum(CAST(street3CheckRaiseDone as integer)) 

7035 ,sum(CAST(street4CheckCallRaiseChance as integer)) 

7036 ,sum(CAST(street4CheckCallDone as integer)) 

7037 ,sum(CAST(street4CheckRaiseDone as integer)) 

7038 ,sum(CAST(street0Calls as integer)) 

7039 ,sum(CAST(street1Calls as integer)) 

7040 ,sum(CAST(street2Calls as integer)) 

7041 ,sum(CAST(street3Calls as integer)) 

7042 ,sum(CAST(street4Calls as integer)) 

7043 ,sum(CAST(street0Bets as integer)) 

7044 ,sum(CAST(street1Bets as integer)) 

7045 ,sum(CAST(street2Bets as integer)) 

7046 ,sum(CAST(street3Bets as integer)) 

7047 ,sum(CAST(street4Bets as integer)) 

7048 ,sum(CAST(hp.street0Raises as integer)) 

7049 ,sum(CAST(hp.street1Raises as integer)) 

7050 ,sum(CAST(hp.street2Raises as integer)) 

7051 ,sum(CAST(hp.street3Raises as integer)) 

7052 ,sum(CAST(hp.street4Raises as integer)) 

7053 ,sum(CAST(street1Discards as integer)) 

7054 ,sum(CAST(street2Discards as integer)) 

7055 ,sum(CAST(street3Discards as integer)) 

7056 FROM Hands h 

7057 INNER JOIN HandsPlayers hp ON (h.id = hp.handId<hero_join>) 

7058 INNER JOIN Gametypes g ON (h.gametypeId = g.id) 

7059 <sessions_join_clause> 

7060 <tourney_join_clause> 

7061 <where_clause> 

7062 GROUP BY <group> 

7063""" 

7064 

7065 

7066 self.query['insert_hudcache'] = """insert into HudCache ( 

7067 gametypeId, 

7068 playerId, 

7069 seats, 

7070 position, 

7071 tourneyTypeId, 

7072 styleKey, 

7073 n, 

7074 street0VPIChance, 

7075 street0VPI, 

7076 street0AggrChance, 

7077 street0Aggr, 

7078 street0CalledRaiseChance, 

7079 street0CalledRaiseDone, 

7080 street0_2BChance, 

7081 street0_2BDone, 

7082 street0_3BChance, 

7083 street0_3BDone, 

7084 street0_4BChance, 

7085 street0_4BDone, 

7086 street0_C4BChance, 

7087 street0_C4BDone, 

7088 street0_FoldTo2BChance, 

7089 street0_FoldTo2BDone, 

7090 street0_FoldTo3BChance, 

7091 street0_FoldTo3BDone, 

7092 street0_FoldTo4BChance, 

7093 street0_FoldTo4BDone, 

7094 street0_SqueezeChance, 

7095 street0_SqueezeDone, 

7096 raiseToStealChance, 

7097 raiseToStealDone, 

7098 stealChance, 

7099 stealDone, 

7100 success_Steal, 

7101 street1Seen, 

7102 street2Seen, 

7103 street3Seen, 

7104 street4Seen, 

7105 sawShowdown, 

7106 street1Aggr, 

7107 street2Aggr, 

7108 street3Aggr, 

7109 street4Aggr, 

7110 otherRaisedStreet0, 

7111 otherRaisedStreet1, 

7112 otherRaisedStreet2, 

7113 otherRaisedStreet3, 

7114 otherRaisedStreet4, 

7115 foldToOtherRaisedStreet0, 

7116 foldToOtherRaisedStreet1, 

7117 foldToOtherRaisedStreet2, 

7118 foldToOtherRaisedStreet3, 

7119 foldToOtherRaisedStreet4, 

7120 wonWhenSeenStreet1, 

7121 wonWhenSeenStreet2, 

7122 wonWhenSeenStreet3, 

7123 wonWhenSeenStreet4, 

7124 wonAtSD, 

7125 raiseFirstInChance, 

7126 raisedFirstIn, 

7127 foldBbToStealChance, 

7128 foldedBbToSteal, 

7129 foldSbToStealChance, 

7130 foldedSbToSteal, 

7131 street1CBChance, 

7132 street1CBDone, 

7133 street2CBChance, 

7134 street2CBDone, 

7135 street3CBChance, 

7136 street3CBDone, 

7137 street4CBChance, 

7138 street4CBDone, 

7139 foldToStreet1CBChance, 

7140 foldToStreet1CBDone, 

7141 foldToStreet2CBChance, 

7142 foldToStreet2CBDone, 

7143 foldToStreet3CBChance, 

7144 foldToStreet3CBDone, 

7145 foldToStreet4CBChance, 

7146 foldToStreet4CBDone, 

7147 common, 

7148 committed, 

7149 winnings, 

7150 rake, 

7151 rakeDealt, 

7152 rakeContributed, 

7153 rakeWeighted, 

7154 totalProfit, 

7155 allInEV, 

7156 showdownWinnings, 

7157 nonShowdownWinnings, 

7158 street1CheckCallRaiseChance, 

7159 street1CheckCallDone, 

7160 street1CheckRaiseDone, 

7161 street2CheckCallRaiseChance, 

7162 street2CheckCallDone, 

7163 street2CheckRaiseDone, 

7164 street3CheckCallRaiseChance, 

7165 street3CheckCallDone, 

7166 street3CheckRaiseDone, 

7167 street4CheckCallRaiseChance, 

7168 street4CheckCallDone, 

7169 street4CheckRaiseDone, 

7170 street0Calls, 

7171 street1Calls, 

7172 street2Calls, 

7173 street3Calls, 

7174 street4Calls, 

7175 street0Bets, 

7176 street1Bets, 

7177 street2Bets, 

7178 street3Bets, 

7179 street4Bets, 

7180 street0Raises, 

7181 street1Raises, 

7182 street2Raises, 

7183 street3Raises, 

7184 street4Raises, 

7185 street1Discards, 

7186 street2Discards, 

7187 street3Discards) 

7188 values (%s, %s, %s, %s, %s, 

7189 %s, %s, %s, %s, %s, 

7190 %s, %s, %s, %s, %s, 

7191 %s, %s, %s, %s, %s, 

7192 %s, %s, %s, %s, %s, 

7193 %s, %s, %s, %s, %s, 

7194 %s, %s, %s, %s, %s, 

7195 %s, %s, %s, %s, %s, 

7196 %s, %s, %s, %s, %s, 

7197 %s, %s, %s, %s, %s, 

7198 %s, %s, %s, %s, %s, 

7199 %s, %s, %s, %s, %s, 

7200 %s, %s, %s, %s, %s, 

7201 %s, %s, %s, %s, %s, 

7202 %s, %s, %s, %s, %s, 

7203 %s, %s, %s, %s, %s, 

7204 %s, %s, %s, %s, %s, 

7205 %s, %s, %s, %s, %s, 

7206 %s, %s, %s, %s, %s, 

7207 %s, %s, %s, %s, %s, 

7208 %s, %s, %s, %s, %s, 

7209 %s, %s, %s, %s, %s, 

7210 %s, %s, %s, %s, %s, 

7211 %s, %s, %s, %s, %s, 

7212 %s)""" 

7213 

7214 self.query['update_hudcache'] = """ 

7215 UPDATE HudCache SET 

7216 n=n+%s, 

7217 street0VPIChance=street0VPIChance+%s, 

7218 street0VPI=street0VPI+%s, 

7219 street0AggrChance=street0AggrChance+%s, 

7220 street0Aggr=street0Aggr+%s, 

7221 street0CalledRaiseChance=street0CalledRaiseChance+%s, 

7222 street0CalledRaiseDone=street0CalledRaiseDone+%s, 

7223 street0_2BChance=street0_2BChance+%s, 

7224 street0_2BDone=street0_2BDone+%s, 

7225 street0_3BChance=street0_3BChance+%s, 

7226 street0_3BDone=street0_3BDone+%s, 

7227 street0_4BChance=street0_4BChance+%s, 

7228 street0_4BDone=street0_4BDone+%s, 

7229 street0_C4BChance=street0_C4BChance+%s, 

7230 street0_C4BDone=street0_C4BDone+%s, 

7231 street0_FoldTo2BChance=street0_FoldTo2BChance+%s, 

7232 street0_FoldTo2BDone=street0_FoldTo2BDone+%s, 

7233 street0_FoldTo3BChance=street0_FoldTo3BChance+%s, 

7234 street0_FoldTo3BDone=street0_FoldTo3BDone+%s, 

7235 street0_FoldTo4BChance=street0_FoldTo4BChance+%s, 

7236 street0_FoldTo4BDone=street0_FoldTo4BDone+%s, 

7237 street0_SqueezeChance=street0_SqueezeChance+%s, 

7238 street0_SqueezeDone=street0_SqueezeDone+%s, 

7239 raiseToStealChance=raiseToStealChance+%s, 

7240 raiseToStealDone=raiseToStealDone+%s, 

7241 stealChance=stealChance+%s, 

7242 stealDone=stealDone+%s, 

7243 success_Steal=success_Steal+%s, 

7244 street1Seen=street1Seen+%s, 

7245 street2Seen=street2Seen+%s, 

7246 street3Seen=street3Seen+%s, 

7247 street4Seen=street4Seen+%s, 

7248 sawShowdown=sawShowdown+%s, 

7249 street1Aggr=street1Aggr+%s, 

7250 street2Aggr=street2Aggr+%s, 

7251 street3Aggr=street3Aggr+%s, 

7252 street4Aggr=street4Aggr+%s, 

7253 otherRaisedStreet0=otherRaisedStreet0+%s, 

7254 otherRaisedStreet1=otherRaisedStreet1+%s, 

7255 otherRaisedStreet2=otherRaisedStreet2+%s, 

7256 otherRaisedStreet3=otherRaisedStreet3+%s, 

7257 otherRaisedStreet4=otherRaisedStreet4+%s, 

7258 foldToOtherRaisedStreet0=foldToOtherRaisedStreet0+%s, 

7259 foldToOtherRaisedStreet1=foldToOtherRaisedStreet1+%s, 

7260 foldToOtherRaisedStreet2=foldToOtherRaisedStreet2+%s, 

7261 foldToOtherRaisedStreet3=foldToOtherRaisedStreet3+%s, 

7262 foldToOtherRaisedStreet4=foldToOtherRaisedStreet4+%s, 

7263 wonWhenSeenStreet1=wonWhenSeenStreet1+%s, 

7264 wonWhenSeenStreet2=wonWhenSeenStreet2+%s, 

7265 wonWhenSeenStreet3=wonWhenSeenStreet3+%s, 

7266 wonWhenSeenStreet4=wonWhenSeenStreet4+%s, 

7267 wonAtSD=wonAtSD+%s, 

7268 raiseFirstInChance=raiseFirstInChance+%s, 

7269 raisedFirstIn=raisedFirstIn+%s, 

7270 foldBbToStealChance=foldBbToStealChance+%s, 

7271 foldedBbToSteal=foldedBbToSteal+%s, 

7272 foldSbToStealChance=foldSbToStealChance+%s, 

7273 foldedSbToSteal=foldedSbToSteal+%s, 

7274 street1CBChance=street1CBChance+%s, 

7275 street1CBDone=street1CBDone+%s, 

7276 street2CBChance=street2CBChance+%s, 

7277 street2CBDone=street2CBDone+%s, 

7278 street3CBChance=street3CBChance+%s, 

7279 street3CBDone=street3CBDone+%s, 

7280 street4CBChance=street4CBChance+%s, 

7281 street4CBDone=street4CBDone+%s, 

7282 foldToStreet1CBChance=foldToStreet1CBChance+%s, 

7283 foldToStreet1CBDone=foldToStreet1CBDone+%s, 

7284 foldToStreet2CBChance=foldToStreet2CBChance+%s, 

7285 foldToStreet2CBDone=foldToStreet2CBDone+%s, 

7286 foldToStreet3CBChance=foldToStreet3CBChance+%s, 

7287 foldToStreet3CBDone=foldToStreet3CBDone+%s, 

7288 foldToStreet4CBChance=foldToStreet4CBChance+%s, 

7289 foldToStreet4CBDone=foldToStreet4CBDone+%s, 

7290 common=common+%s, 

7291 committed=committed+%s, 

7292 winnings=winnings+%s, 

7293 rake=rake+%s, 

7294 rakeDealt=rakeDealt+%s, 

7295 rakeContributed=rakeContributed+%s, 

7296 rakeWeighted=rakeWeighted+%s, 

7297 totalProfit=totalProfit+%s, 

7298 allInEV=allInEV+%s, 

7299 showdownWinnings=showdownWinnings+%s, 

7300 nonShowdownWinnings=nonShowdownWinnings+%s, 

7301 street1CheckCallRaiseChance=street1CheckCallRaiseChance+%s, 

7302 street1CheckCallDone=street1CheckCallDone+%s, 

7303 street1CheckRaiseDone=street1CheckRaiseDone+%s, 

7304 street2CheckCallRaiseChance=street2CheckCallRaiseChance+%s, 

7305 street2CheckCallDone=street2CheckCallDone+%s, 

7306 street2CheckRaiseDone=street2CheckRaiseDone+%s, 

7307 street3CheckCallRaiseChance=street3CheckCallRaiseChance+%s, 

7308 street3CheckCallDone=street3CheckCallDone+%s, 

7309 street3CheckRaiseDone=street3CheckRaiseDone+%s, 

7310 street4CheckCallRaiseChance=street4CheckCallRaiseChance+%s, 

7311 street4CheckCallDone=street4CheckCallDone+%s, 

7312 street4CheckRaiseDone=street4CheckRaiseDone+%s, 

7313 street0Calls=street0Calls+%s, 

7314 street1Calls=street1Calls+%s, 

7315 street2Calls=street2Calls+%s, 

7316 street3Calls=street3Calls+%s, 

7317 street4Calls=street4Calls+%s, 

7318 street0Bets=street0Bets+%s,  

7319 street1Bets=street1Bets+%s, 

7320 street2Bets=street2Bets+%s,  

7321 street3Bets=street3Bets+%s, 

7322 street4Bets=street4Bets+%s,  

7323 street0Raises=street0Raises+%s, 

7324 street1Raises=street1Raises+%s, 

7325 street2Raises=street2Raises+%s, 

7326 street3Raises=street3Raises+%s, 

7327 street4Raises=street4Raises+%s,  

7328 street1Discards=street1Discards+%s, 

7329 street2Discards=street2Discards+%s, 

7330 street3Discards=street3Discards+%s 

7331 WHERE id=%s""" 

7332 

7333 self.query['select_hudcache_ring'] = """ 

7334 SELECT id 

7335 FROM HudCache 

7336 WHERE gametypeId=%s 

7337 AND playerId=%s 

7338 AND seats=%s 

7339 AND position=%s 

7340 AND tourneyTypeId is NULL 

7341 AND styleKey = %s""" 

7342 

7343 self.query['select_hudcache_tour'] = """ 

7344 SELECT id 

7345 FROM HudCache 

7346 WHERE gametypeId=%s 

7347 AND playerId=%s 

7348 AND seats=%s 

7349 AND position=%s 

7350 AND tourneyTypeId=%s 

7351 AND styleKey = %s""" 

7352 

7353 self.query['get_hero_hudcache_start'] = """select min(hc.styleKey) 

7354 from HudCache hc 

7355 where hc.playerId in <playerid_list> 

7356 and hc.styleKey like 'd%'""" 

7357 

7358 #################################### 

7359 # Queries to insert/update cardscache 

7360 #################################### 

7361 

7362 self.query['insert_cardscache'] = """insert into CardsCache ( 

7363 weekId, 

7364 monthId, 

7365 gametypeId, 

7366 tourneyTypeId, 

7367 playerId, 

7368 startCards, 

7369 n, 

7370 street0VPIChance, 

7371 street0VPI, 

7372 street0AggrChance, 

7373 street0Aggr, 

7374 street0CalledRaiseChance, 

7375 street0CalledRaiseDone, 

7376 street0_3BChance, 

7377 street0_3BDone, 

7378 street0_2BChance, 

7379 street0_2BDone, 

7380 street0_4BChance, 

7381 street0_4BDone, 

7382 street0_C4BChance, 

7383 street0_C4BDone, 

7384 street0_FoldTo2BChance, 

7385 street0_FoldTo2BDone, 

7386 street0_FoldTo3BChance, 

7387 street0_FoldTo3BDone, 

7388 street0_FoldTo4BChance, 

7389 street0_FoldTo4BDone, 

7390 street0_SqueezeChance, 

7391 street0_SqueezeDone, 

7392 raiseToStealChance, 

7393 raiseToStealDone, 

7394 stealChance, 

7395 stealDone, 

7396 success_Steal, 

7397 street1Seen, 

7398 street2Seen, 

7399 street3Seen, 

7400 street4Seen, 

7401 sawShowdown, 

7402 street1Aggr, 

7403 street2Aggr, 

7404 street3Aggr, 

7405 street4Aggr, 

7406 otherRaisedStreet0, 

7407 otherRaisedStreet1, 

7408 otherRaisedStreet2, 

7409 otherRaisedStreet3, 

7410 otherRaisedStreet4, 

7411 foldToOtherRaisedStreet0, 

7412 foldToOtherRaisedStreet1, 

7413 foldToOtherRaisedStreet2, 

7414 foldToOtherRaisedStreet3, 

7415 foldToOtherRaisedStreet4, 

7416 wonWhenSeenStreet1, 

7417 wonWhenSeenStreet2, 

7418 wonWhenSeenStreet3, 

7419 wonWhenSeenStreet4, 

7420 wonAtSD, 

7421 raiseFirstInChance, 

7422 raisedFirstIn, 

7423 foldBbToStealChance, 

7424 foldedBbToSteal, 

7425 foldSbToStealChance, 

7426 foldedSbToSteal, 

7427 street1CBChance, 

7428 street1CBDone, 

7429 street2CBChance, 

7430 street2CBDone, 

7431 street3CBChance, 

7432 street3CBDone, 

7433 street4CBChance, 

7434 street4CBDone, 

7435 foldToStreet1CBChance, 

7436 foldToStreet1CBDone, 

7437 foldToStreet2CBChance, 

7438 foldToStreet2CBDone, 

7439 foldToStreet3CBChance, 

7440 foldToStreet3CBDone, 

7441 foldToStreet4CBChance, 

7442 foldToStreet4CBDone, 

7443 common, 

7444 committed, 

7445 winnings, 

7446 rake, 

7447 rakeDealt, 

7448 rakeContributed, 

7449 rakeWeighted, 

7450 totalProfit, 

7451 allInEV, 

7452 showdownWinnings, 

7453 nonShowdownWinnings, 

7454 street1CheckCallRaiseChance, 

7455 street1CheckCallDone, 

7456 street1CheckRaiseDone, 

7457 street2CheckCallRaiseChance, 

7458 street2CheckCallDone, 

7459 street2CheckRaiseDone, 

7460 street3CheckCallRaiseChance, 

7461 street3CheckCallDone, 

7462 street3CheckRaiseDone, 

7463 street4CheckCallRaiseChance, 

7464 street4CheckCallDone, 

7465 street4CheckRaiseDone, 

7466 street0Calls, 

7467 street1Calls, 

7468 street2Calls, 

7469 street3Calls, 

7470 street4Calls, 

7471 street0Bets, 

7472 street1Bets, 

7473 street2Bets, 

7474 street3Bets, 

7475 street4Bets, 

7476 street0Raises, 

7477 street1Raises, 

7478 street2Raises, 

7479 street3Raises, 

7480 street4Raises, 

7481 street1Discards, 

7482 street2Discards, 

7483 street3Discards) 

7484 values (%s, %s, %s, %s, %s, 

7485 %s, %s, %s, %s, %s, 

7486 %s, %s, %s, %s, %s, 

7487 %s, %s, %s, %s, %s, 

7488 %s, %s, %s, %s, %s, 

7489 %s, %s, %s, %s, %s, 

7490 %s, %s, %s, %s, %s, 

7491 %s, %s, %s, %s, %s, 

7492 %s, %s, %s, %s, %s, 

7493 %s, %s, %s, %s, %s, 

7494 %s, %s, %s, %s, %s, 

7495 %s, %s, %s, %s, %s, 

7496 %s, %s, %s, %s, %s, 

7497 %s, %s, %s, %s, %s, 

7498 %s, %s, %s, %s, %s, 

7499 %s, %s, %s, %s, %s, 

7500 %s, %s, %s, %s, %s, 

7501 %s, %s, %s, %s, %s, 

7502 %s, %s, %s, %s, %s, 

7503 %s, %s, %s, %s, %s, 

7504 %s, %s, %s, %s, %s, 

7505 %s, %s, %s, %s, %s, 

7506 %s, %s, %s, %s, %s, 

7507 %s, %s, %s, %s, %s, 

7508 %s)""" 

7509 

7510 self.query['update_cardscache'] = """ 

7511 UPDATE CardsCache SET 

7512 n=n+%s, 

7513 street0VPIChance=street0VPIChance+%s, 

7514 street0VPI=street0VPI+%s, 

7515 street0AggrChance=street0AggrChance+%s, 

7516 street0Aggr=street0Aggr+%s, 

7517 street0CalledRaiseChance=street0CalledRaiseChance+%s, 

7518 street0CalledRaiseDone=street0CalledRaiseDone+%s, 

7519 street0_2BChance=street0_2BChance+%s, 

7520 street0_2BDone=street0_2BDone+%s, 

7521 street0_3BChance=street0_3BChance+%s, 

7522 street0_3BDone=street0_3BDone+%s, 

7523 street0_4BChance=street0_4BChance+%s, 

7524 street0_4BDone=street0_4BDone+%s, 

7525 street0_C4BChance=street0_C4BChance+%s, 

7526 street0_C4BDone=street0_C4BDone+%s, 

7527 street0_FoldTo2BChance=street0_FoldTo2BChance+%s, 

7528 street0_FoldTo2BDone=street0_FoldTo2BDone+%s, 

7529 street0_FoldTo3BChance=street0_FoldTo3BChance+%s, 

7530 street0_FoldTo3BDone=street0_FoldTo3BDone+%s, 

7531 street0_FoldTo4BChance=street0_FoldTo4BChance+%s, 

7532 street0_FoldTo4BDone=street0_FoldTo4BDone+%s, 

7533 street0_SqueezeChance=street0_SqueezeChance+%s, 

7534 street0_SqueezeDone=street0_SqueezeDone+%s, 

7535 raiseToStealChance=raiseToStealChance+%s, 

7536 raiseToStealDone=raiseToStealDone+%s, 

7537 stealChance=stealChance+%s, 

7538 stealDone=stealDone+%s, 

7539 success_Steal=success_Steal+%s, 

7540 street1Seen=street1Seen+%s, 

7541 street2Seen=street2Seen+%s, 

7542 street3Seen=street3Seen+%s, 

7543 street4Seen=street4Seen+%s, 

7544 sawShowdown=sawShowdown+%s, 

7545 street1Aggr=street1Aggr+%s, 

7546 street2Aggr=street2Aggr+%s, 

7547 street3Aggr=street3Aggr+%s, 

7548 street4Aggr=street4Aggr+%s, 

7549 otherRaisedStreet0=otherRaisedStreet0+%s, 

7550 otherRaisedStreet1=otherRaisedStreet1+%s, 

7551 otherRaisedStreet2=otherRaisedStreet2+%s, 

7552 otherRaisedStreet3=otherRaisedStreet3+%s, 

7553 otherRaisedStreet4=otherRaisedStreet4+%s, 

7554 foldToOtherRaisedStreet0=foldToOtherRaisedStreet0+%s, 

7555 foldToOtherRaisedStreet1=foldToOtherRaisedStreet1+%s, 

7556 foldToOtherRaisedStreet2=foldToOtherRaisedStreet2+%s, 

7557 foldToOtherRaisedStreet3=foldToOtherRaisedStreet3+%s, 

7558 foldToOtherRaisedStreet4=foldToOtherRaisedStreet4+%s, 

7559 wonWhenSeenStreet1=wonWhenSeenStreet1+%s, 

7560 wonWhenSeenStreet2=wonWhenSeenStreet2+%s, 

7561 wonWhenSeenStreet3=wonWhenSeenStreet3+%s, 

7562 wonWhenSeenStreet4=wonWhenSeenStreet4+%s, 

7563 wonAtSD=wonAtSD+%s, 

7564 raiseFirstInChance=raiseFirstInChance+%s, 

7565 raisedFirstIn=raisedFirstIn+%s, 

7566 foldBbToStealChance=foldBbToStealChance+%s, 

7567 foldedBbToSteal=foldedBbToSteal+%s, 

7568 foldSbToStealChance=foldSbToStealChance+%s, 

7569 foldedSbToSteal=foldedSbToSteal+%s, 

7570 street1CBChance=street1CBChance+%s, 

7571 street1CBDone=street1CBDone+%s, 

7572 street2CBChance=street2CBChance+%s, 

7573 street2CBDone=street2CBDone+%s, 

7574 street3CBChance=street3CBChance+%s, 

7575 street3CBDone=street3CBDone+%s, 

7576 street4CBChance=street4CBChance+%s, 

7577 street4CBDone=street4CBDone+%s, 

7578 foldToStreet1CBChance=foldToStreet1CBChance+%s, 

7579 foldToStreet1CBDone=foldToStreet1CBDone+%s, 

7580 foldToStreet2CBChance=foldToStreet2CBChance+%s, 

7581 foldToStreet2CBDone=foldToStreet2CBDone+%s, 

7582 foldToStreet3CBChance=foldToStreet3CBChance+%s, 

7583 foldToStreet3CBDone=foldToStreet3CBDone+%s, 

7584 foldToStreet4CBChance=foldToStreet4CBChance+%s, 

7585 foldToStreet4CBDone=foldToStreet4CBDone+%s, 

7586 common=common+%s, 

7587 committed=committed+%s, 

7588 winnings=winnings+%s, 

7589 rake=rake+%s, 

7590 rakeDealt=rakeDealt+%s, 

7591 rakeContributed=rakeContributed+%s, 

7592 rakeWeighted=rakeWeighted+%s, 

7593 totalProfit=totalProfit+%s, 

7594 allInEV=allInEV+%s, 

7595 showdownWinnings=showdownWinnings+%s, 

7596 nonShowdownWinnings=nonShowdownWinnings+%s, 

7597 street1CheckCallRaiseChance=street1CheckCallRaiseChance+%s, 

7598 street1CheckCallDone=street1CheckCallDone+%s, 

7599 street1CheckRaiseDone=street1CheckRaiseDone+%s, 

7600 street2CheckCallRaiseChance=street2CheckCallRaiseChance+%s, 

7601 street2CheckCallDone=street2CheckCallDone+%s, 

7602 street2CheckRaiseDone=street2CheckRaiseDone+%s, 

7603 street3CheckCallRaiseChance=street3CheckCallRaiseChance+%s, 

7604 street3CheckCallDone=street3CheckCallDone+%s, 

7605 street3CheckRaiseDone=street3CheckRaiseDone+%s, 

7606 street4CheckCallRaiseChance=street4CheckCallRaiseChance+%s, 

7607 street4CheckCallDone=street4CheckCallDone+%s, 

7608 street4CheckRaiseDone=street4CheckRaiseDone+%s, 

7609 street0Calls=street0Calls+%s, 

7610 street1Calls=street1Calls+%s, 

7611 street2Calls=street2Calls+%s, 

7612 street3Calls=street3Calls+%s, 

7613 street4Calls=street4Calls+%s, 

7614 street0Bets=street0Bets+%s,  

7615 street1Bets=street1Bets+%s, 

7616 street2Bets=street2Bets+%s,  

7617 street3Bets=street3Bets+%s, 

7618 street4Bets=street4Bets+%s,  

7619 street0Raises=street0Raises+%s, 

7620 street1Raises=street1Raises+%s, 

7621 street2Raises=street2Raises+%s, 

7622 street3Raises=street3Raises+%s, 

7623 street4Raises=street4Raises+%s, 

7624 street1Discards=street1Discards+%s, 

7625 street2Discards=street2Discards+%s, 

7626 street3Discards=street3Discards+%s 

7627 WHERE id=%s""" 

7628 

7629 self.query['select_cardscache_ring'] = """ 

7630 SELECT id 

7631 FROM CardsCache 

7632 WHERE weekId=%s 

7633 AND monthId=%s 

7634 AND gametypeId=%s 

7635 AND tourneyTypeId is NULL 

7636 AND playerId=%s 

7637 AND startCards=%s""" 

7638 

7639 self.query['select_cardscache_tour'] = """ 

7640 SELECT id 

7641 FROM CardsCache 

7642 WHERE weekId=%s 

7643 AND monthId=%s 

7644 AND gametypeId=%s 

7645 AND tourneyTypeId=%s 

7646 AND playerId=%s 

7647 AND startCards=%s""" 

7648 

7649 

7650 #################################### 

7651 # create comment on players 

7652 #################################### 

7653 

7654 self.query['get_player_comment'] = """ 

7655 SELECT comment FROM Players WHERE id=%s 

7656 """ 

7657 

7658 self.query['update_player_comment'] = """ 

7659 UPDATE Players SET comment=%s, commentTs=CURRENT_TIMESTAMP WHERE id=%s 

7660 """ 

7661 self.query['get_player_name'] = "SELECT name FROM Players WHERE id=%s" 

7662 

7663 #################################### 

7664 

7665 #################################### 

7666 # Queries to insert/update positionscache 

7667 #################################### 

7668 

7669 self.query['insert_positionscache'] = """insert into PositionsCache ( 

7670 weekId, 

7671 monthId, 

7672 gametypeId, 

7673 tourneyTypeId, 

7674 playerId, 

7675 seats, 

7676 maxPosition, 

7677 position, 

7678 n, 

7679 street0VPIChance, 

7680 street0VPI, 

7681 street0AggrChance, 

7682 street0Aggr, 

7683 street0CalledRaiseChance, 

7684 street0CalledRaiseDone, 

7685 street0_2BChance, 

7686 street0_2BDone, 

7687 street0_3BChance, 

7688 street0_3BDone, 

7689 street0_4BChance, 

7690 street0_4BDone, 

7691 street0_C4BChance, 

7692 street0_C4BDone, 

7693 street0_FoldTo2BChance, 

7694 street0_FoldTo2BDone, 

7695 street0_FoldTo3BChance, 

7696 street0_FoldTo3BDone, 

7697 street0_FoldTo4BChance, 

7698 street0_FoldTo4BDone, 

7699 street0_SqueezeChance, 

7700 street0_SqueezeDone, 

7701 raiseToStealChance, 

7702 raiseToStealDone, 

7703 stealChance, 

7704 stealDone, 

7705 success_Steal, 

7706 street1Seen, 

7707 street2Seen, 

7708 street3Seen, 

7709 street4Seen, 

7710 sawShowdown, 

7711 street1Aggr, 

7712 street2Aggr, 

7713 street3Aggr, 

7714 street4Aggr, 

7715 otherRaisedStreet0, 

7716 otherRaisedStreet1, 

7717 otherRaisedStreet2, 

7718 otherRaisedStreet3, 

7719 otherRaisedStreet4, 

7720 foldToOtherRaisedStreet0, 

7721 foldToOtherRaisedStreet1, 

7722 foldToOtherRaisedStreet2, 

7723 foldToOtherRaisedStreet3, 

7724 foldToOtherRaisedStreet4, 

7725 wonWhenSeenStreet1, 

7726 wonWhenSeenStreet2, 

7727 wonWhenSeenStreet3, 

7728 wonWhenSeenStreet4, 

7729 wonAtSD, 

7730 raiseFirstInChance, 

7731 raisedFirstIn, 

7732 foldBbToStealChance, 

7733 foldedBbToSteal, 

7734 foldSbToStealChance, 

7735 foldedSbToSteal, 

7736 street1CBChance, 

7737 street1CBDone, 

7738 street2CBChance, 

7739 street2CBDone, 

7740 street3CBChance, 

7741 street3CBDone, 

7742 street4CBChance, 

7743 street4CBDone, 

7744 foldToStreet1CBChance, 

7745 foldToStreet1CBDone, 

7746 foldToStreet2CBChance, 

7747 foldToStreet2CBDone, 

7748 foldToStreet3CBChance, 

7749 foldToStreet3CBDone, 

7750 foldToStreet4CBChance, 

7751 foldToStreet4CBDone, 

7752 common, 

7753 committed, 

7754 winnings, 

7755 rake, 

7756 rakeDealt, 

7757 rakeContributed, 

7758 rakeWeighted, 

7759 totalProfit, 

7760 allInEV, 

7761 showdownWinnings, 

7762 nonShowdownWinnings, 

7763 street1CheckCallRaiseChance, 

7764 street1CheckCallDone, 

7765 street1CheckRaiseDone, 

7766 street2CheckCallRaiseChance, 

7767 street2CheckCallDone, 

7768 street2CheckRaiseDone, 

7769 street3CheckCallRaiseChance, 

7770 street3CheckCallDone, 

7771 street3CheckRaiseDone, 

7772 street4CheckCallRaiseChance, 

7773 street4CheckCallDone, 

7774 street4CheckRaiseDone, 

7775 street0Calls, 

7776 street1Calls, 

7777 street2Calls, 

7778 street3Calls, 

7779 street4Calls, 

7780 street0Bets, 

7781 street1Bets, 

7782 street2Bets, 

7783 street3Bets, 

7784 street4Bets, 

7785 street0Raises, 

7786 street1Raises, 

7787 street2Raises, 

7788 street3Raises, 

7789 street4Raises, 

7790 street1Discards, 

7791 street2Discards, 

7792 street3Discards) 

7793 values (%s, %s, %s, %s, %s, 

7794 %s, %s, %s, %s, %s, 

7795 %s, %s, %s, %s, %s, 

7796 %s, %s, %s, %s, %s, 

7797 %s, %s, %s, %s, %s, 

7798 %s, %s, %s, %s, %s, 

7799 %s, %s, %s, %s, %s, 

7800 %s, %s, %s, %s, %s, 

7801 %s, %s, %s, %s, %s, 

7802 %s, %s, %s, %s, %s, 

7803 %s, %s, %s, %s, %s, 

7804 %s, %s, %s, %s, %s, 

7805 %s, %s, %s, %s, %s, 

7806 %s, %s, %s, %s, %s, 

7807 %s, %s, %s, %s, %s, 

7808 %s, %s, %s, %s, %s, 

7809 %s, %s, %s, %s, %s, 

7810 %s, %s, %s, %s, %s, 

7811 %s, %s, %s, %s, %s, 

7812 %s, %s, %s, %s, %s, 

7813 %s, %s, %s, %s, %s, 

7814 %s, %s, %s, %s, %s, 

7815 %s, %s, %s, %s, %s, 

7816 %s, %s, %s, %s, %s, 

7817 %s, %s, %s 

7818 )""" 

7819 

7820 self.query['update_positionscache'] = """ 

7821 UPDATE PositionsCache SET 

7822 n=n+%s, 

7823 street0VPIChance=street0VPIChance+%s, 

7824 street0VPI=street0VPI+%s, 

7825 street0AggrChance=street0AggrChance+%s, 

7826 street0Aggr=street0Aggr+%s, 

7827 street0CalledRaiseChance=street0CalledRaiseChance+%s, 

7828 street0CalledRaiseDone=street0CalledRaiseDone+%s, 

7829 street0_2BChance=street0_2BChance+%s, 

7830 street0_2BDone=street0_2BDone+%s, 

7831 street0_3BChance=street0_3BChance+%s, 

7832 street0_3BDone=street0_3BDone+%s, 

7833 street0_4BChance=street0_4BChance+%s, 

7834 street0_4BDone=street0_4BDone+%s, 

7835 street0_C4BChance=street0_C4BChance+%s, 

7836 street0_C4BDone=street0_C4BDone+%s, 

7837 street0_FoldTo2BChance=street0_FoldTo2BChance+%s, 

7838 street0_FoldTo2BDone=street0_FoldTo2BDone+%s, 

7839 street0_FoldTo3BChance=street0_FoldTo3BChance+%s, 

7840 street0_FoldTo3BDone=street0_FoldTo3BDone+%s, 

7841 street0_FoldTo4BChance=street0_FoldTo4BChance+%s, 

7842 street0_FoldTo4BDone=street0_FoldTo4BDone+%s, 

7843 street0_SqueezeChance=street0_SqueezeChance+%s, 

7844 street0_SqueezeDone=street0_SqueezeDone+%s, 

7845 raiseToStealChance=raiseToStealChance+%s, 

7846 raiseToStealDone=raiseToStealDone+%s, 

7847 stealChance=stealChance+%s, 

7848 stealDone=stealDone+%s, 

7849 success_Steal=success_Steal+%s, 

7850 street1Seen=street1Seen+%s, 

7851 street2Seen=street2Seen+%s, 

7852 street3Seen=street3Seen+%s, 

7853 street4Seen=street4Seen+%s, 

7854 sawShowdown=sawShowdown+%s, 

7855 street1Aggr=street1Aggr+%s, 

7856 street2Aggr=street2Aggr+%s, 

7857 street3Aggr=street3Aggr+%s, 

7858 street4Aggr=street4Aggr+%s, 

7859 otherRaisedStreet0=otherRaisedStreet0+%s, 

7860 otherRaisedStreet1=otherRaisedStreet1+%s, 

7861 otherRaisedStreet2=otherRaisedStreet2+%s, 

7862 otherRaisedStreet3=otherRaisedStreet3+%s, 

7863 otherRaisedStreet4=otherRaisedStreet4+%s, 

7864 foldToOtherRaisedStreet0=foldToOtherRaisedStreet0+%s, 

7865 foldToOtherRaisedStreet1=foldToOtherRaisedStreet1+%s, 

7866 foldToOtherRaisedStreet2=foldToOtherRaisedStreet2+%s, 

7867 foldToOtherRaisedStreet3=foldToOtherRaisedStreet3+%s, 

7868 foldToOtherRaisedStreet4=foldToOtherRaisedStreet4+%s, 

7869 wonWhenSeenStreet1=wonWhenSeenStreet1+%s, 

7870 wonWhenSeenStreet2=wonWhenSeenStreet2+%s, 

7871 wonWhenSeenStreet3=wonWhenSeenStreet3+%s, 

7872 wonWhenSeenStreet4=wonWhenSeenStreet4+%s, 

7873 wonAtSD=wonAtSD+%s, 

7874 raiseFirstInChance=raiseFirstInChance+%s, 

7875 raisedFirstIn=raisedFirstIn+%s, 

7876 foldBbToStealChance=foldBbToStealChance+%s, 

7877 foldedBbToSteal=foldedBbToSteal+%s, 

7878 foldSbToStealChance=foldSbToStealChance+%s, 

7879 foldedSbToSteal=foldedSbToSteal+%s, 

7880 street1CBChance=street1CBChance+%s, 

7881 street1CBDone=street1CBDone+%s, 

7882 street2CBChance=street2CBChance+%s, 

7883 street2CBDone=street2CBDone+%s, 

7884 street3CBChance=street3CBChance+%s, 

7885 street3CBDone=street3CBDone+%s, 

7886 street4CBChance=street4CBChance+%s, 

7887 street4CBDone=street4CBDone+%s, 

7888 foldToStreet1CBChance=foldToStreet1CBChance+%s, 

7889 foldToStreet1CBDone=foldToStreet1CBDone+%s, 

7890 foldToStreet2CBChance=foldToStreet2CBChance+%s, 

7891 foldToStreet2CBDone=foldToStreet2CBDone+%s, 

7892 foldToStreet3CBChance=foldToStreet3CBChance+%s, 

7893 foldToStreet3CBDone=foldToStreet3CBDone+%s, 

7894 foldToStreet4CBChance=foldToStreet4CBChance+%s, 

7895 foldToStreet4CBDone=foldToStreet4CBDone+%s, 

7896 common=common+%s, 

7897 committed=committed+%s, 

7898 winnings=winnings+%s, 

7899 rake=rake+%s, 

7900 rakeDealt=rakeDealt+%s, 

7901 rakeContributed=rakeContributed+%s, 

7902 rakeWeighted=rakeWeighted+%s, 

7903 totalProfit=totalProfit+%s, 

7904 allInEV=allInEV+%s, 

7905 showdownWinnings=showdownWinnings+%s, 

7906 nonShowdownWinnings=nonShowdownWinnings+%s, 

7907 street1CheckCallRaiseChance=street1CheckCallRaiseChance+%s, 

7908 street1CheckCallDone=street1CheckCallDone+%s, 

7909 street1CheckRaiseDone=street1CheckRaiseDone+%s, 

7910 street2CheckCallRaiseChance=street2CheckCallRaiseChance+%s, 

7911 street2CheckCallDone=street2CheckCallDone+%s, 

7912 street2CheckRaiseDone=street2CheckRaiseDone+%s, 

7913 street3CheckCallRaiseChance=street3CheckCallRaiseChance+%s, 

7914 street3CheckCallDone=street3CheckCallDone+%s, 

7915 street3CheckRaiseDone=street3CheckRaiseDone+%s, 

7916 street4CheckCallRaiseChance=street4CheckCallRaiseChance+%s, 

7917 street4CheckCallDone=street4CheckCallDone+%s, 

7918 street4CheckRaiseDone=street4CheckRaiseDone+%s, 

7919 street0Calls=street0Calls+%s, 

7920 street1Calls=street1Calls+%s, 

7921 street2Calls=street2Calls+%s, 

7922 street3Calls=street3Calls+%s, 

7923 street4Calls=street4Calls+%s, 

7924 street0Bets=street0Bets+%s,  

7925 street1Bets=street1Bets+%s, 

7926 street2Bets=street2Bets+%s,  

7927 street3Bets=street3Bets+%s, 

7928 street4Bets=street4Bets+%s,  

7929 street0Raises=street0Raises+%s, 

7930 street1Raises=street1Raises+%s, 

7931 street2Raises=street2Raises+%s, 

7932 street3Raises=street3Raises+%s, 

7933 street4Raises=street4Raises+%s, 

7934 street1Discards=street1Discards+%s, 

7935 street2Discards=street2Discards+%s, 

7936 street3Discards=street3Discards+%s 

7937 WHERE id=%s""" 

7938 

7939 self.query['select_positionscache_ring'] = """ 

7940 SELECT id 

7941 FROM PositionsCache 

7942 WHERE weekId=%s 

7943 AND monthId=%s 

7944 AND gametypeId=%s 

7945 AND tourneyTypeId is NULL 

7946 AND playerId=%s 

7947 AND seats=%s 

7948 AND maxPosition=%s 

7949 AND position=%s""" 

7950 

7951 self.query['select_positionscache_tour'] = """ 

7952 SELECT id 

7953 FROM PositionsCache 

7954 WHERE weekId=%s 

7955 AND monthId=%s 

7956 AND gametypeId=%s 

7957 AND tourneyTypeId=%s 

7958 AND playerId=%s 

7959 AND seats=%s 

7960 AND maxPosition=%s 

7961 AND position=%s""" 

7962 

7963 #################################### 

7964 # Queries to rebuild/modify sessionscache 

7965 #################################### 

7966 

7967 self.query['clear_S_H'] = "UPDATE Hands SET sessionId = NULL" 

7968 self.query['clear_S_T'] = "UPDATE Tourneys SET sessionId = NULL" 

7969 self.query['clear_S_SC'] = "UPDATE SessionsCache SET sessionId = NULL" 

7970 self.query['clear_S_TC'] = "UPDATE TourneysCache SET sessionId = NULL" 

7971 self.query['clear_W_S'] = "UPDATE Sessions SET weekId = NULL" 

7972 self.query['clear_M_S'] = "UPDATE Sessions SET monthId = NULL" 

7973 self.query['clearSessionsCache'] = "DELETE FROM SessionsCache WHERE 1" 

7974 self.query['clearTourneysCache'] = "DELETE FROM TourneysCache WHERE 1" 

7975 self.query['clearSessions'] = "DELETE FROM Sessions WHERE 1" 

7976 self.query['clearWeeks'] = "DELETE FROM Weeks WHERE 1" 

7977 self.query['clearMonths'] = "DELETE FROM Months WHERE 1" 

7978 self.query['update_RSC_H'] = "UPDATE Hands SET sessionId = %s WHERE id = %s" 

7979 

7980 #################################### 

7981 # select 

7982 #################################### 

7983 

7984 self.query['select_S_all'] = """ 

7985 SELECT SC.id as id, 

7986 sessionStart, 

7987 weekStart, 

7988 monthStart, 

7989 weekId, 

7990 monthId 

7991 FROM Sessions SC 

7992 INNER JOIN Weeks WC ON (SC.weekId = WC.id) 

7993 INNER JOIN Months MC ON (SC.monthId = MC.id) 

7994 WHERE sessionEnd>=%s 

7995 AND sessionStart<=%s""" 

7996 

7997 self.query['select_S'] = """ 

7998 SELECT SC.id as id, 

7999 sessionStart, 

8000 sessionEnd, 

8001 weekStart, 

8002 monthStart, 

8003 weekId, 

8004 monthId 

8005 FROM Sessions SC 

8006 INNER JOIN Weeks WC ON (SC.weekId = WC.id) 

8007 INNER JOIN Months MC ON (SC.monthId = MC.id) 

8008 WHERE (sessionEnd>=%s AND sessionStart<=%s) 

8009 <TOURSELECT>""" 

8010 

8011 self.query['select_W'] = """ 

8012 SELECT id 

8013 FROM Weeks 

8014 WHERE weekStart = %s""" 

8015 

8016 self.query['select_M'] = """ 

8017 SELECT id 

8018 FROM Months 

8019 WHERE monthStart = %s""" 

8020 

8021 self.query['select_SC'] = """ 

8022 SELECT id, 

8023 sessionId, 

8024 startTime, 

8025 endTime, 

8026 n, 

8027 street0VPIChance, 

8028 street0VPI, 

8029 street0AggrChance, 

8030 street0Aggr, 

8031 street0CalledRaiseChance, 

8032 street0CalledRaiseDone, 

8033 street0_2BChance, 

8034 street0_2BDone, 

8035 street0_3BChance, 

8036 street0_3BDone, 

8037 street0_4BChance, 

8038 street0_4BDone, 

8039 street0_C4BChance, 

8040 street0_C4BDone, 

8041 street0_FoldTo2BChance, 

8042 street0_FoldTo2BDone, 

8043 street0_FoldTo3BChance, 

8044 street0_FoldTo3BDone, 

8045 street0_FoldTo4BChance, 

8046 street0_FoldTo4BDone, 

8047 street0_SqueezeChance, 

8048 street0_SqueezeDone, 

8049 raiseToStealChance, 

8050 raiseToStealDone, 

8051 stealChance, 

8052 stealDone, 

8053 success_Steal, 

8054 street1Seen, 

8055 street2Seen, 

8056 street3Seen, 

8057 street4Seen, 

8058 sawShowdown, 

8059 street1Aggr, 

8060 street2Aggr, 

8061 street3Aggr, 

8062 street4Aggr, 

8063 otherRaisedStreet0, 

8064 otherRaisedStreet1, 

8065 otherRaisedStreet2, 

8066 otherRaisedStreet3, 

8067 otherRaisedStreet4, 

8068 foldToOtherRaisedStreet0, 

8069 foldToOtherRaisedStreet1, 

8070 foldToOtherRaisedStreet2, 

8071 foldToOtherRaisedStreet3, 

8072 foldToOtherRaisedStreet4, 

8073 wonWhenSeenStreet1, 

8074 wonWhenSeenStreet2, 

8075 wonWhenSeenStreet3, 

8076 wonWhenSeenStreet4, 

8077 wonAtSD, 

8078 raiseFirstInChance, 

8079 raisedFirstIn, 

8080 foldBbToStealChance, 

8081 foldedBbToSteal, 

8082 foldSbToStealChance, 

8083 foldedSbToSteal, 

8084 street1CBChance, 

8085 street1CBDone, 

8086 street2CBChance, 

8087 street2CBDone, 

8088 street3CBChance, 

8089 street3CBDone, 

8090 street4CBChance, 

8091 street4CBDone, 

8092 foldToStreet1CBChance, 

8093 foldToStreet1CBDone, 

8094 foldToStreet2CBChance, 

8095 foldToStreet2CBDone, 

8096 foldToStreet3CBChance, 

8097 foldToStreet3CBDone, 

8098 foldToStreet4CBChance, 

8099 foldToStreet4CBDone, 

8100 common, 

8101 committed, 

8102 winnings, 

8103 rake, 

8104 rakeDealt, 

8105 rakeContributed, 

8106 rakeWeighted, 

8107 totalProfit, 

8108 allInEV, 

8109 showdownWinnings, 

8110 nonShowdownWinnings, 

8111 street1CheckCallRaiseChance, 

8112 street1CheckCallDone, 

8113 street1CheckRaiseDone, 

8114 street2CheckCallRaiseChance, 

8115 street2CheckCallDone, 

8116 street2CheckRaiseDone, 

8117 street3CheckCallRaiseChance, 

8118 street3CheckCallDone, 

8119 street3CheckRaiseDone, 

8120 street4CheckCallRaiseChance, 

8121 street4CheckCallDone, 

8122 street4CheckRaiseDone, 

8123 street0Calls, 

8124 street1Calls, 

8125 street2Calls, 

8126 street3Calls, 

8127 street4Calls, 

8128 street0Bets, 

8129 street1Bets, 

8130 street2Bets, 

8131 street3Bets, 

8132 street4Bets, 

8133 street0Raises, 

8134 street1Raises, 

8135 street2Raises, 

8136 street3Raises, 

8137 street4Raises, 

8138 street1Discards, 

8139 street2Discards, 

8140 street3Discards 

8141 FROM SessionsCache 

8142 WHERE endTime>=%s 

8143 AND startTime<=%s 

8144 AND gametypeId=%s 

8145 AND playerId=%s""" 

8146 

8147 self.query['select_TC'] = """ 

8148 SELECT id, startTime, endTime 

8149 FROM TourneysCache TC 

8150 WHERE tourneyId=%s 

8151 AND playerId=%s""" 

8152 

8153 #################################### 

8154 # insert 

8155 #################################### 

8156 

8157 self.query['insert_W'] = """insert into Weeks ( 

8158 weekStart) 

8159 values (%s)""" 

8160 

8161 self.query['insert_M'] = """insert into Months ( 

8162 monthStart) 

8163 values (%s)""" 

8164 

8165 self.query['insert_S'] = """insert into Sessions ( 

8166 weekId, 

8167 monthId, 

8168 sessionStart, 

8169 sessionEnd) 

8170 values (%s, %s, %s, %s)""" 

8171 

8172 self.query['insert_SC'] = """insert into SessionsCache ( 

8173 sessionId, 

8174 startTime, 

8175 endTime, 

8176 gametypeId, 

8177 playerId, 

8178 n, 

8179 street0VPIChance, 

8180 street0VPI, 

8181 street0AggrChance, 

8182 street0Aggr, 

8183 street0CalledRaiseChance, 

8184 street0CalledRaiseDone, 

8185 street0_2BChance, 

8186 street0_2BDone, 

8187 street0_3BChance, 

8188 street0_3BDone, 

8189 street0_4BChance, 

8190 street0_4BDone, 

8191 street0_C4BChance, 

8192 street0_C4BDone, 

8193 street0_FoldTo2BChance, 

8194 street0_FoldTo2BDone, 

8195 street0_FoldTo3BChance, 

8196 street0_FoldTo3BDone, 

8197 street0_FoldTo4BChance, 

8198 street0_FoldTo4BDone, 

8199 street0_SqueezeChance, 

8200 street0_SqueezeDone, 

8201 raiseToStealChance, 

8202 raiseToStealDone, 

8203 stealChance, 

8204 stealDone, 

8205 success_Steal, 

8206 street1Seen, 

8207 street2Seen, 

8208 street3Seen, 

8209 street4Seen, 

8210 sawShowdown, 

8211 street1Aggr, 

8212 street2Aggr, 

8213 street3Aggr, 

8214 street4Aggr, 

8215 otherRaisedStreet0, 

8216 otherRaisedStreet1, 

8217 otherRaisedStreet2, 

8218 otherRaisedStreet3, 

8219 otherRaisedStreet4, 

8220 foldToOtherRaisedStreet0, 

8221 foldToOtherRaisedStreet1, 

8222 foldToOtherRaisedStreet2, 

8223 foldToOtherRaisedStreet3, 

8224 foldToOtherRaisedStreet4, 

8225 wonWhenSeenStreet1, 

8226 wonWhenSeenStreet2, 

8227 wonWhenSeenStreet3, 

8228 wonWhenSeenStreet4, 

8229 wonAtSD, 

8230 raiseFirstInChance, 

8231 raisedFirstIn, 

8232 foldBbToStealChance, 

8233 foldedBbToSteal, 

8234 foldSbToStealChance, 

8235 foldedSbToSteal, 

8236 street1CBChance, 

8237 street1CBDone, 

8238 street2CBChance, 

8239 street2CBDone, 

8240 street3CBChance, 

8241 street3CBDone, 

8242 street4CBChance, 

8243 street4CBDone, 

8244 foldToStreet1CBChance, 

8245 foldToStreet1CBDone, 

8246 foldToStreet2CBChance, 

8247 foldToStreet2CBDone, 

8248 foldToStreet3CBChance, 

8249 foldToStreet3CBDone, 

8250 foldToStreet4CBChance, 

8251 foldToStreet4CBDone, 

8252 common, 

8253 committed, 

8254 winnings, 

8255 rake, 

8256 rakeDealt, 

8257 rakeContributed, 

8258 rakeWeighted, 

8259 totalProfit, 

8260 allInEV, 

8261 showdownWinnings, 

8262 nonShowdownWinnings, 

8263 street1CheckCallRaiseChance, 

8264 street1CheckCallDone, 

8265 street1CheckRaiseDone, 

8266 street2CheckCallRaiseChance, 

8267 street2CheckCallDone, 

8268 street2CheckRaiseDone, 

8269 street3CheckCallRaiseChance, 

8270 street3CheckCallDone, 

8271 street3CheckRaiseDone, 

8272 street4CheckCallRaiseChance, 

8273 street4CheckCallDone, 

8274 street4CheckRaiseDone, 

8275 street0Calls, 

8276 street1Calls, 

8277 street2Calls, 

8278 street3Calls, 

8279 street4Calls, 

8280 street0Bets, 

8281 street1Bets, 

8282 street2Bets, 

8283 street3Bets, 

8284 street4Bets, 

8285 street0Raises, 

8286 street1Raises, 

8287 street2Raises, 

8288 street3Raises, 

8289 street4Raises, 

8290 street1Discards, 

8291 street2Discards, 

8292 street3Discards 

8293 ) 

8294 values (%s, %s, %s, %s, %s, 

8295 %s, %s, %s, %s, %s, 

8296 %s, %s, %s, %s, %s, 

8297 %s, %s, %s, %s, %s, 

8298 %s, %s, %s, %s, %s, 

8299 %s, %s, %s, %s, %s, 

8300 %s, %s, %s, %s, %s, 

8301 %s, %s, %s, %s, %s, 

8302 %s, %s, %s, %s, %s, 

8303 %s, %s, %s, %s, %s, 

8304 %s, %s, %s, %s, %s, 

8305 %s, %s, %s, %s, %s, 

8306 %s, %s, %s, %s, %s, 

8307 %s, %s, %s, %s, %s, 

8308 %s, %s, %s, %s, %s, 

8309 %s, %s, %s, %s, %s, 

8310 %s, %s, %s, %s, %s, 

8311 %s, %s, %s, %s, %s, 

8312 %s, %s, %s, %s, %s, 

8313 %s, %s, %s, %s, %s, 

8314 %s, %s, %s, %s, %s, 

8315 %s, %s, %s, %s, %s, 

8316 %s, %s, %s, %s, %s, 

8317 %s, %s, %s, %s, %s)""" 

8318 

8319 self.query['insert_TC'] = """insert into TourneysCache ( 

8320 sessionId, 

8321 startTime, 

8322 endTime, 

8323 tourneyId, 

8324 playerId, 

8325 n, 

8326 street0VPIChance, 

8327 street0VPI, 

8328 street0AggrChance, 

8329 street0Aggr, 

8330 street0CalledRaiseChance, 

8331 street0CalledRaiseDone, 

8332 street0_2BChance, 

8333 street0_2BDone, 

8334 street0_3BChance, 

8335 street0_3BDone, 

8336 street0_4BChance, 

8337 street0_4BDone, 

8338 street0_C4BChance, 

8339 street0_C4BDone, 

8340 street0_FoldTo2BChance, 

8341 street0_FoldTo2BDone, 

8342 street0_FoldTo3BChance, 

8343 street0_FoldTo3BDone, 

8344 street0_FoldTo4BChance, 

8345 street0_FoldTo4BDone, 

8346 street0_SqueezeChance, 

8347 street0_SqueezeDone, 

8348 raiseToStealChance, 

8349 raiseToStealDone, 

8350 stealChance, 

8351 stealDone, 

8352 success_Steal, 

8353 street1Seen, 

8354 street2Seen, 

8355 street3Seen, 

8356 street4Seen, 

8357 sawShowdown, 

8358 street1Aggr, 

8359 street2Aggr, 

8360 street3Aggr, 

8361 street4Aggr, 

8362 otherRaisedStreet0, 

8363 otherRaisedStreet1, 

8364 otherRaisedStreet2, 

8365 otherRaisedStreet3, 

8366 otherRaisedStreet4, 

8367 foldToOtherRaisedStreet0, 

8368 foldToOtherRaisedStreet1, 

8369 foldToOtherRaisedStreet2, 

8370 foldToOtherRaisedStreet3, 

8371 foldToOtherRaisedStreet4, 

8372 wonWhenSeenStreet1, 

8373 wonWhenSeenStreet2, 

8374 wonWhenSeenStreet3, 

8375 wonWhenSeenStreet4, 

8376 wonAtSD, 

8377 raiseFirstInChance, 

8378 raisedFirstIn, 

8379 foldBbToStealChance, 

8380 foldedBbToSteal, 

8381 foldSbToStealChance, 

8382 foldedSbToSteal, 

8383 street1CBChance, 

8384 street1CBDone, 

8385 street2CBChance, 

8386 street2CBDone, 

8387 street3CBChance, 

8388 street3CBDone, 

8389 street4CBChance, 

8390 street4CBDone, 

8391 foldToStreet1CBChance, 

8392 foldToStreet1CBDone, 

8393 foldToStreet2CBChance, 

8394 foldToStreet2CBDone, 

8395 foldToStreet3CBChance, 

8396 foldToStreet3CBDone, 

8397 foldToStreet4CBChance, 

8398 foldToStreet4CBDone, 

8399 common, 

8400 committed, 

8401 winnings, 

8402 rake, 

8403 rakeDealt, 

8404 rakeContributed, 

8405 rakeWeighted, 

8406 totalProfit, 

8407 allInEV, 

8408 showdownWinnings, 

8409 nonShowdownWinnings, 

8410 street1CheckCallRaiseChance, 

8411 street1CheckCallDone, 

8412 street1CheckRaiseDone, 

8413 street2CheckCallRaiseChance, 

8414 street2CheckCallDone, 

8415 street2CheckRaiseDone, 

8416 street3CheckCallRaiseChance, 

8417 street3CheckCallDone, 

8418 street3CheckRaiseDone, 

8419 street4CheckCallRaiseChance, 

8420 street4CheckCallDone, 

8421 street4CheckRaiseDone, 

8422 street0Calls, 

8423 street1Calls, 

8424 street2Calls, 

8425 street3Calls, 

8426 street4Calls, 

8427 street0Bets, 

8428 street1Bets, 

8429 street2Bets, 

8430 street3Bets, 

8431 street4Bets, 

8432 street0Raises, 

8433 street1Raises, 

8434 street2Raises, 

8435 street3Raises, 

8436 street4Raises, 

8437 street1Discards, 

8438 street2Discards, 

8439 street3Discards 

8440 ) 

8441 values (%s, %s, %s, %s, %s, 

8442 %s, %s, %s, %s, %s, 

8443 %s, %s, %s, %s, %s, 

8444 %s, %s, %s, %s, %s, 

8445 %s, %s, %s, %s, %s, 

8446 %s, %s, %s, %s, %s, 

8447 %s, %s, %s, %s, %s, 

8448 %s, %s, %s, %s, %s, 

8449 %s, %s, %s, %s, %s, 

8450 %s, %s, %s, %s, %s, 

8451 %s, %s, %s, %s, %s, 

8452 %s, %s, %s, %s, %s, 

8453 %s, %s, %s, %s, %s, 

8454 %s, %s, %s, %s, %s, 

8455 %s, %s, %s, %s, %s, 

8456 %s, %s, %s, %s, %s, 

8457 %s, %s, %s, %s, %s, 

8458 %s, %s, %s, %s, %s, 

8459 %s, %s, %s, %s, %s, 

8460 %s, %s, %s, %s, %s, 

8461 %s, %s, %s, %s, %s, 

8462 %s, %s, %s, %s, %s, 

8463 %s, %s, %s, %s, %s, 

8464 %s, %s, %s, %s, %s)""" 

8465 

8466 #################################### 

8467 # update 

8468 #################################### 

8469 

8470 self.query['update_WM_S'] = """ 

8471 UPDATE Sessions SET 

8472 weekId=%s, 

8473 monthId=%s 

8474 WHERE id=%s""" 

8475 

8476 self.query['update_S'] = """ 

8477 UPDATE Sessions SET  

8478 weekId=%s, 

8479 monthId=%s, 

8480 sessionStart=%s, 

8481 sessionEnd=%s 

8482 WHERE id=%s""" 

8483 

8484 self.query['update_SC'] = """ 

8485 UPDATE SessionsCache SET 

8486 startTime=%s, 

8487 endTime=%s, 

8488 n=n+%s, 

8489 street0VPIChance=street0VPIChance+%s, 

8490 street0VPI=street0VPI+%s, 

8491 street0AggrChance=street0AggrChance+%s, 

8492 street0Aggr=street0Aggr+%s, 

8493 street0CalledRaiseChance=street0CalledRaiseChance+%s, 

8494 street0CalledRaiseDone=street0CalledRaiseDone+%s, 

8495 street0_2BChance=street0_2BChance+%s, 

8496 street0_2BDone=street0_2BDone+%s, 

8497 street0_3BChance=street0_3BChance+%s, 

8498 street0_3BDone=street0_3BDone+%s, 

8499 street0_4BChance=street0_4BChance+%s, 

8500 street0_4BDone=street0_4BDone+%s, 

8501 street0_C4BChance=street0_C4BChance+%s, 

8502 street0_C4BDone=street0_C4BDone+%s, 

8503 street0_FoldTo2BChance=street0_FoldTo2BChance+%s, 

8504 street0_FoldTo2BDone=street0_FoldTo2BDone+%s, 

8505 street0_FoldTo3BChance=street0_FoldTo3BChance+%s, 

8506 street0_FoldTo3BDone=street0_FoldTo3BDone+%s, 

8507 street0_FoldTo4BChance=street0_FoldTo4BChance+%s, 

8508 street0_FoldTo4BDone=street0_FoldTo4BDone+%s, 

8509 street0_SqueezeChance=street0_SqueezeChance+%s, 

8510 street0_SqueezeDone=street0_SqueezeDone+%s, 

8511 raiseToStealChance=raiseToStealChance+%s, 

8512 raiseToStealDone=raiseToStealDone+%s, 

8513 stealChance=stealChance+%s, 

8514 stealDone=stealDone+%s, 

8515 success_Steal=success_Steal+%s, 

8516 street1Seen=street1Seen+%s, 

8517 street2Seen=street2Seen+%s, 

8518 street3Seen=street3Seen+%s, 

8519 street4Seen=street4Seen+%s, 

8520 sawShowdown=sawShowdown+%s, 

8521 street1Aggr=street1Aggr+%s, 

8522 street2Aggr=street2Aggr+%s, 

8523 street3Aggr=street3Aggr+%s, 

8524 street4Aggr=street4Aggr+%s, 

8525 otherRaisedStreet0=otherRaisedStreet0+%s, 

8526 otherRaisedStreet1=otherRaisedStreet1+%s, 

8527 otherRaisedStreet2=otherRaisedStreet2+%s, 

8528 otherRaisedStreet3=otherRaisedStreet3+%s, 

8529 otherRaisedStreet4=otherRaisedStreet4+%s, 

8530 foldToOtherRaisedStreet0=foldToOtherRaisedStreet0+%s, 

8531 foldToOtherRaisedStreet1=foldToOtherRaisedStreet1+%s, 

8532 foldToOtherRaisedStreet2=foldToOtherRaisedStreet2+%s, 

8533 foldToOtherRaisedStreet3=foldToOtherRaisedStreet3+%s, 

8534 foldToOtherRaisedStreet4=foldToOtherRaisedStreet4+%s, 

8535 wonWhenSeenStreet1=wonWhenSeenStreet1+%s, 

8536 wonWhenSeenStreet2=wonWhenSeenStreet2+%s, 

8537 wonWhenSeenStreet3=wonWhenSeenStreet3+%s, 

8538 wonWhenSeenStreet4=wonWhenSeenStreet4+%s, 

8539 wonAtSD=wonAtSD+%s, 

8540 raiseFirstInChance=raiseFirstInChance+%s, 

8541 raisedFirstIn=raisedFirstIn+%s, 

8542 foldBbToStealChance=foldBbToStealChance+%s, 

8543 foldedBbToSteal=foldedBbToSteal+%s, 

8544 foldSbToStealChance=foldSbToStealChance+%s, 

8545 foldedSbToSteal=foldedSbToSteal+%s, 

8546 street1CBChance=street1CBChance+%s, 

8547 street1CBDone=street1CBDone+%s, 

8548 street2CBChance=street2CBChance+%s, 

8549 street2CBDone=street2CBDone+%s, 

8550 street3CBChance=street3CBChance+%s, 

8551 street3CBDone=street3CBDone+%s, 

8552 street4CBChance=street4CBChance+%s, 

8553 street4CBDone=street4CBDone+%s, 

8554 foldToStreet1CBChance=foldToStreet1CBChance+%s, 

8555 foldToStreet1CBDone=foldToStreet1CBDone+%s, 

8556 foldToStreet2CBChance=foldToStreet2CBChance+%s, 

8557 foldToStreet2CBDone=foldToStreet2CBDone+%s, 

8558 foldToStreet3CBChance=foldToStreet3CBChance+%s, 

8559 foldToStreet3CBDone=foldToStreet3CBDone+%s, 

8560 foldToStreet4CBChance=foldToStreet4CBChance+%s, 

8561 foldToStreet4CBDone=foldToStreet4CBDone+%s, 

8562 common=common+%s, 

8563 committed=committed+%s, 

8564 winnings=winnings+%s, 

8565 rake=rake+%s, 

8566 rakeDealt=rakeDealt+%s, 

8567 rakeContributed=rakeContributed+%s, 

8568 rakeWeighted=rakeWeighted+%s, 

8569 totalProfit=totalProfit+%s, 

8570 allInEV=allInEV+%s, 

8571 showdownWinnings=showdownWinnings+%s, 

8572 nonShowdownWinnings=nonShowdownWinnings+%s, 

8573 street1CheckCallRaiseChance=street1CheckCallRaiseChance+%s, 

8574 street1CheckCallDone=street1CheckCallDone+%s, 

8575 street1CheckRaiseDone=street1CheckRaiseDone+%s, 

8576 street2CheckCallRaiseChance=street2CheckCallRaiseChance+%s, 

8577 street2CheckCallDone=street2CheckCallDone+%s, 

8578 street2CheckRaiseDone=street2CheckRaiseDone+%s, 

8579 street3CheckCallRaiseChance=street3CheckCallRaiseChance+%s, 

8580 street3CheckCallDone=street3CheckCallDone+%s, 

8581 street3CheckRaiseDone=street3CheckRaiseDone+%s, 

8582 street4CheckCallRaiseChance=street4CheckCallRaiseChance+%s, 

8583 street4CheckCallDone=street4CheckCallDone+%s, 

8584 street4CheckRaiseDone=street4CheckRaiseDone+%s, 

8585 street0Calls=street0Calls+%s, 

8586 street1Calls=street1Calls+%s, 

8587 street2Calls=street2Calls+%s, 

8588 street3Calls=street3Calls+%s, 

8589 street4Calls=street4Calls+%s, 

8590 street0Bets=street0Bets+%s,  

8591 street1Bets=street1Bets+%s, 

8592 street2Bets=street2Bets+%s,  

8593 street3Bets=street3Bets+%s, 

8594 street4Bets=street4Bets+%s,  

8595 street0Raises=street0Raises+%s, 

8596 street1Raises=street1Raises+%s, 

8597 street2Raises=street2Raises+%s, 

8598 street3Raises=street3Raises+%s, 

8599 street4Raises=street4Raises+%s, 

8600 street1Discards=street1Discards+%s, 

8601 street2Discards=street2Discards+%s, 

8602 street3Discards=street3Discards+%s 

8603 WHERE id=%s""" 

8604 

8605 self.query['update_TC'] = """ 

8606 UPDATE TourneysCache SET 

8607 <UPDATE> 

8608 n=n+%s, 

8609 street0VPIChance=street0VPIChance+%s, 

8610 street0VPI=street0VPI+%s, 

8611 street0AggrChance=street0AggrChance+%s, 

8612 street0Aggr=street0Aggr+%s, 

8613 street0CalledRaiseChance=street0CalledRaiseChance+%s, 

8614 street0CalledRaiseDone=street0CalledRaiseDone+%s, 

8615 street0_2BChance=street0_2BChance+%s, 

8616 street0_2BDone=street0_2BDone+%s, 

8617 street0_3BChance=street0_3BChance+%s, 

8618 street0_3BDone=street0_3BDone+%s, 

8619 street0_4BChance=street0_4BChance+%s, 

8620 street0_4BDone=street0_4BDone+%s, 

8621 street0_C4BChance=street0_C4BChance+%s, 

8622 street0_C4BDone=street0_C4BDone+%s, 

8623 street0_FoldTo2BChance=street0_FoldTo2BChance+%s, 

8624 street0_FoldTo2BDone=street0_FoldTo2BDone+%s, 

8625 street0_FoldTo3BChance=street0_FoldTo3BChance+%s, 

8626 street0_FoldTo3BDone=street0_FoldTo3BDone+%s, 

8627 street0_FoldTo4BChance=street0_FoldTo4BChance+%s, 

8628 street0_FoldTo4BDone=street0_FoldTo4BDone+%s, 

8629 street0_SqueezeChance=street0_SqueezeChance+%s, 

8630 street0_SqueezeDone=street0_SqueezeDone+%s, 

8631 raiseToStealChance=raiseToStealChance+%s, 

8632 raiseToStealDone=raiseToStealDone+%s, 

8633 stealChance=stealChance+%s, 

8634 stealDone=stealDone+%s, 

8635 success_Steal=success_Steal+%s, 

8636 street1Seen=street1Seen+%s, 

8637 street2Seen=street2Seen+%s, 

8638 street3Seen=street3Seen+%s, 

8639 street4Seen=street4Seen+%s, 

8640 sawShowdown=sawShowdown+%s, 

8641 street1Aggr=street1Aggr+%s, 

8642 street2Aggr=street2Aggr+%s, 

8643 street3Aggr=street3Aggr+%s, 

8644 street4Aggr=street4Aggr+%s, 

8645 otherRaisedStreet0=otherRaisedStreet0+%s, 

8646 otherRaisedStreet1=otherRaisedStreet1+%s, 

8647 otherRaisedStreet2=otherRaisedStreet2+%s, 

8648 otherRaisedStreet3=otherRaisedStreet3+%s, 

8649 otherRaisedStreet4=otherRaisedStreet4+%s, 

8650 foldToOtherRaisedStreet0=foldToOtherRaisedStreet0+%s, 

8651 foldToOtherRaisedStreet1=foldToOtherRaisedStreet1+%s, 

8652 foldToOtherRaisedStreet2=foldToOtherRaisedStreet2+%s, 

8653 foldToOtherRaisedStreet3=foldToOtherRaisedStreet3+%s, 

8654 foldToOtherRaisedStreet4=foldToOtherRaisedStreet4+%s, 

8655 wonWhenSeenStreet1=wonWhenSeenStreet1+%s, 

8656 wonWhenSeenStreet2=wonWhenSeenStreet2+%s, 

8657 wonWhenSeenStreet3=wonWhenSeenStreet3+%s, 

8658 wonWhenSeenStreet4=wonWhenSeenStreet4+%s, 

8659 wonAtSD=wonAtSD+%s, 

8660 raiseFirstInChance=raiseFirstInChance+%s, 

8661 raisedFirstIn=raisedFirstIn+%s, 

8662 foldBbToStealChance=foldBbToStealChance+%s, 

8663 foldedBbToSteal=foldedBbToSteal+%s, 

8664 foldSbToStealChance=foldSbToStealChance+%s, 

8665 foldedSbToSteal=foldedSbToSteal+%s, 

8666 street1CBChance=street1CBChance+%s, 

8667 street1CBDone=street1CBDone+%s, 

8668 street2CBChance=street2CBChance+%s, 

8669 street2CBDone=street2CBDone+%s, 

8670 street3CBChance=street3CBChance+%s, 

8671 street3CBDone=street3CBDone+%s, 

8672 street4CBChance=street4CBChance+%s, 

8673 street4CBDone=street4CBDone+%s, 

8674 foldToStreet1CBChance=foldToStreet1CBChance+%s, 

8675 foldToStreet1CBDone=foldToStreet1CBDone+%s, 

8676 foldToStreet2CBChance=foldToStreet2CBChance+%s, 

8677 foldToStreet2CBDone=foldToStreet2CBDone+%s, 

8678 foldToStreet3CBChance=foldToStreet3CBChance+%s, 

8679 foldToStreet3CBDone=foldToStreet3CBDone+%s, 

8680 foldToStreet4CBChance=foldToStreet4CBChance+%s, 

8681 foldToStreet4CBDone=foldToStreet4CBDone+%s, 

8682 common=common+%s, 

8683 committed=committed+%s, 

8684 winnings=winnings+%s, 

8685 rake=rake+%s, 

8686 rakeDealt=rakeDealt+%s, 

8687 rakeContributed=rakeContributed+%s, 

8688 rakeWeighted=rakeWeighted+%s, 

8689 totalProfit=totalProfit+%s, 

8690 allInEV=allInEV+%s, 

8691 showdownWinnings=showdownWinnings+%s, 

8692 nonShowdownWinnings=nonShowdownWinnings+%s, 

8693 street1CheckCallRaiseChance=street1CheckCallRaiseChance+%s, 

8694 street1CheckCallDone=street1CheckCallDone+%s, 

8695 street1CheckRaiseDone=street1CheckRaiseDone+%s, 

8696 street2CheckCallRaiseChance=street2CheckCallRaiseChance+%s, 

8697 street2CheckCallDone=street2CheckCallDone+%s, 

8698 street2CheckRaiseDone=street2CheckRaiseDone+%s, 

8699 street3CheckCallRaiseChance=street3CheckCallRaiseChance+%s, 

8700 street3CheckCallDone=street3CheckCallDone+%s, 

8701 street3CheckRaiseDone=street3CheckRaiseDone+%s, 

8702 street4CheckCallRaiseChance=street4CheckCallRaiseChance+%s, 

8703 street4CheckCallDone=street4CheckCallDone+%s, 

8704 street4CheckRaiseDone=street4CheckRaiseDone+%s, 

8705 street0Calls=street0Calls+%s, 

8706 street1Calls=street1Calls+%s, 

8707 street2Calls=street2Calls+%s, 

8708 street3Calls=street3Calls+%s, 

8709 street4Calls=street4Calls+%s, 

8710 street0Bets=street0Bets+%s,  

8711 street1Bets=street1Bets+%s, 

8712 street2Bets=street2Bets+%s,  

8713 street3Bets=street3Bets+%s, 

8714 street4Bets=street4Bets+%s,  

8715 street0Raises=street0Raises+%s, 

8716 street1Raises=street1Raises+%s, 

8717 street2Raises=street2Raises+%s, 

8718 street3Raises=street3Raises+%s, 

8719 street4Raises=street4Raises+%s, 

8720 street1Discards=street1Discards+%s, 

8721 street2Discards=street2Discards+%s, 

8722 street3Discards=street3Discards+%s 

8723 WHERE tourneyId=%s 

8724 AND playerId=%s""" 

8725 

8726 #################################### 

8727 # delete 

8728 #################################### 

8729 

8730 self.query['delete_S'] = """ 

8731 DELETE FROM Sessions 

8732 WHERE id=%s""" 

8733 

8734 self.query['delete_SC'] = """ 

8735 DELETE FROM SessionsCache 

8736 WHERE id=%s""" 

8737 

8738 #################################### 

8739 # update SessionsCache, Hands, Tourneys 

8740 #################################### 

8741 

8742 self.query['update_S_SC'] = """ 

8743 UPDATE SessionsCache SET 

8744 sessionId=%s 

8745 WHERE sessionId=%s""" 

8746 

8747 self.query['update_S_TC'] = """ 

8748 UPDATE TourneysCache SET 

8749 sessionId=%s 

8750 WHERE sessionId=%s""" 

8751 

8752 self.query['update_S_T'] = """ 

8753 UPDATE Tourneys SET 

8754 sessionId=%s 

8755 WHERE sessionId=%s""" 

8756 

8757 self.query['update_S_H'] = """ 

8758 UPDATE Hands SET 

8759 sessionId=%s 

8760 WHERE sessionId=%s""" 

8761 

8762 #################################### 

8763 # update Tourneys w. sessionIds, hands, start/end 

8764 #################################### 

8765 

8766 self.query['updateTourneysSessions'] = """ 

8767 UPDATE Tourneys SET 

8768 sessionId=%s 

8769 WHERE id=%s""" 

8770 

8771 #################################### 

8772 # Database management queries 

8773 #################################### 

8774 

8775 if db_server == 'mysql': 

8776 self.query['analyze'] = """ 

8777 analyze table Actions, Autorates, Backings, Boards, Files, Gametypes, Hands, HandsActions, HandsPlayers,  

8778 HandsStove, HudCache, Players, RawHands, RawTourneys, Sessions, Settings, Sites, 

8779 Tourneys, TourneysPlayers, TourneyTypes 

8780 """ 

8781 elif db_server == 'postgresql': 

8782 self.query['analyze'] = "analyze" 

8783 elif db_server == 'sqlite': 

8784 self.query['analyze'] = "analyze" 

8785 

8786 

8787 if db_server == 'mysql': 

8788 self.query['vacuum'] = """ 

8789 optimize table Actions, Autorates, Backings, Boards, Files, Gametypes, Hands, HandsActions, HandsPlayers,  

8790 HandsStove, HudCache, Players, RawHands, RawTourneys, Sessions, Settings, Sites, 

8791 Tourneys, TourneysPlayers, TourneyTypes 

8792 """ 

8793 elif db_server == 'postgresql': 

8794 self.query['vacuum'] = """ vacuum """ 

8795 elif db_server == 'sqlite': 

8796 self.query['vacuum'] = """ vacuum """ 

8797 

8798 if db_server == 'mysql': 

8799 self.query['switchLockOn'] = """ 

8800 UPDATE InsertLock k1,  

8801 (SELECT count(locked) as locks FROM InsertLock WHERE locked=True) as k2 SET 

8802 k1.locked=%s 

8803 WHERE k1.id=%s 

8804 AND k2.locks = 0""" 

8805 

8806 if db_server == 'mysql': 

8807 self.query['switchLockOff'] = """ 

8808 UPDATE InsertLock SET 

8809 locked=%s 

8810 WHERE id=%s""" 

8811 

8812 if db_server == 'mysql': 

8813 self.query['lockForInsert'] = """ 

8814 lock tables Hands write, HandsPlayers write, HandsActions write, Players write 

8815 , HudCache write, Gametypes write, Sites write, Tourneys write 

8816 , TourneysPlayers write, TourneyTypes write, Autorates write 

8817 """ 

8818 elif db_server == 'postgresql': 

8819 self.query['lockForInsert'] = "" 

8820 elif db_server == 'sqlite': 

8821 self.query['lockForInsert'] = "" 

8822 

8823 self.query['getGametypeFL'] = """SELECT id 

8824 FROM Gametypes 

8825 WHERE siteId=%s 

8826 AND type=%s 

8827 AND category=%s 

8828 AND limitType=%s 

8829 AND smallBet=%s 

8830 AND bigBet=%s 

8831 AND maxSeats=%s 

8832 AND ante=%s 

8833 """ #TODO: seems odd to have limitType variable in this query 

8834 

8835 self.query['getGametypeNL'] = """SELECT id 

8836 FROM Gametypes 

8837 WHERE siteId=%s 

8838 AND type=%s 

8839 AND category=%s 

8840 AND limitType=%s 

8841 AND currency=%s 

8842 AND mix=%s 

8843 AND smallBlind=%s 

8844 AND bigBlind=%s 

8845 AND maxSeats=%s 

8846 AND ante=%s 

8847 AND buyinType=%s 

8848 AND fast=%s 

8849 AND newToGame=%s 

8850 AND homeGame=%s 

8851 AND split=%s 

8852 """ #TODO: seems odd to have limitType variable in this query 

8853 

8854 self.query['insertGameTypes'] = """insert into Gametypes (siteId, currency, type, base, category, limitType, hiLo, mix,  

8855 smallBlind, bigBlind, smallBet, bigBet, maxSeats, ante, buyinType, fast, newToGame, homeGame, split) 

8856 values (%s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s)""" 

8857 

8858 self.query['isAlreadyInDB'] = """SELECT H.id FROM Hands H 

8859 INNER JOIN Gametypes G ON (H.gametypeId = G.id) 

8860 WHERE siteHandNo=%s AND G.siteId=%s<heroSeat> 

8861 """ 

8862 

8863 self.query['getTourneyTypeIdByTourneyNo'] = """SELECT tt.id, 

8864 tt.siteId, 

8865 tt.currency, 

8866 tt.buyin, 

8867 tt.fee, 

8868 tt.category, 

8869 tt.limitType, 

8870 tt.maxSeats, 

8871 tt.sng, 

8872 tt.knockout, 

8873 tt.koBounty, 

8874 tt.progressive, 

8875 tt.rebuy, 

8876 tt.rebuyCost, 

8877 tt.addOn, 

8878 tt.addOnCost, 

8879 tt.speed, 

8880 tt.shootout, 

8881 tt.matrix, 

8882 tt.fast, 

8883 tt.stack,  

8884 tt.step, 

8885 tt.stepNo, 

8886 tt.chance, 

8887 tt.chanceCount, 

8888 tt.multiEntry, 

8889 tt.reEntry, 

8890 tt.homeGame, 

8891 tt.newToGame, 

8892 tt.split, 

8893 tt.fifty50, 

8894 tt.time, 

8895 tt.timeAmt, 

8896 tt.satellite, 

8897 tt.doubleOrNothing, 

8898 tt.cashOut, 

8899 tt.onDemand, 

8900 tt.flighted, 

8901 tt.guarantee, 

8902 tt.guaranteeAmt 

8903 FROM TourneyTypes tt  

8904 INNER JOIN Tourneys t ON (t.tourneyTypeId = tt.id)  

8905 WHERE t.siteTourneyNo=%s AND tt.siteId=%s 

8906 """ 

8907 

8908 self.query['getTourneyTypeId'] = """SELECT id 

8909 FROM TourneyTypes 

8910 WHERE siteId=%s 

8911 AND currency=%s 

8912 AND buyin=%s 

8913 AND fee=%s 

8914 AND category=%s 

8915 AND limitType=%s 

8916 AND maxSeats=%s 

8917 AND sng=%s 

8918 AND knockout=%s 

8919 AND koBounty=%s 

8920 AND progressive=%s 

8921 AND rebuy=%s 

8922 AND rebuyCost=%s 

8923 AND addOn=%s 

8924 AND addOnCost=%s 

8925 AND speed=%s 

8926 AND shootout=%s 

8927 AND matrix=%s 

8928 AND fast=%s 

8929 AND stack=%s 

8930 AND step=%s 

8931 AND stepNo=%s 

8932 AND chance=%s 

8933 AND chanceCount=%s 

8934 AND multiEntry=%s 

8935 AND reEntry=%s 

8936 AND homeGame=%s 

8937 AND newToGame=%s 

8938 AND split=%s 

8939 AND fifty50=%s 

8940 AND time=%s 

8941 AND timeAmt=%s 

8942 AND satellite=%s 

8943 AND doubleOrNothing=%s 

8944 AND cashOut=%s 

8945 AND onDemand=%s 

8946 AND flighted=%s 

8947 AND guarantee=%s 

8948 AND guaranteeAmt=%s 

8949 """ 

8950 

8951 self.query['insertTourneyType'] = """insert into TourneyTypes ( 

8952 siteId, currency, buyin, fee, category, limitType, maxSeats, sng, knockout, koBounty, progressive, 

8953 rebuy, rebuyCost, addOn, addOnCost, speed, shootout, matrix, fast, 

8954 stack, step, stepNo, chance, chanceCount, multiEntry, reEntry, homeGame, newToGame, split, 

8955 fifty50, time, timeAmt, satellite, doubleOrNothing, cashOut, onDemand, flighted, guarantee, guaranteeAmt 

8956 ) 

8957 values (%s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, 

8958 %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s) 

8959 """ 

8960 

8961 if db_server == 'sqlite': 

8962 self.query['updateTourneyTypeId'] = """UPDATE Tourneys 

8963 SET tourneyTypeId = %s 

8964 WHERE tourneyTypeId in (SELECT id FROM TourneyTypes WHERE siteId=%s) 

8965 AND siteTourneyNo=%s 

8966 """ 

8967 elif db_server == 'postgresql': 

8968 self.query['updateTourneyTypeId'] = """UPDATE Tourneys t  

8969 SET tourneyTypeId = %s 

8970 FROM TourneyTypes tt  

8971 WHERE t.tourneyTypeId = tt.id 

8972 AND tt.siteId=%s  

8973 AND t.siteTourneyNo=%s 

8974 """ 

8975 else: 

8976 self.query['updateTourneyTypeId'] = """UPDATE Tourneys t INNER JOIN TourneyTypes tt ON (t.tourneyTypeId = tt.id) 

8977 SET tourneyTypeId = %s 

8978 WHERE tt.siteId=%s AND t.siteTourneyNo=%s 

8979 """ 

8980 

8981 self.query['selectTourneyWithTypeId'] = """SELECT id  

8982 FROM Tourneys 

8983 WHERE tourneyTypeId = %s 

8984 """ 

8985 

8986 self.query['deleteTourneyTypeId'] = """DELETE FROM TourneyTypes WHERE id = %s 

8987 """ 

8988 

8989 self.query['getTourneyByTourneyNo'] = """SELECT t.* 

8990 FROM Tourneys t 

8991 INNER JOIN TourneyTypes tt ON (t.tourneyTypeId = tt.id) 

8992 WHERE tt.siteId=%s AND t.siteTourneyNo=%s 

8993 """ 

8994 

8995 self.query['getTourneyInfo'] = """SELECT tt.*, t.* 

8996 FROM Tourneys t 

8997 INNER JOIN TourneyTypes tt ON (t.tourneyTypeId = tt.id) 

8998 INNER JOIN Sites s ON (tt.siteId = s.id) 

8999 WHERE s.name=%s AND t.siteTourneyNo=%s 

9000 """ 

9001 

9002 self.query['getSiteTourneyNos'] = """SELECT t.siteTourneyNo 

9003 FROM Tourneys t 

9004 INNER JOIN TourneyTypes tt ON (t.tourneyTypeId = tt.id) 

9005 INNER JOIN Sites s ON (tt.siteId = s.id) 

9006 WHERE tt.siteId=%s 

9007 """ 

9008 

9009 self.query['getTourneyPlayerInfo'] = """SELECT tp.* 

9010 FROM Tourneys t 

9011 INNER JOIN TourneyTypes tt ON (t.tourneyTypeId = tt.id) 

9012 INNER JOIN Sites s ON (tt.siteId = s.id) 

9013 INNER JOIN TourneysPlayers tp ON (tp.tourneyId = t.id) 

9014 INNER JOIN Players p ON (p.id = tp.playerId) 

9015 WHERE s.name=%s AND t.siteTourneyNo=%s AND p.name=%s 

9016 """ 

9017 

9018 self.query['insertTourney'] = """insert into Tourneys ( 

9019 tourneyTypeId, sessionId, siteTourneyNo, entries, prizepool, 

9020 startTime, endTime, tourneyName, totalRebuyCount, totalAddOnCount, 

9021 comment, commentTs, added, addedCurrency) 

9022 values (%s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s) 

9023 """ 

9024 

9025 self.query['updateTourney'] = """UPDATE Tourneys 

9026 SET entries = %s, 

9027 prizepool = %s, 

9028 startTime = %s, 

9029 endTime = %s, 

9030 tourneyName = %s, 

9031 totalRebuyCount = %s, 

9032 totalAddOnCount = %s, 

9033 comment = %s, 

9034 commentTs = %s, 

9035 added = %s, 

9036 addedCurrency = %s 

9037 WHERE id=%s 

9038 """ 

9039 

9040 self.query['updateTourneyStart'] = """UPDATE Tourneys 

9041 SET startTime = %s 

9042 WHERE id=%s 

9043 """ 

9044 

9045 self.query['updateTourneyEnd'] = """UPDATE Tourneys 

9046 SET endTime = %s 

9047 WHERE id=%s 

9048 """ 

9049 

9050 self.query['getTourneysPlayersByIds'] = """SELECT * 

9051 FROM TourneysPlayers 

9052 WHERE tourneyId=%s AND playerId=%s AND entryId=%s 

9053 """ 

9054 

9055 self.query['getTourneysPlayersByTourney'] = """SELECT playerId, entryId 

9056 FROM TourneysPlayers 

9057 WHERE tourneyId=%s 

9058 """ 

9059 

9060 self.query['updateTourneysPlayer'] = """UPDATE TourneysPlayers 

9061 SET rank = %s, 

9062 winnings = %s, 

9063 winningsCurrency = %s, 

9064 rebuyCount = %s, 

9065 addOnCount = %s, 

9066 koCount = %s 

9067 WHERE id=%s 

9068 """ 

9069 

9070 self.query['updateTourneysPlayerBounties'] = """UPDATE TourneysPlayers 

9071 SET koCount = case when koCount is null then %s else koCount+%s end 

9072 WHERE id=%s 

9073 """ 

9074 

9075 self.query['insertTourneysPlayer'] = """insert into TourneysPlayers ( 

9076 tourneyId, 

9077 playerId, 

9078 entryId, 

9079 rank, 

9080 winnings, 

9081 winningsCurrency, 

9082 rebuyCount, 

9083 addOnCount, 

9084 koCount 

9085 ) 

9086 values (%s, %s, %s, %s, %s,  

9087 %s, %s, %s, %s) 

9088 """ 

9089 

9090 self.query['selectHandsPlayersWithWrongTTypeId'] = """SELECT id 

9091 FROM HandsPlayers  

9092 WHERE tourneyTypeId <> %s AND (TourneysPlayersId+0=%s) 

9093 """ 

9094 

9095# self.query['updateHandsPlayersForTTypeId2'] = """UPDATE HandsPlayers  

9096# SET tourneyTypeId= %s 

9097# WHERE (TourneysPlayersId+0=%s) 

9098# """ 

9099 

9100 self.query['updateHandsPlayersForTTypeId'] = """UPDATE HandsPlayers  

9101 SET tourneyTypeId= %s 

9102 WHERE (id=%s) 

9103 """ 

9104 

9105 

9106 self.query['handsPlayersTTypeId_joiner'] = " OR TourneysPlayersId+0=" 

9107 self.query['handsPlayersTTypeId_joiner_id'] = " OR id=" 

9108 

9109 self.query['store_hand'] = """insert into Hands ( 

9110 tablename, 

9111 sitehandno, 

9112 tourneyId, 

9113 gametypeid, 

9114 sessionId, 

9115 fileId, 

9116 startTime, 

9117 importtime, 

9118 seats, 

9119 heroSeat, 

9120 maxPosition, 

9121 texture, 

9122 playersVpi, 

9123 boardcard1, 

9124 boardcard2, 

9125 boardcard3, 

9126 boardcard4, 

9127 boardcard5, 

9128 runItTwice, 

9129 playersAtStreet1, 

9130 playersAtStreet2, 

9131 playersAtStreet3, 

9132 playersAtStreet4, 

9133 playersAtShowdown, 

9134 street0Raises, 

9135 street1Raises, 

9136 street2Raises, 

9137 street3Raises, 

9138 street4Raises, 

9139 street0Pot, 

9140 street1Pot, 

9141 street2Pot, 

9142 street3Pot, 

9143 street4Pot, 

9144 finalPot 

9145 ) 

9146 values 

9147 (%s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, 

9148 %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, 

9149 %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, %s, 

9150 %s, %s)""" 

9151 

9152 

9153 self.query['store_hands_players'] = """insert into HandsPlayers ( 

9154 handId, 

9155 playerId, 

9156 startCash, 

9157 effStack, 

9158 startBounty, 

9159 endBounty, 

9160 seatNo, 

9161 sitout, 

9162 card1, 

9163 card2, 

9164 card3, 

9165 card4, 

9166 card5, 

9167 card6, 

9168 card7, 

9169 card8, 

9170 card9, 

9171 card10, 

9172 card11, 

9173 card12, 

9174 card13, 

9175 card14, 

9176 card15, 

9177 card16, 

9178 card17, 

9179 card18, 

9180 card19, 

9181 card20, 

9182 common, 

9183 committed, 

9184 winnings, 

9185 rake, 

9186 rakeDealt, 

9187 rakeContributed, 

9188 rakeWeighted, 

9189 totalProfit, 

9190 allInEV, 

9191 street0VPIChance, 

9192 street0VPI, 

9193 street1Seen, 

9194 street2Seen, 

9195 street3Seen, 

9196 street4Seen, 

9197 sawShowdown, 

9198 showed, 

9199 street0AllIn, 

9200 street1AllIn, 

9201 street2AllIn, 

9202 street3AllIn, 

9203 street4AllIn, 

9204 wentAllIn, 

9205 street0AggrChance, 

9206 street0Aggr, 

9207 street1Aggr, 

9208 street2Aggr, 

9209 street3Aggr, 

9210 street4Aggr, 

9211 street1CBChance, 

9212 street2CBChance, 

9213 street3CBChance, 

9214 street4CBChance, 

9215 street1CBDone, 

9216 street2CBDone, 

9217 street3CBDone, 

9218 street4CBDone, 

9219 wonWhenSeenStreet1, 

9220 wonWhenSeenStreet2, 

9221 wonWhenSeenStreet3, 

9222 wonWhenSeenStreet4, 

9223 wonAtSD, 

9224 position, 

9225 street0InPosition, 

9226 street1InPosition, 

9227 street2InPosition, 

9228 street3InPosition, 

9229 street4InPosition, 

9230 street0FirstToAct, 

9231 street1FirstToAct, 

9232 street2FirstToAct, 

9233 street3FirstToAct, 

9234 street4FirstToAct, 

9235 tourneysPlayersId, 

9236 startCards, 

9237 street0CalledRaiseChance, 

9238 street0CalledRaiseDone, 

9239 street0_2BChance, 

9240 street0_2BDone, 

9241 street0_3BChance, 

9242 street0_3BDone, 

9243 street0_4BChance, 

9244 street0_4BDone, 

9245 street0_C4BChance, 

9246 street0_C4BDone, 

9247 street0_FoldTo2BChance, 

9248 street0_FoldTo2BDone, 

9249 street0_FoldTo3BChance, 

9250 street0_FoldTo3BDone, 

9251 street0_FoldTo4BChance, 

9252 street0_FoldTo4BDone, 

9253 street0_SqueezeChance, 

9254 street0_SqueezeDone, 

9255 raiseToStealChance, 

9256 raiseToStealDone, 

9257 stealChance, 

9258 stealDone, 

9259 success_Steal, 

9260 otherRaisedStreet0, 

9261 otherRaisedStreet1, 

9262 otherRaisedStreet2, 

9263 otherRaisedStreet3, 

9264 otherRaisedStreet4, 

9265 foldToOtherRaisedStreet0, 

9266 foldToOtherRaisedStreet1, 

9267 foldToOtherRaisedStreet2, 

9268 foldToOtherRaisedStreet3, 

9269 foldToOtherRaisedStreet4, 

9270 raiseFirstInChance, 

9271 raisedFirstIn, 

9272 foldBbToStealChance, 

9273 foldedBbToSteal, 

9274 foldSbToStealChance, 

9275 foldedSbToSteal, 

9276 foldToStreet1CBChance, 

9277 foldToStreet1CBDone, 

9278 foldToStreet2CBChance, 

9279 foldToStreet2CBDone, 

9280 foldToStreet3CBChance, 

9281 foldToStreet3CBDone, 

9282 foldToStreet4CBChance, 

9283 foldToStreet4CBDone, 

9284 street1CheckCallRaiseChance, 

9285 street1CheckCallDone, 

9286 street1CheckRaiseDone, 

9287 street2CheckCallRaiseChance, 

9288 street2CheckCallDone, 

9289 street2CheckRaiseDone, 

9290 street3CheckCallRaiseChance, 

9291 street3CheckCallDone, 

9292 street3CheckRaiseDone, 

9293 street4CheckCallRaiseChance, 

9294 street4CheckCallDone, 

9295 street4CheckRaiseDone, 

9296 street0Calls, 

9297 street1Calls, 

9298 street2Calls, 

9299 street3Calls, 

9300 street4Calls, 

9301 street0Bets, 

9302 street1Bets, 

9303 street2Bets, 

9304 street3Bets, 

9305 street4Bets, 

9306 street0Raises, 

9307 street1Raises, 

9308 street2Raises, 

9309 street3Raises, 

9310 street4Raises, 

9311 street1Discards, 

9312 street2Discards, 

9313 street3Discards, 

9314 handString 

9315 ) 

9316 values ( 

9317 %s, %s, %s, %s, %s, 

9318 %s, %s, %s, %s, %s, 

9319 %s, %s, %s, %s, %s, 

9320 %s, %s, %s, %s, %s, 

9321 %s, %s, %s, %s, %s, 

9322 %s, %s, %s, %s, %s, 

9323 %s, %s, %s, %s, %s, 

9324 %s, %s, %s, %s, %s, 

9325 %s, %s, %s, %s, %s, 

9326 %s, %s, %s, %s, %s, 

9327 %s, %s, %s, %s, %s, 

9328 %s, %s, %s, %s, %s, 

9329 %s, %s, %s, %s, %s, 

9330 %s, %s, %s, %s, %s, 

9331 %s, %s, %s, %s, %s, 

9332 %s, %s, %s, %s, %s, 

9333 %s, %s, %s, %s, %s, 

9334 %s, %s, %s, %s, %s, 

9335 %s, %s, %s, %s, %s, 

9336 %s, %s, %s, %s, %s, 

9337 %s, %s, %s, %s, %s, 

9338 %s, %s, %s, %s, %s, 

9339 %s, %s, %s, %s, %s, 

9340 %s, %s, %s, %s, %s, 

9341 %s, %s, %s, %s, %s, 

9342 %s, %s, %s, %s, %s, 

9343 %s, %s, %s, %s, %s, 

9344 %s, %s, %s, %s, %s, 

9345 %s, %s, %s, %s, %s, 

9346 %s, %s, %s, %s, %s, 

9347 %s, %s, %s, %s, %s, 

9348 %s, %s, %s, %s, %s, 

9349 %s 

9350 )""" 

9351 

9352 self.query['store_hands_actions'] = """insert into HandsActions ( 

9353 handId, 

9354 playerId, 

9355 street, 

9356 actionNo, 

9357 streetActionNo, 

9358 actionId, 

9359 amount, 

9360 raiseTo, 

9361 amountCalled, 

9362 numDiscarded, 

9363 cardsDiscarded, 

9364 allIn 

9365 ) 

9366 values ( 

9367 %s, %s, %s, %s, %s, 

9368 %s, %s, %s, %s, %s, 

9369 %s, %s 

9370 )""" 

9371 

9372 self.query['store_hands_stove'] = """insert into HandsStove ( 

9373 handId, 

9374 playerId, 

9375 streetId, 

9376 boardId, 

9377 hiLo, 

9378 rankId, 

9379 value, 

9380 cards, 

9381 ev 

9382 ) 

9383 values ( 

9384 %s, %s, %s, %s, %s, 

9385 %s, %s, %s, %s 

9386 )""" 

9387 

9388 self.query['store_boards'] = """insert into Boards ( 

9389 handId, 

9390 boardId, 

9391 boardcard1, 

9392 boardcard2, 

9393 boardcard3, 

9394 boardcard4, 

9395 boardcard5 

9396 ) 

9397 values ( 

9398 %s, %s, %s, %s, %s, 

9399 %s, %s 

9400 )""" 

9401 

9402 self.query['store_hands_pots'] = """insert into HandsPots ( 

9403 handId, 

9404 potId, 

9405 boardId, 

9406 hiLo, 

9407 playerId, 

9408 pot, 

9409 collected, 

9410 rake 

9411 ) 

9412 values ( 

9413 %s, %s, %s, %s, 

9414 %s, %s, %s, %s 

9415 )""" 

9416 

9417 ################################ 

9418 # queries for Files Table 

9419 ################################ 

9420 

9421 self.query['get_id'] = """ 

9422 SELECT id 

9423 FROM Files 

9424 WHERE file=%s""" 

9425 

9426 self.query['store_file'] = """ insert into Files ( 

9427 file, 

9428 site, 

9429 startTime, 

9430 lastUpdate, 

9431 hands, 

9432 storedHands, 

9433 dups, 

9434 partial, 

9435 skipped, 

9436 errs, 

9437 ttime100, 

9438 finished) 

9439 values ( 

9440 %s, %s, %s, %s, %s, 

9441 %s, %s, %s, %s, %s, 

9442 %s, %s 

9443 )""" 

9444 

9445 self.query['update_file'] = """ 

9446 UPDATE Files SET 

9447 type=%s, 

9448 lastUpdate=%s, 

9449 endTime=%s, 

9450 hands=hands+%s, 

9451 storedHands=storedHands+%s, 

9452 dups=dups+%s, 

9453 partial=partial+%s, 

9454 skipped=skipped+%s, 

9455 errs=errs+%s, 

9456 ttime100=ttime100+%s, 

9457 finished=%s 

9458 WHERE id=%s""" 

9459 

9460 ################################ 

9461 # Counts for DB stats window 

9462 ################################ 

9463 self.query['getHandCount'] = "SELECT COUNT(*) FROM Hands" 

9464 self.query['getTourneyCount'] = "SELECT COUNT(*) FROM Tourneys" 

9465 self.query['getTourneyTypeCount'] = "SELECT COUNT(*) FROM TourneyTypes" 

9466 

9467 ################################ 

9468 # queries for dumpDatabase 

9469 ################################ 

9470 for table in (u'Autorates', u'Backings', u'Gametypes', u'Hands', u'HandsActions', u'HandsPlayers', u'HudCache', u'Players', u'RawHands', u'RawTourneys', u'Settings', u'Sites', u'TourneyTypes', u'Tourneys', u'TourneysPlayers'): 

9471 self.query['get' + table] = u"SELECT * FROM " + table 

9472 

9473 ################################ 

9474 # placeholders and substitution stuff 

9475 ################################ 

9476 if db_server == 'mysql': 

9477 self.query['placeholder'] = u'%s' 

9478 elif db_server == 'postgresql': 

9479 self.query['placeholder'] = u'%s' 

9480 elif db_server == 'sqlite': 

9481 self.query['placeholder'] = u'?' 

9482 

9483 

9484 # If using sqlite, use the ? placeholder instead of %s 

9485 if db_server == 'sqlite': 

9486 for k, q in list(self.query.items()): 

9487 self.query[k] = re.sub('%s', '?', q) 

9488 

9489if __name__ == "__main__": 

9490# just print the default queries and exit 

9491 s = Sql() 

9492 for key in s.query: 

9493 print("For query " + key + ", sql =") 

9494 print(s.query[key])