dexcoder-dal 2.3.0 發布,最方便易用的通用dal層

jopen 8年前發布 | 17K 次閱讀

該通用dal是在開發過程中,對于簡單封裝的通用dao或數據訪問層使用深感痛苦與不便,由此進行了整合和改進發展而來。

如果你不喜歡用Hibernate、Mybaits這類ORM框架,喜歡Spring JdbcTemplate或DbUtils,那么可以試試這個封裝的通用dal,這可能是目前封裝的最方便易用的通用dal層了。

dexcoder-dal 2.3.0 更新說明:

  • 實體類表名及屬性名映射增加注解支持

  • 增加更多的執行自定義sql方法

  • 因為sql權限問題去掉使用TRUNCATE的deleteAll方法

  • 修正使用注解時注解的屬性名不遵循規范時get方法主鍵錯誤問題

  • 修正水平拆分數據分表不根據主鍵拆分時update無法獲取表名的問題

  • 修改NameHandler類名為MappingHandler

配置動態數據源請看這里:在dexcoder-dal中使用動態數據源并設置讀寫分離

數據水平分表請看這里:在dexcoder-dal中實現分表數據水平拆分

dexcoder-dal的一些特性:

  1. 一個dao即可以搞定所有的實體類,不必再一個個建立跟實體對應的繼承于類似BaseDao這類“通用dao”了。

  2. 各類方法參數除了Entity外,支持更強大的Criteria方式。

  3. sql的where條件支持一些復雜的條件,如=、!=、or、in、not in甚至是執行函數。

  4. 允許在查詢時指定使用哪個字段進行排序,可以指定多個進行組合升降序自由排序。

  5. 支持在查詢時指定返回字段的白名單和黑名單,可以指定只返回某些字段或不返回某些字段。

  6. select查詢時支持函數,count()、max()、to_char()、甚至是distinct,理論上都可以支持。

  7. 方便強大的分頁功能,無須額外操作,二三行代碼搞定分頁,自動判斷數據庫,無須指定。

  8. 可以使用{}和[]完成一些特殊的操作,{}中的代碼將原生執行,[]中的代碼會進行命名轉換,一般fieldName轉columnName。

  9. 支持執行自定義sql。

  10. 支持使用類似mybatis的方式執行自定義sql。

  11. 支持讀寫分離和動態數據源。

  12. 對于數據分表水平拆分支持友好。

使用dexcoder-dal,maven坐標

<dependency>
    <groupId>com.dexcoder</groupId>
    <artifactId>dexcoder-dal-spring</artifactId>
    <version>${version}</version>
</dependency>

幾個示例

select

//白名單、in、括號、or、asc、desc
//最終sql:SELECT LOGIN_NAME FROM USER WHERE USER_TYPE in (?,?) and ( LOGIN_NAME =  ? or EMAIL =  ? ) and PASSWORD =  ? and  (USER_AGE = ? OR USER_AGE = ? OR USER_AGE = ?)  ORDER BY USER_ID ASC,USER_AGE DESC
Criteria criteria = Criteria.select(User.class).include("loginName")
        .where("userType","in", new Object[] { "1", "2" }).begin().and("loginName", new Object[] { "javaer" })
        .or("email", new Object[] { "javaer@live.com" }).end().and("password", new Object[] { "123456" })
        .and("userAge", new Object[] { 18, 19, 20 }).asc("userId").desc("userAge");
List<User> users = jdbcDao.queryList(criteria);

update

user.setPassword("abcdef");
//方式一 為null的屬性值將被忽略
jdbcDao.update(user);

//方式二 為null的屬性值將更新到數據庫
jdbcDao.update(user,false);

//方式三 criteria 這里的email設為null也將被更新
Criteria criteria = Criteria.update(User.class).set("password", "update222").set("email",null)
    .where("userId", new Object[] { 56L, 57L, 58L });
jdbcDao.update(criteria);

分頁

//進行分頁,只需要增加這行,查詢方式上沒有任何區別
PageControl.performPage(user);
jdbcDao.queryList(user);
//分頁后數據由PageControl中獲取
Pager pager = PageControl.getPager();
//列表
List<User> users = pager.getList(User.class);
//總記錄數
int itemsTotal = pager.getItemsTotal();

執行函數

//max()
Criteria criteria = Criteria.select(User.class).addSelectFunc("max([userId])");
Long userId = jdbcDao.queryForObject(criteria);

//count()
Criteria criteria = Criteria.select(User.class).addSelectFunc("count(*)");
Long count = jdbcDao.queryForObject(criteria);

//distinct
Criteria criteria = Criteria.select(User.class).addSelectFunc("distinct [loginName]");
List<Map<String, Object>> mapList = jdbcDao.queryForList(criteria);

//where中
Criteria criteria = Criteria.select(User.class).where("[gmtCreate]", ">",
    new Object[] { "str_to_date('2015-10-1','%Y-%m-%d')" });
List<User> userList = jdbcDao.queryList(criteria);

更多詳細信息請查看:http://git.oschina.net/selfly/dexcoder-assistant 

來自: http://www.oschina.net//news/69977/dexcoder-dal-2-3-0

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!