clarified commented transactional apply

This commit is contained in:
Shlomi Noach 2016-08-17 10:50:41 +02:00
parent 16d76aa299
commit 3a0ee9b4a5
2 changed files with 26 additions and 1 deletions

View File

@ -2,7 +2,7 @@
# #
# #
RELEASE_VERSION="1.0.9" RELEASE_VERSION="1.0.10"
function build { function build {
osname=$1 osname=$1

View File

@ -853,6 +853,31 @@ func (this *Applier) ApplyDMLEventQuery(dmlEvent *binlog.BinlogDMLEvent) error {
if err != nil { if err != nil {
return err return err
} }
// TODO The below is commented, and is in preparation for transactional writes on the ghost tables.
// Such writes would be, for example:
// - prepended with sql_mode setup
// - prepended with SET SQL_LOG_BIN=0
// - prepended with SET FK_CHECKS=0
// etc.
//
// Current known problem: https://github.com/golang/go/issues/9373 -- bitint unsigned values, not supported in database/sql
//
// err = func() error {
// tx, err := this.db.Begin()
// if err != nil {
// return err
// }
// if _, err := tx.Exec(query, args...); err != nil {
// return err
// }
// if err := tx.Commit(); err != nil {
// return err
// }
// return nil
// }()
_, err = sqlutils.Exec(this.db, query, args...) _, err = sqlutils.Exec(this.db, query, args...)
if err == nil { if err == nil {
atomic.AddInt64(&this.migrationContext.TotalDMLEventsApplied, 1) atomic.AddInt64(&this.migrationContext.TotalDMLEventsApplied, 1)