speedment 入门教程
speedment 是基于 Java8 的 orm 框架,相比较 hibernate 和 mybatis 你只要很少的代码就可以实现对数据库的操作,而且根据查询自动帮你优化SQL,开发者无需编写SQL代码
首先建立maven项目,然后在pom.xml中添加依赖:
<dependencies> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.42</version> <scope>runtime</scope> </dependency> <dependency> <groupId>com.speedment</groupId> <artifactId>runtime</artifactId> <version>${speedment.version}</version> <type>pom</type> </dependency> </dependencies>
导入依赖包后,在pom.xml目录下,运行maven命令,mvn speedment:tool 弹出初始化工具,并且会在你的项目目录下面生成模板 speedment.json 文件
根据图形工具的提示,输入连接信息,选择db,然后点击 Generate,就会生成基础类,到你的当前工程目录下
初始化加载,Spring Boot项目为例:
@Configuration public class Setup { @Bean public Dms2Application createApplication() { return new Dms2ApplicationBuilder() .withPassword("root") .withLogging(LogType.STREAM_OPTIMIZER) .build(); } @Bean public Jackson2ObjectMapperBuilder jacksonBuilder() { return new Jackson2ObjectMapperBuilder().indentOutput(true); } }
上面代码,是我对dms2数据库进行的初始化配置,读者初始化的时候请根据生成的代码,改为自己数据库的名称,格式都差不多
speedment.json 只会保留你的基本信息,不会保留你的 password 等重要信息,所以需要在初始化的时候设置数据库密码,当然,在初始化中你可以配置更多的信息,例如线程池,日志信息等等,具体请查阅文档
初始化完毕后,就可以开始使用 speedment 对数据库开始操作了
AccountManager accountManager; private AccountService(Dms2Application app) { accountManager = app.getOrThrow(AccountManager.class); } /** * 新增 Deutsch 用户 * @return */ public Account add() { Account account = new AccountImpl().setUserName("Deutsch"); return accountManager.persist(account); } /** * 查找 Deutsch 用户 并且修改名字为 Deutsch-h * @return */ public Account edit() { Optional<Account> optAccount = accountManager.stream().filter(Account.USER_NAME.equal("Deutsch")).findFirst(); optAccount.map(account -> { return accountManager.update(account.setUserName("Deutsch-h")); }); return null; } /** * 查找 Deutsch-h 用户 并且删除 */ public void delete() { Optional<Account> optAccount = accountManager.stream().filter(Account.USER_NAME.equal("Deutsch-h")).findFirst(); optAccount.ifPresent(a -> { accountManager.remove(a); }); }
上面就是 speedment 简单的增删改查,都是通过 java.util.stream 来操作,非常的方便
当然 speedment 还支持更多强大的查询,我们只做简单介绍,例如多条件复杂查询,可以单独定义 Predicate<T> , 然后传入到 .filter 中来灵活处理
Predicate<Account> queryParams = Account.STATUS.notEqual(DataStatusEnum.DELETE.value); if(StringUtil.isNotEmpty(userName)) { queryParams = queryParams.and(Account.USER_NAME.equal(userName)); } if(StringUtil.isNotEmpty(loginName)) { queryParams = queryParams.and(Account.LOGIN_NAME.equal(loginName)); } //动态查询条件,构建分页 List<Account> data = accountManager.stream().filter(queryParams).skip(accountReqPaging.getStartIndex()).limit(pageSize).collect(Collectors.toList());
以上只是简单使用,更多的Offset, Offset and Limit, Count, Group By, Gaving , Distinct 都是可以很轻松的实现
获取更多 Java 实战知识,请扫二维码,关注获取更多技术知识