[ruby-gnome2-doc-cvs] [Hiki] update - tut-libgda-transactions

アーカイブの一覧に戻る

ruby-****@sourc***** ruby-****@sourc*****
2004年 4月 1日 (木) 20:35:51 JST


-------------------------
REMOTE_ADDR = 195.207.101.112
REMOTE_HOST = 
        URL = http://ruby-gnome2.sourceforge.jp/en/?tut-libgda-transactions
-------------------------
  = Managing transactions
+ {{link("tut-libgda-datamodels", nil, "tut-libgda", "tut-libgda-errors")}}
  
  The special methods we need to do this are defined in Gda::Transaction, Gda::Connection and Gda::Command classes, and they are:
  
   * Gda::Transaction.new;
   * Gda::Connection#begin_transaction;
   * Gda::Connection#commit_transaction;
   * Gda::Connection#rollback_transaction;
   * Gda::Command#set_transaction or Gda::Command#transaction=.
  
  
  Things you have to do to manage transactions are:
  
  (1) Create transaction
  (2) Change, if needed, the isolation level
  (3) Link transaction to a connection
  (4) For each command you want to execute:
      (1) Create command
      (2) Link transaction to command
      (3) Execute command
  (5) Commit or rollback transaction
  
  Here you can see an example: 
  
    def process_accounts(conn)
        # Creates first transaction.
        transaction_one = Gda::Transaction.new("accounts1")
        # Changes the isolation level.
        transaction_one.isolation_level = Gda::Transaction::ISOLATION_SERIALIZABLE
        # Links it to connection.
        conn.begin_transaction(transaction_one)
    
        command = Gda::Command.new("UPDATE accounts SET balance=balance+50 WHERE ref_customer=1",
                                   Gda::Command::TYPE_SQL,
                                   Gda::Command::OPTION_STOP_ON_ERRORS)
        # Links command to transaction.
        command.transaction = transaction_one
        conn.execute_non_query(command)
    
        command = Gda::Command.new("UPDATE accounts SET balance=balance-50 WHERE ref_customer=2",
                                   Gda::Command::TYPE_SQL,
                                   Gda::Command::OPTION_STOP_ON_ERRORS)
        command.transaction = transaction_one
        conn.execute_non_query(command)
    
        # Makes commit on transaction.
        conn.commit_transaction(transaction_one)
    
        transaction_two = Gda::Transaction.new("accounts2")
        transaction_two.isolation_level = Gda::Transaction::ISOLATION_SERIALIZABLE
        conn.begin_transaction(transaction_two)
    
        command = Gda::Command.new("UPDATE accounts SET balance=balance+400 WHERE ref_customer=1",
                                   Gda::Command::TYPE_SQL,
                                   Gda::Command::OPTION_STOP_ON_ERRORS)
        command.transaction = transaction_two
        conn.execute_non_query(command)
    
        command = Gda::Command.new("UPDATE accounts SET balance=balance-400 WHERE ref_customer=2",
                                   Gda::Command::TYPE_SQL,
                                   Gda::Command::OPTION_STOP_ON_ERRORS)
        command.transaction = transaction_two
        conn.execute_non_query(command)
    
        # Makes rollback on second transaction.
        conn.rollback_transaction(transaction_two)
    
        execute_sql_command(conn, "SELECT * FROM accounts")
    end





ruby-gnome2-cvs メーリングリストの案内
アーカイブの一覧に戻る