會(huì)話(huà)是對(duì)應(yīng)用中具體業(yè)務(wù)操作觸發(fā)的一系列與數(shù)據(jù)庫(kù)之間的交互過(guò)程的封裝,通過(guò)建立一個(gè)臨時(shí)通道,負(fù)責(zé)與數(shù)據(jù)庫(kù)之間連接資源的創(chuàng)建及回收,同時(shí)提供更為高級(jí)的抽象指令接口調(diào)用,基于會(huì)話(huà)的優(yōu)點(diǎn):
開(kāi)發(fā)人員不需要擔(dān)心連接資源是否正確釋放;
嚴(yán)格的編碼規(guī)范更利于維護(hù)和理解;
更好的業(yè)務(wù)封裝性;
會(huì)話(huà)對(duì)象參數(shù):
數(shù)據(jù)庫(kù)連接持有者(IConnectionHolder):
指定本次會(huì)話(huà)使用的數(shù)據(jù)源連接;
會(huì)話(huà)執(zhí)行器(ISessionExecutor):
以?xún)?nèi)部類(lèi)的形式定義本次會(huì)話(huà)返回結(jié)果對(duì)象并提供Session實(shí)例對(duì)象的引用;
開(kāi)啟會(huì)話(huà)示例代碼:
// 使用默認(rèn)數(shù)據(jù)源開(kāi)啟會(huì)話(huà) User _result = JDBC.get().openSession(new ISessionExecutor<User>() { public User execute(ISession session) throws Exception { // TODO 此處填寫(xiě)業(yè)務(wù)邏輯代碼 return session.findFirst(EntitySQL.create(User.class)); } }); // 使用指定的數(shù)據(jù)源開(kāi)啟會(huì)話(huà) IConnectionHolder _conn = JDBC.get().getConnectionHolder("oracledb"); // 不需要關(guān)心_conn對(duì)象的資源釋放 IResultSet<User> _results = JDBC.get().openSession(_conn, new ISessionExecutor<IResultSet<User>>() { public IResultSet<User> execute(ISession session) throws Exception { // TODO 此處填寫(xiě)業(yè)務(wù)邏輯代碼 return session.find(EntitySQL.create(User.class)); } });
基于ISession接口的數(shù)據(jù)庫(kù)操作:
示例代碼是圍繞用戶(hù)(User)數(shù)據(jù)實(shí)體完成的CRUD(新增、查詢(xún)、修改、刪除)操作來(lái)展示如何使用ISession對(duì)象,數(shù)據(jù)實(shí)體如下:
@Entity("user") public static class User extends BaseEntity<User, String> { @Id @Property private String id; @Property(name = "user_name") private String username; @Property(name = "pwd") private String pwd; @Property(name = "sex") private String sex; @Property(name = "age") private Integer age; // 忽略Getter和Setter方法 public static class FIELDS { public static final String ID = "id"; public static final String USER_NAME = "username"; public static final String PWD = "pwd"; public static final String SEX = "sex"; public static final String AGE = "age"; } public static final String TABLE_NAME = "user"; }
插入(Insert):
User _user = new User(); _user.setId(UUIDUtils.UUID()); _user.setUsername("suninformation"); _user.setPwd(DigestUtils.md5Hex("123456")); _user.setAge(20); _user.setSex("F"); // 執(zhí)行數(shù)據(jù)插入 session.insert(_user); // 或者在插入時(shí)也可以指定/排除某些字段 session.insert(_user, Fields.create(User.FIELDS.SEX, User.FIELDS.AGE).excluded(true));
更新(Update):
User _user = new User(); _user.setId("bc19f5645aa9438089c5e9954e5f1ac5"); _user.setPwd(DigestUtils.md5Hex("654321")); // 更新指定的字段 session.update(_user, Fields.create(User.FIELDS.PWD));
查詢(xún)(Find):
方式一:通過(guò)數(shù)據(jù)實(shí)體設(shè)置條件(非空屬性之間將使用and條件連接),查詢(xún)所有符合條件的記錄;
User _user = new User(); _user.setUsername("suninformation"); _user.setPwd(DigestUtils.md5Hex("123456")); // 返回所有字段 IResultSet<User> _users = session.find(_user); // 或者返回指定的字段 _users = session.find(_user, Fields.create(User.FIELDS.ID, User.FIELDS.AGE));
方式二:通過(guò)自定義條件,查詢(xún)所有符合條件的記錄;
IResultSet<User> _users = session.find( EntitySQL.create(User.class) .field(User.FIELDS.ID) .field(User.FIELDS.SEX), // 設(shè)置Order By條件 Where.create() .orderDesc(User.FIELDS.USER_NAME));
方式三:分頁(yè)查詢(xún);
IResultSet<User> _users = session.find( EntitySQL.create(User.class) .field(User.FIELDS.ID) .field(User.FIELDS.SEX), Where.create() .orderDesc(User.FIELDS.USER_NAME), // 查詢(xún)第1頁(yè),每頁(yè)10條記錄,統(tǒng)計(jì)總記錄數(shù) Page.create(1).pageSize(10).count(true));
方式四:僅返回符合條件的第一條記錄(FindFirst);
// 查詢(xún)用戶(hù)名稱(chēng)和密碼都匹配的第一條記錄 User _user = session.findFirst(EntitySQL.create(User.class), Where.create( Cond.create() .eq(User.FIELDS.USER_NAME).param("suninformation") .eq(User.FIELDS.PWD).param(DigestUtils.md5Hex("123456"))));
注:更多的查詢(xún)方式將在后面的 “查詢(xún)(Query)” 章節(jié)中詳細(xì)闡述;
刪除(Delete):
根據(jù)實(shí)體主鍵刪除記錄:
User _user = new User(); _user.setId("bc19f5645aa9438089c5e9954e5f1ac5"); // session.delete(_user); // session.delete(User.class, "bc19f5645aa9438089c5e9954e5f1ac5");
根據(jù)條件刪除記錄:
// 刪除年齡小于20歲的用戶(hù)記錄 session.executeForUpdate( SQL.create( Delete.create(User.class).where( Where.create( Cond.create() .lt(User.FIELDS.AGE).param(20)))));
統(tǒng)計(jì)(Count):
// 統(tǒng)計(jì)年齡小于20歲的用戶(hù)記錄總數(shù) // 方式一: long _count = session.count(User.class, Where.create( Cond.create() .lt(User.FIELDS.AGE).param(20))); // 方式二: _count = session.count( SQL.create( Delete.create(User.class).where( Where.create( Cond.create() .lt(User.FIELDS.AGE).param(20)))));
執(zhí)行更新類(lèi)操作(ExecuteForUpdate):
該方法用于執(zhí)行ISession接口中并未提供對(duì)應(yīng)的方法封裝且執(zhí)行操作會(huì)對(duì)數(shù)據(jù)庫(kù)產(chǎn)生變化的SQL語(yǔ)句,執(zhí)行該方法后將返回受影響記錄行數(shù),如上面執(zhí)行的刪除年齡小于20歲的用戶(hù)記錄:
int _effectCount =session.executeForUpdate( SQL.create( Delete.create(User.class).where( Where.create( Cond.create() .lt(User.FIELDS.AGE).param(20)))));
注:以上操作均支持批量操作,具體使用請(qǐng)閱讀API接口文檔和相關(guān)源碼;
更多建議: