Mybatis配置之properties和settings标签的用法

Mybatis properties标签和settings标签 本次将讲述mybatis的配置,主要的配置是基于mybatis的配置文件来进行配置的,其配置文件并不复杂
如下面的例子:


需要注意的是mybatis的配置项不能够相互颠倒,如果颠倒了他们的顺序,那么在mybatis启动阶段就会发生异常,导致程序无法进行下去。
其一般的顺序为:

1.properties属性
properties属性是用来给系统配置一些参数,可以放在xml文件或者是properties文件中,而不是放在java 的编码中,这样的好处是方便管理和修改,而不会引起代码的重新编译,一般而言,有以下3种配置方式:
properties子元素:

如上面及格对数据库连接参数的设定,我们需要在property标签内部标识属性名称和属性值。这种方式将配置的属性的名称和对应的属性值记录在xml文件中。同时也可以采用占位符引用管理,这个在代码的编写中经常见到,是一种较为流行的操作方式。

如上面属性的赋值方式,采用的占位符引用的方式,将上文中写好的值通过占位的方式引用过来,这样写的话还需要我们在上面的properties标签下面定义properties的子元素,类似于所示的例子一样。
使用properties文件:
这就需要我们创建一个properties的文件:
database.driver=com.mysql.jdbc.Driverdatabase.url=jdbc:mysql://localhost:3306/chapter4database.username=rootdatabase.password=123456

我们想利用这个文件中所定义的值,则需要在标签的resource 进行赋值,其值为包的路径,使用方式如下(假设文件名为jdbc.properties):

这样可以将多个键值饭在一个properties文件中,方便以后的修改和管理。同时,也可以结合上面的占位符的方式进行传递。
使用程序传递方式传递参数:
某些情况下数据库的用户密码数对开发人员和其他人员保密的,运维人员为了保密一般的都需要把用户名和密码进行加密,然后配置到properties文件中,此时往往需要解密才能到到真实的用户名和密码数据库也不可能使用已经加密的字符串去链接数据库。所以假设已经有一个操作解密的工具,我们需要解密人后重置到properties文件中:
public class SqlSessionFactoryUtils { private final static Class LOCK = SqlSessionFactoryUtils.class; private static SqlSessionFactory sqlSessionFactory = null; private SqlSessionFactoryUtils() { } public static SqlSessionFactory getSqlSessionFactory() {synchronized (LOCK) {if (sqlSessionFactory != null) {return sqlSessionFactory; }String resource = "mybatis-config.xml"; InputStream inputStream; try {inputStream = Resources.getResourceAsStream(resource); sqlSessionFactory = newSqlSessionFactoryBuilder().build(inputStream); 采用程序传递加密参数,启用它之前,修改用户密码为密文..InputStream in = Resources.getResourceAsStream("jdbc.properties"); Properties props = new Properties(); props.load(in); String username = props.getProperty("database.username"); String password = props.getProperty("database.password"); // 解密用户和密码,并在属性中重置props.put("database.username", CodeUtils.decode(username)); props.put("database.password", CodeUtils.decode(password)); inputStream = Resources.getResourceAsStream(resource); // 使用程序传递的方式覆盖原有的properties属性参数sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream, props); } catch (IOException e) {e.printStackTrace(); return null; }return sqlSessionFactory; } } public static SqlSession openSqlSession() {if (sqlSessionFactory == null) {getSqlSessionFactory(); }return sqlSessionFactory.openSession(); } public static void main(String[] args) {System.out.println(CodeUtils.encode("root")); System.out.println(CodeUtils.encode("123456")); } static class CodeUtils {private static String encode(String src) {BASE64Encoder encoder = new BASE64Encoder(); return encoder.encode(src.getBytes()); } private static String decode(String des) {BASE64Decoder decoder = new BASE64Decoder(); try {return new String(decoder.decodeBuffer(des)); } catch (IOException e) {e.printStackTrace(); }return null; } }}

这里面制作了一个基于程序传递的方式传递参数的例子,首先使用Resource对象读取一个jdbc.properties文件,然后获取原来的配置的用户名和密码,并进行解密,重置,最后使用SqlSessionFactoryBuilder类的biuld方法传递properties中的参数完成覆盖原来的密文,及解决了安全问题,又能够安全的去连接数据库。
2.Settings标签设置
这个是mybatis中最为复杂的配置,这个标签中的设置能够深刻的影响到底层的运行,但是大部分情况下使用默认的配置就可以运行,不需要去配置这个属性,多多数情况下修改一些常用的规则就可以了,比如自动映射,驼峰命名映射,级联规则,是否开启缓存,执行器类型等等。

【Mybatis配置之properties和settings标签的用法】以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

    推荐阅读