好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

Mybatis 如何在配置文件中给实体类起别名

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

查看更多关于Mybatis 如何在配置文件中给实体类起别名的详细内容...

  阅读:21次