是自动的,但是好象interbase的sql语法不标准 >:(

解决方案 »

  1.   

    应该不是自动的,当我未用commit提交时,修改的数据其他程序看不见
      

  2.   

    还是oracle好用,用那麽多例程,被DELPHI 5的INTERBASE控件组给迷惑了
      

  3.   

    不能在过程里面写commit,但是可以用一个exception来发一个例外,自动rollback
      

  4.   

    我不知道oracle怎么工作,但我知道Interbase内部不能Commit是合理的,因为
    事务是外部的,在内部怎么可以提交外部的事务呢?我认为Execute Procedure
    ...然后Transaction.Commit没有什么不便呀?
      

  5.   

    我不明白事务有什麽内部与外部之分(好像没这种分法吧?DBMS与用户?)也许存储过程中不一定要提交所有对数据库的修改,我要根据情况提交一部分,而把另一部分修改全部回滚掉(我在编delphi-oracle过程中遇到过几次),这样interbase是不是很不方便,当然也可以用更麻烦的方法实现.INTERBASE中真的不能COMMIT吗??
      

  6.   

    我映象中的事务根本没有内部这一说。事务是与数据库平级的一个对象,一个事
    务可以包括多个数据库,一个数据库也可以隶属于多个事务。但是存贮过程却是
    内部的,没听说存贮过程中访问别的数据库吧?我根本想象不出来如何在数据库
    内部提交事务。难道Oracle可以吗?
      

  7.   

    CKEN老弟:看来是我错了!InterBase果然有内部事务!
    如果要将部分内容提交数据库,可以在准备提交前使用
    Set Transaction MyTransaction;
    数据更新完成后运行:
    Commit Transaction MyTransaction;祝成功!顺便拜个旱年!