一小时迅速入门Mybatis之bind与多数据源支持|一小时迅速入门Mybatis之bind与多数据源支持 Java API
目录
- 一、bind
- 二、 多数据库支持
- 2.1 pom.xml
- 2.2 mybatis-config.xml
- 2.3 接口 PersonMapper
- 2.4 xml PersonMapper.xml
- 2.5 测试
一、bind
// 测试bindList testBind(@Param("name") String name);
select * from person where name like #{bidname}
import dao.PersonMapper; import entity.Person; import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; import java.io.InputStream; import java.util.*; /** * @author 发现更多精彩关注公众号:木子的昼夜编程 * 一个生活在互联网底层,做着增删改查的码农,不谙世事的造作 */public class TestMain03 {public static void main(String[] args) throws Exception {String resource = "mybatis-config.xml"; InputStream inputStream = Resources.getResourceAsStream(resource); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); try (SqlSession session = sqlSessionFactory.openSession()) {// 通过sesson获取Mapper 这个Mapper会编程Mybatis的代理MapperPersonMapper mapper = session.getMapper(PersonMapper.class); List list = mapper.testBind("小强"); Optional.ofNullable(list).orElse(new ArrayList<>()).forEach(item -> {System.out.println(item); }); }}}
bind就是允许使用OGNL表达式创建一个变量(例如:bidname) ,然后将其绑定在当前上下文
二、 多数据库支持 搞了半天搞错了,浪费了点儿点儿时间
2.1 pom.xml
我用的jar包版本是3.4.5
4.0.0 org.example testDB1.0-SNAPSHOT 8 8 org.mybatis mybatis3.4.5 mysql mysql-connector-java5.1.47
2.2 mybatis-config.xml
【一小时迅速入门Mybatis之bind与多数据源支持|一小时迅速入门Mybatis之bind与多数据源支持 Java API】databaseIdProvider我用了默认配置 没有自定义,下一篇天写一个自定义实现类的示例
2.3 接口 PersonMapper
package dao; /** * @author 发现更多精彩关注公众号:木子的昼夜编程分享一个生活在互联网底层做着增删改查的码农的感悟与学习 * @create 2021-08-30 21:54 */public interface PersonMapper {// 测试返回当前时间String testDb(); }
2.4 xml PersonMapper.xml
select CONCAT("mysql-->",#{_databaseId},"-->",now()) from dual select "oracle-->"||#{_databaseId}from dual
2.5 测试
import dao.PersonMapper; import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; import java.io.InputStream; /** * @author 发现更多精彩关注公众号:木子的昼夜编程 * 一个生活在互联网底层,做着增删改查的码农,不谙世事的造作 * @create 2021-09-02 21:42 */public class TestMain {public static void main(String[] args) throws Exception {String resource = "mybatis-config.xml"; InputStream inputStream = Resources.getResourceAsStream(resource); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); SqlSession session = sqlSessionFactory.openSession(); // 通过sesson获取Mapper 这个Mapper会编程Mybatis的代理MapperPersonMapper mapper = session.getMapper(PersonMapper.class); String type = mapper.testDb(); System.out.println("数据库类型:"+type); }}
可以看到我pom里边引入的是Mysql的驱动包,所以我这里结果肯定是Mysql,如果引入多个包,那么会默认使用databaseIdProvider第一个匹配到的,引入多个驱动下一篇写demo
输出结果:
文章图片
下集预告:
- 自定义DatabaseIdProvider 自己定义_databaseId 类型
- databaseId标签使用 不再用if
- 引入多驱动 表现结果
推荐阅读
- typeScript入门基础介绍
- Android|Android sqlite3数据库入门系列
- Android下的IO库-Okio源码解析(一)|Android下的IO库-Okio源码解析(一) 入门
- 深度学习-入门
- 第三章|第三章 进校园重拾旧梦 登讲台初为人师第一节 接乱班面临考验 ,遇高师指点入门
- iOS开发技术之美—iOS入门技术的基础学习
- OpenCV|OpenCV-Python实战(18)——深度学习简介与入门示例
- 【入门】Python网络爬虫与信息提取1
- 垂直农场101-室内农业入门知识
- 所有Python入门书籍的整理,初学者必看,附赠所有电子版(三)