编辑“︁
Refactoring Database Access in Marauroa
”︁(章节)
跳转到导航
跳转到搜索
警告:
您没有登录。如果您进行任何编辑,您的IP地址会公开展示。如果您
登录
或
创建账号
,您的编辑会以您的用户名署名,此外还有其他益处。
反垃圾检查。
不要
加入这个!
== Porting of JMaPacman == The following diff shows the complete list of changes that were required to port JMaPacman. I think it may help you to get a feeling on how to adjust your own code. <!-- Don't use syntax highlighting here because it does not work well with the diff characters and bold formation <source lang="java"> --> public class MaPacmanRPRuleProcessor implements IRPRuleProcessor { public AccountResult createAccount(String username, String password, String email) { - IDatabase database = DatabaseFactory.getDatabase(); + '''TransactionPool transactionPool = TransactionPool.get();''' - Transaction trans = database.getTransaction(); + '''DBTransaction trans = transactionPool.beginWork();''' + '''AccountDAO accountDAO = DAORegister.get().get(AccountDAO.class);''' try { - trans.begin(); - if (database.hasPlayer(trans, username)) { + if ('''accountDAO'''.hasPlayer(trans, username)) { return new AccountResult(Result.FAILED_PLAYER_EXISTS, username); } - database.addPlayer(trans, username, Hash.hash(password), email); + '''accountDAO'''.addPlayer(trans, username, Hash.hash(password), email); - trans.commit(); + '''transactionPool.commit(trans);''' return new AccountResult(Result.OK_CREATED, username); } catch (SQLException e1) { - try { - trans.rollback(); - } catch (SQLException e2) { - //logger.error("Rollback failed: ", e2); - System.out.println("Rollback failed: " + e2); - } + '''transactionPool.rollback(trans);''' return new AccountResult(Result.FAILED_EXCEPTION, username); } } public CharacterResult createCharacter(String username, String character, RPObject tmpl) { - IDatabase database = DatabaseFactory.getDatabase(); + '''TransactionPool transactionPool = TransactionPool.get();''' - Transaction trans = database.getTransaction(); + '''DBTransaction trans = transactionPool.beginWork();''' + CharacterDAO characterDAO = DAORegister.get().get(CharacterDAO.class); try { - trans.begin(); - if (database.hasCharacter(trans, username, character)) { + if ('''characterDAO'''.hasCharacter(trans, username, character)) { return new CharacterResult(Result.FAILED_PLAYER_EXISTS, character, tmpl); } @@ -196,18 +190,13 @@ - database.addCharacter(trans, username, character, object); + '''characterDAO'''.addCharacter(trans, username, character, object); - trans.commit(); + '''transactionPool.commit(trans);''' return new CharacterResult(Result.OK_CREATED, character, object); } catch (Exception e1) { //logger.warn("SQL exception while trying to create a new character: ", e1); - try { - trans.rollback(); - } catch (SQLException e2) { - //logger.error("Rollback failed: ", e2); - System.out.println("Rollback failed: " + e2); - } + '''transactionPool.rollback(trans);''' return new CharacterResult(Result.FAILED_EXCEPTION, character, tmpl); } } [[Category:Marauroa]]
摘要:
请注意,所有对gamedev的贡献均可能会被其他贡献者编辑、修改或删除。如果您不希望您的文字作品被随意编辑,请不要在此提交。
您同时也向我们承诺,您提交的内容为您自己所创作,或是复制自公共领域或类似自由来源(详情请见
Gamedev:著作权
)。
未经许可,请勿提交受著作权保护的作品!
取消
编辑帮助
(在新窗口中打开)
导航菜单
个人工具
未登录
讨论
贡献
创建账号
登录
命名空间
页面
讨论
不转换
不转换
简体
繁體
大陆简体
香港繁體
澳門繁體
大马简体
新加坡简体
臺灣正體
查看
阅读
编辑
查看历史
更多
搜索
导航
首页
最近更改
随机页面
MediaWiki帮助
工具
链入页面
相关更改
特殊页面
页面信息