取引


YMPv2.0 の新機能に基づいて、JDBC モジュールはデータベース トランザクションをより柔軟に処理できます。クラス オブジェクト マネージャーによって管理されるオブジェクトは、

  • @Transaction アノテーションを通じてトランザクションをサポートできます。

      パラメータの説明:
    • 値: トランザクション タイプ (JDBC トランザクション タイプを参照)、デフォルトは JDBC.TRANSACTION.READ_COMMITTED です。

    • 使用法:
    • まず、データベース トランザクション サポートを必要とするクラス オブジェクトを宣言する必要があります。 @Transaction アノテーション ;

      次に、特にトランザクション処理を有効にする必要があるクラス メソッドに @Transaction アノテーションを追加します。

  • トランザクション サンプル コード:
  • public interface IUserService {
    
        User doGetUser(String username, String pwd);
    
        boolean doLogin(String username, String pwd);
    }
    
    @Bean
    @Transaction
    public class UserService implements IUserService {
    
        public User doGetUser(final String username, final String pwd) {
            return JDBC.get().openSession(new ISessionExecutor<User>() {
                public User execute(ISession session) throws Exception {
                    Cond _cond = Cond.create().eq("username").param(username).eq("pwd").param(pwd);
                    return session.findFirst(EntitySQL.create(User.class), Where.create(_cond));
                }
            });
        }
    
        @Transaction
        public boolean doLogin(String username, String pwd) {
            User _user = doGetUser(username, pwd);
            if (_user != null) {
                _user.setLastLoginTime(System.currentTimeMillis());
                _user.update();
                //
                return true;
            }
            return false;
        }
    }
    
    @Bean
    public class TransDemo {
    
        @Inject
        private IUserService __userService;
    
        public boolean testTrans() {
            return __userService.doLogin("suninformation", "123456");
        }
    
        public static void main(String[] args) throws Exception {
            YMP.get().init();
            try {
                TransDemo _demo = YMP.get().getBean(TransDemo.class);
                _demo.testTrans();
            } finally {
                YMP.get().destroy();
            }
        }
    }