Sqlbean1.5.6 发布,减少 Sql 语句,让你编码更高效

Sqlbean

介绍

Sqlbean是一款使用Java面向对象思想来编写并生成Sql语句的工具,在此基础上对MybatisSpring Jdbc实现了类似于JPA的轻量级插件支持。其中内置大量常用SQL执行的方法,可以非常方便的达到你想要的目的,相对复杂的SQL语句也得以支持,在常规的项目开发几乎做到不写DAO层,可以有效的提高项目开发的效率,让开发者更专注于业务代码的编写。

🚀特点: 零入侵, 多数据源, 动态Schema, 读写分离, 自动建表, 连表查询, 乐观锁, 分页, 支持Mybatis和Spring Jdbc

💻环境: JDK8+, Mybatis3.2.4+, (Spring MVC 4.1.2+, Spring Boot 1.x, Spring Boot 2.x)

💿数据库: Mysql, MariaDB, Oracle, Sqlserver2008+, PostgreSQL, DB2, Derby, Sqlite, HSQL, H2

Sqlbean For Android请移步这里👉 gitee, github

简单上手

1.引入Maven依赖

<dependency>
	<groupId>cn.vonce</groupId>
	<artifactId>vonce-sqlbean-spring</artifactId>
	<version>1.5.6</version>
</dependency>
 

2.标注实体类

//标识表名
//标识表名
@SqlTable("d_essay")
public class Essay {
    @SqlId(type = IdType.SNOWFLAKE_ID_16)
    private Long id;
    private String userId;
    private String content;
    private Date creationTime;
    @SqlVersion
    private Date updateTime;
    /**省略get set方法*/
}
 

3.无需Dao层,Service层接口只需继承SqlBeanService<实体类, ID>

public interface EssayService extends SqlBeanService<Essay, Long> {
    //已内置大量常用查询、更新、删除、插入方法,这里可以写自己封装的方法

}
 

4.Service实现类只需继承MybatisSqlBeanServiceImpl<实体类, ID>和实现你的Service接口

//使用Spring Jdbc的话将继承的父类改成SpringJdbcSqlBeanServiceImpl即可
@Service
public class EssayServiceImpl extends MybatisSqlBeanServiceImpl<Essay, Long> implements EssayService {

}
 

5.Controller层

@RequestMapping("essay")
@RestController
public class EssayController {

    @Autowired
    private EssayService essayService;

    //查询
    @GetMapping("select")
    public RS select() {
        //查询列表
        List<Essay> list = essayService.selectAll();
        list = essayService.selectByCondition(Wrapper.where(gt(Essay$.id, 10)).and(lt(Essay$.id, 20)));

        //查询一条
        Essay essay = essayService.selectById(1L);
        essay = essayService.selectOneByCondition(Wrapper.where(eq(Essay$.id, 333)));

        //复杂查询
        Select select = new Select();
        select.column(Essay$.id).column(Essay$.content);
        select.where().gt(Essay$.id, 1).and().eq(Essay$.content, "222");
        select.orderBy(Essay$.id, SqlSort.DESC);
        list = essayService.select(select);

        //用于查询Map
        Map<String, Object> map = essayService.selectMap(select);
        List<Map<String, Object>> mapList = essayService.selectMapList(select);

        return super.successHint("获取成功", list);
    }

    //分页
    @GetMapping("getList")
    public Map getList(HttpServletRequest request) {
        // 查询对象
        Select select = new Select();
        ReqPageHelper<Essay> pageHelper = new ReqPageHelper<>(request);
        pageHelper.paging(select, essayService);
        return pageHelper.toResult("获取列表成功");
    }

    //更新
    @PostMapping("update")
    public RS update(Essay essay) {
        //根据bean内部id更新
        long i = essayService.updateByBeanId(essay);
        //根据条件更新
        //i = essayService.updateByCondition(Wrapper.where(gt(Essay$.id, 1)).and(eq(Essay$.content, "222")));
        if (i > 0) {
            return super.successHint("更新成功");
        }
        return super.othersHint("更新失败");
    }

    //删除
    @PostMapping("deleteById")
    public RS deleteById(Integer[] id) {
        //根据id删除
        long i = essayService.deleteById(id);
        //根据条件删除
        //i = essayService.deleteByCondition(Wrapper.where(gt(Essay$.id, 1)).and(eq(Essay$.content, "222")));
        if (i > 0) {
            return super.successHint("删除成功");
        }
        return super.othersHint("删除失败");
    }

    //插入
    @PostMapping("add")
    public RS add() {
        List<Essay> essayList = new ArrayList<>();
        for (int i = 0; i < 100; i++) {
            Essay essay = new Essay(i, "name" + i);
            essayList.add(essay);
        }
        essayService.insert(essayList);
        return successHint("成功");
    }

}

本次更新内容:

1:如果使用逻辑删除时Delete对象自动转Update对象进行逻辑删除;
2:如果使用逻辑删除但该字段为null则自动填充;
3:优化字段生成,非数据库字段过滤;
4:重载排序方法;
5:修复条件处理器;
6:其他优化

优秀的个人博客,低调大师

微信关注我们

原文链接:https://www.oschina.net/news/196436/sqlbean-1-5-6-released

转载内容版权归作者及来源网站所有!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

相关文章

发表评论

资源下载

更多资源
优质分享Android(本站安卓app)

优质分享Android(本站安卓app)

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Apache Tomcat7、8、9(Java Web服务器)

Apache Tomcat7、8、9(Java Web服务器)

Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun 和其他一些公司及个人共同开发而成。因为Tomcat 技术先进、性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。

Java Development Kit(Java开发工具)

Java Development Kit(Java开发工具)

JDK是 Java 语言的软件开发工具包,主要用于移动设备、嵌入式设备上的java应用程序。JDK是整个java开发的核心,它包含了JAVA的运行环境(JVM+Java系统类库)和JAVA工具。

Sublime Text 一个代码编辑器

Sublime Text 一个代码编辑器

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。