MyBatis中基于別名typeAliases的設(shè)置
<?xml version='1.0' encoding='UTF-8' ?><!DOCTYPE configurationPUBLIC '-//mybatis.org//DTD Config 3.0//EN''http://mybatis.org/dtd/mybatis-3-config.dtd'><configuration> <!-- 設(shè)置別名 --> <typeAliases><!-- type指的是javabean的完全限定名 alias就是指代別名--><typeAlias alias='student' type='cn.entity.Student' /> </typeAliases> <environments default='development'><environment id='development'> <!-- 使用jdbc的事務(wù) --> <transactionManager type='JDBC' /> <!-- 使用自帶的連接池 --> <dataSource type='POOLED'><property name='driver' value='oracle.jdbc.driver.OracleDriver' /><property name='url' value='jdbc:oracle:thin:@localhost:1521:orcl' /><property name='username' value='test' /><property name='password' value='test' /> </dataSource></environment> </environments> <mappers><mapper resource='cn/dao/StudentDAO.xml' /> </mappers></configuration>
通過(guò)這種方式設(shè)置別名在以后的操作是如果用到了某個(gè)javabean的完全限定名的時(shí)候我們就可以使用alias設(shè)置的值來(lái)代替,從而簡(jiǎn)化了編程。
第二種方式:通過(guò)在配置文件中typeAliases節(jié)點(diǎn)中設(shè)置package 的方式<?xml version='1.0' encoding='UTF-8' ?><!DOCTYPE configurationPUBLIC '-//mybatis.org//DTD Config 3.0//EN''http://mybatis.org/dtd/mybatis-3-config.dtd'><configuration> <!-- 設(shè)置別名 --> <typeAliases><!-- 通過(guò)package, 可以直接指定package的名字, mybatis會(huì)自動(dòng)掃描你指定包下面的javabean, 并且默認(rèn)設(shè)置一個(gè)別名,默認(rèn)的名字為: javabean 的首字母小寫(xiě)的非限定類(lèi)名來(lái)作為它的別名 --><package name='cn.entity' /> </typeAliases> <environments default='development'><environment id='development'> <!-- 使用jdbc的事務(wù) --> <transactionManager type='JDBC' /> <!-- 使用自帶的連接池 --> <dataSource type='POOLED'><property name='driver' value='oracle.jdbc.driver.OracleDriver' /><property name='url' value='jdbc:oracle:thin:@localhost:1521:orcl' /><property name='username' value='test' /><property name='password' value='test' /> </dataSource></environment> </environments> <mappers><mapper resource='cn/dao/StudentDAO.xml' /> </mappers></configuration>
通過(guò)這種方式更加簡(jiǎn)化了編程,因?yàn)樵趯?shí)際開(kāi)發(fā)中會(huì)有很多的javabean,這里只需要指定這些javabean所在的包就行了,那么默認(rèn)他的別名是javabean 的首字母小寫(xiě)的非限定類(lèi)名來(lái)作為它的別名。
第三種:通過(guò)注解的方式@Alias/** * 學(xué)生實(shí)體類(lèi) * @author hyj * */@Alias(value='student')public class Student { private Integer id;//編號(hào) private Integer age;//年齡 private String name;//姓名 public Student() { } public Student(Integer id, Integer age, String name) {super();this.id = id;this.age = age;this.name = name; } public Integer getId() {return id; } public void setId(Integer id) {this.id = id; } public Integer getAge() {return age; } public void setAge(Integer age) {this.age = age; } public String getName() {return name; } public void setName(String name) {this.name = name; } @Override public String toString() {return 'Student [id=' + id + ', age=' + age + ', name=' + name + ']'; } }mybatis的typeAliases別名和注解理解一、別名(從mapper那里尋找類(lèi)換到了從mybatis-config那里找)
1.修改beammapper.xml
2.修改全局配置mybatis-config.xml (新增了別名)
3.包的別名
會(huì)自動(dòng)識(shí)別這個(gè)包下小寫(xiě)開(kāi)頭的類(lèi).
二、別名的好與壞好處是可以簡(jiǎn)略地直接用小寫(xiě)開(kāi)頭的類(lèi)名來(lái)用,更簡(jiǎn)潔
壞處是如果項(xiàng)目一多,類(lèi)一多起來(lái),就不好在beanmapper來(lái)ctrl來(lái)查找到對(duì)應(yīng)的類(lèi)
這里一個(gè)解決方法是別名的時(shí)候換成包的別名,但是依舊治標(biāo)不治本.
所以這時(shí)候推薦使用注解
三、注解的使用在每個(gè)beam包下使用注解來(lái)識(shí)別這個(gè)類(lèi)
如:
這里取的別名跟上面的配置的不一樣,會(huì)報(bào)錯(cuò)找不到category這個(gè)類(lèi)
因?yàn)榈陌杨?lèi)取了個(gè)不一樣的別名,
這時(shí)候改回正確的就可以正常運(yùn)行了
mybatis-config.xml
properties:屬性集(引入外部資源)
resource:加載類(lèi)路徑下的資源
url:引用網(wǎng)絡(luò)路徑或磁盤(pán)路徑下的資源
mappers:加載已經(jīng)寫(xiě)好的sql映射配置文件并注冊(cè)到全局配置文件
settings配置(基于全局特性)
typealias別名
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. golang實(shí)現(xiàn)mysql數(shù)據(jù)庫(kù)事務(wù)的提交與回滾2. MyBatis如何實(shí)現(xiàn)流式查詢(xún)的示例代碼3. Mybatis Limit實(shí)現(xiàn)分頁(yè)功能4. mybatis plus動(dòng)態(tài)數(shù)據(jù)源切換及查詢(xún)過(guò)程淺析5. 解決db2事務(wù)日志已滿(mǎn)及日志磁盤(pán)空間已滿(mǎn)問(wèn)題辦法詳解6. SQLite教程(二):C/C++接口簡(jiǎn)介7. MyBatis SELECT基本查詢(xún)實(shí)現(xiàn)方法詳解8. 基于mysql的論壇(3)9. Mybatis在sqlite中無(wú)法讀寫(xiě)byte[]類(lèi)問(wèn)題的解決辦法10. Mybatis分頁(yè)P(yáng)ageHelper插件代碼實(shí)例
