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