BeetlSQL 2.10.5 发布,Java Dao 工具

栏目: Java · 发布时间: 8年前

内容简介:BeetlSQL 2.10.5 发布,Java Dao 工具

本次发布增强了Query功能

  • #IHJI8 query 方法支持asc和desc方法

  • #IHI79  ORM功能可以直接映射到setter方法上

  • #IHD7X sqlserver使用query.single()查询生成 sql 错误

  • #IHCGZ query.updateSelective,lambda等方法错误检测

<dependency>
    <groupId>com.ibeetl</groupId>
    <artifactId>beetlsql</artifactId>
    <version>2.10.5</version>
</dependency>

BeetlSQL介绍

* 派别:SQL为中心

* 强化SQL管理,通过md文件管理sql,使用Beetl模板编写复杂sql

* 简单SQL可以通过Query类链式API完成

* 内置常见增删改查功能,节省项目50%工作量

* 全面支持跨数据库平台

* 支持一对一,一对多等常见的ORM映射

* 其他

* 具备代码生成功能

* 主从支持

* 支持Interceptor,如Debug,Cache等

内置增删改查

* void insert(T entity);

* int updateById(T entity);

* int updateTemplateById(T entity);

* int deleteById(Object key);

* T unique(Object key);

* T single(Object key);

* T lock(Object key);

* List<T> all(); 

* List<T> template(T entity);

* <T> T templateOne(T entity); 

* List<T> execute(String sql,Object... args);

* ....等等大量内置方法且可以扩展内置方法

Query查询

List<User> list = userDao.createQuery().andEq("name","hi").orderBy("create_date").select();

如果是 Java 8,且引入了对jaque库依赖,则可以

List<User> list1  = userDao.createQuery().lamdba().andEq(User::getName, "hi").orderBy(User::getCreateDate).select();

管理SQL

@SqlResource("console.user") public interface UserConsoleDao extends BaseMapper<SysUser> {

    void batchDelUserByIds(List<Long> ids);
    void batchUpdateUserState( List<Long> ids,  GeneralStateEnum stateEnum);
    @Sql("update sys_user set password=? where id=?")
    int changePassword(String newPassword,long id);


}

对应的sql文件是console/user.md,内容如下

batchDelUserByIds
===
    update SYS_USER u set u.del_flag = 1 where u.id in( #join(ids)#)
    
batchUpdateUserState
===
    update SYS_USER u set u.state = #state# where u.id in( #join(ids)#)

关系映射

selectUserAndDepartment
===
    select * from user where user_id=#userId#
    @ orm.single({"departmentId":"id"},"Department");
    @ orm.many({"id":"userId"},"user.selectRole","Role");


user.selectRole
===

    select r.* from user_role ur left join role r on ur.role_id=r.id
where ur.user_id=#userId#

也支持注解说明映射关系

与 hiberante,myabtis 比较

BeetlSQL 2.10.5 发布,Java Dao 工具

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Learning Vue.js 2

Learning Vue.js 2

Olga Filipova / Packt Publishing / 2017-1-5 / USD 41.99

About This Book Learn how to propagate DOM changes across the website without writing extensive jQuery callbacks code.Learn how to achieve reactivity and easily compose views with Vue.js and unders......一起来看看 《Learning Vue.js 2》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

MD5 加密
MD5 加密

MD5 加密工具