Mybatis 给实体类起别名
全局配置文件中的标签:
标签3: typeAliases 别名处理器 可以为java类型起别名 别名忽略大小写
原来:
1
|
< select id = "getTeacherById" parameterType = "integer" resultType = "entity.Teacher" >
|
ctrl+左键就可以定位到该类 其实比较方便
起了别名后就难找了
注意:
有个问题 typeAlias标签 还有位置问题 得放在proerties后面 而不是configuration后面
有三个方法起别名:
第一种:单个起别名
1
2
3
|
< typeAliases >
< typeAlias type = "entity.Teacher" alias = "ss" />
</ typeAliases >
|
type是要为起别名的类型全类名 默认是类名的小写teacher
alias
:是指新的别名
第二种:批量起别名
1
2
3
|
< typeAliases >
< package name = "entity" />
</ typeAliases >
|
package
:为某个包下的所有类批量起别名
name
:指定包名 以及下面所有的后代包的每一个类都起一个默认别名(类名小写)
第三种:使用注解
如果此时类名冲突怎么办?
使用@Alias注解为某个类指定新的别名:
1
2
|
@Alias ( "ss" )
public class Teacher {
|
注意:得考虑是否起别名,有时候起别名反而更麻烦了
其实Mybatis内部就有很多起别名的:来看看 全局配置Configuration中的别名
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
public Configuration() {
typeAliasRegistry.registerAlias( "JDBC" , JdbcTransactionFactory. class );
typeAliasRegistry.registerAlias( "MANAGED" , ManagedTransactionFactory. class );
typeAliasRegistry.registerAlias( "JNDI" , JndiDataSourceFactory. class );
typeAliasRegistry.registerAlias( "POOLED" , PooledDataSourceFactory. class );
typeAliasRegistry.registerAlias( "UNPOOLED" , UnpooledDataSourceFactory. class );
typeAliasRegistry.registerAlias( "PERPETUAL" , PerpetualCache. class );
typeAliasRegistry.registerAlias( "FIFO" , FifoCache. class );
typeAliasRegistry.registerAlias( "LRU" , LruCache. class );
typeAliasRegistry.registerAlias( "SOFT" , SoftCache. class );
typeAliasRegistry.registerAlias( "WEAK" , WeakCache. class );
typeAliasRegistry.registerAlias( "DB_VENDOR" , VendorDatabaseIdProvider. class );
typeAliasRegistry.registerAlias( "XML" , XMLLanguageDriver. class );
typeAliasRegistry.registerAlias( "RAW" , RawLanguageDriver. class );
typeAliasRegistry.registerAlias( "SLF4J" , Slf4jImpl. class );
typeAliasRegistry.registerAlias( "COMMONS_LOGGING" , JakartaCommonsLoggingImpl. class );
typeAliasRegistry.registerAlias( "LOG4J" , Log4jImpl. class );
typeAliasRegistry.registerAlias( "LOG4J2" , Log4j2Impl. class );
typeAliasRegistry.registerAlias( "JDK_LOGGING" , Jdk14LoggingImpl. class );
typeAliasRegistry.registerAlias( "STDOUT_LOGGING" , StdOutImpl. class );
typeAliasRegistry.registerAlias( "NO_LOGGING" , NoLoggingImpl. class );
typeAliasRegistry.registerAlias( "CGLIB" , CglibProxyFactory. class );
typeAliasRegistry.registerAlias( "JAVASSIST" , JavassistProxyFactory. class );
|
Mybatis 取别名问题
今天学习Mybatis时在取别名这里总是报错,如图所示
错误信息:
Cause: org.apache.ibatis.builder.BuilderException: Error creating document instance. Cause: org.xml.sax.SAXParseException; lineNumber: 36; columnNumber: 17; 元素类型为 “configuration” 的内容必须匹配 “(properties?,settings?,typeAliases?,typeHandlers?,objectFactory?,objectWrapperFactory?,reflectorFactory?,plugins?,environments?,databaseIdProvider?,mappers?)”。
最后发现只需要在定义别名的时候把typeAlias标签放在properties标签后面就好了
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
<? xml version = "1.0" encoding = "UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
< configuration >
<!--typeAlias用于配置别名。type属性指定的是实体类全限定类名。alias属性指定别名,当指定了别名就不区分大小写,linux中仍然区分大小写,且typeAlias标签必须放在properties后面-->
< properties resource = "jdbcConfig.properties" >
</ properties >
< typeAliases >
< package name = "domain" ></ package >
</ typeAliases >
<!--配置环境-->
< environments default = "mysql" >
<!--配置mysql的环境-->
< environment id = "mysql" >
<!--配置事务的类型-->
< transactionManager type = "JDBC" >
</ transactionManager >
<!--配置数据源(连接池)-->
< dataSource type = "POOLED" >
<!--配置连接数据库的4个基本信息-->
< property name = "driver" value = "${driver}" />
< property name = "url" value = "${url}" />
< property name = "username" value = "${username}" />
< property name = "password" value = "${password}" />
</ dataSource >
</ environment >
</ environments >
<!--指定映射配置文件的位置,映射配置文件指的是每个dao独立的配置文件
如果是用注解来配置的话,此处应该使用class属性指定被注解的dao全限定类名
-->
< mappers >
< package name = "dao" />
</ mappers >
</ configuration >
|
之后运行就正常了
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/qq_38409944/article/details/82466922