色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

MyBatis中的JdbcType映射使用詳解

瀏覽:2日期:2023-11-26 13:56:39

Java項(xiàng)目涉及到數(shù)據(jù)庫交互,以往常用的是JDBC,現(xiàn)在則有Hibernate、Mybatis等這些持久化支持。

項(xiàng)目中用到了MyBatis,和JDBC最顯著的區(qū)別,就是SQL語句配置化,通過xml文件定義SQL語句,當(dāng)然JDBC也可以將SQL配置化,需要定制開發(fā),MyBatis則直接支持這種方法。

官方對于MyBatis的介紹,

MyBatis is a first class persistence framework with support for custom SQL, stored procedures and advanced mappings. MyBatis eliminates almost all of the JDBC code and manual setting of parameters and retrieval of results. MyBatis can use simple XML or Annotations for configuration and map primitives, Map interfaces and Java POJOs (Plain Old Java Objects) to database records.

簡單來講,MyBatis幾乎屏蔽了所有JDBC代碼,用一種簡單的xml,或者注解,就能完成數(shù)據(jù)庫交互。

xml配置文件,可用MyBatis自己定義的數(shù)據(jù)類型,引自:http://www.mybatis.org/mybatis-3/configuration.html

Associated JDBC type can be specified by two means:

Adding a jdbcType attribute to the typeHandler element (for example: jdbcType='VARCHAR').

Adding a @MappedJdbcTypes annotation to your TypeHandler class specifying the list of JDBC types to associate it with. This annotation will be ignored if the jdbcType attribute as also been specified.

例如下面的配置,指定companyid參數(shù)類型為BIGINT,

<select id=’getMeetingnoByCompanyid’ parameterType='java.lang.Integer' resultType='java.lang.String'> select a.meetingno from xxx a where a.companyid = #{companyid, jdbcType=BIGINT}</select>

對于jdbcType,MyBatis的API文檔有說明,引自:http://www.mybatis.org/mybatis-3/apidocs/reference/org/apache/ibatis/type/JdbcType.html

MyBatis中的JdbcType映射使用詳解

另外,以下介紹給出了JdbcType和Oracle以及MySQL,相互之間的映射關(guān)系,比較詳細(xì):

1. Mybatis JdbcType與Oracle、MySql數(shù)據(jù)類型對應(yīng)列表

JdbcType Oracle MySql JdbcType ARRAY JdbcType BIGINT BIGINT JdbcType BINARY JdbcType BIT BIT JdbcType BLOB BLOB BLOB JdbcType BOOLEAN JdbcType CHAR CHAR CHAR JdbcType CLOB CLOB 修改為TEXT JdbcType CURSOR JdbcType DATE DATE DATE JdbcType DECIMAL DECIMAL DECIMAL JdbcType DOUBLE NUMBER DOUBLE JdbcType FLOAT FLOAT FLOAT JdbcType INTEGER INTEGER INTEGER JdbcType LONGVARBINARY JdbcType LONGVARCHAR LONG VARCHAR JdbcType NCHAR NCHAR JdbcType NCLOB NCLOB JdbcType NULL JdbcType NUMERIC NUMERIC/NUMBER NUMERIC/ JdbcType NVARCHAR JdbcType OTHER JdbcType REAL REAL REAL JdbcType SMALLINT SMALLINT SMALLINT JdbcType STRUCT JdbcType TIME TIME JdbcType TIMESTAMP TIMESTAMP TIMESTAMP/DATETIME JdbcType TINYINT TINYINT JdbcType UNDEFINED JdbcType VARBINARY JdbcType VARCHAR VARCHAR VARCHAR

注意到, MyBatis的JdbcType中部分沒有對應(yīng)到Oracle和Mysql的數(shù)據(jù)類型中(或許由于自己遺漏),不過不用擔(dān)心,后續(xù)大家碰到再具體分析;同時(shí)上述對應(yīng)關(guān)系不一定是一一對應(yīng),請大家了解。

大家主要掌握基本的數(shù)字、時(shí)間、字符串就足以應(yīng)對日常開發(fā)了。

2. Mybatis JdbcType官方文檔

Mybatis JdbcType官方文檔

MyBatis中的JdbcType映射使用詳解

查閱Mybatis JdbcType官方文檔是很有必要的!

3. 說明

對于自己不肯定的,調(diào)整代碼多嘗試下,能夠使自己加深印象!

4. 更新日志

2017-04-26 修改內(nèi)容:MySQL中沒有CLOB類型,謝謝@火靈 指正。

Mybatis JdbcType Oracle MySql JdbcType CLOB CLOB CLOB?>修改為TEXT

以上這篇MyBatis中的JdbcType映射使用詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: JDBC
相關(guān)文章:
主站蜘蛛池模板: 久久免费视频网 | 亚洲男人的天堂久久无 | 欧美性高清视频免费看www | 午夜视频国产 | 99久久免费观看 | 一区二区在线看 | 亚洲黄色成人 | 亚洲欧美在线视频免费 | 狠狠综合久久久综合 | 99热热久久这里只有精品166 | 国产做a爰片久久毛片a | 亚洲欧美日韩成人一区在线 | 香港台湾经典三级a视频 | 又粗又爽又色男女乱淫播放男女 | 狠狠色丁香久久婷婷综 | 成人免费午间影院在线观看 | 失禁h啪肉尿出来高h | 亚洲成人欧美 | 欧美特黄aaaaaa | 97国产精品 | 97欧美精品一区二区三区 | 亚洲一区在线视频 | 5x社区直接进入一区二区三区 | 欧美成本人视频 | 国产在线观看精品一区二区三区91 | 国产三级做爰在线观看 | 久久伊人热| 国产成人av性色在线影院 | 日本一级aaaa特黄毛片 | 日本一级特黄毛片高清视频 | 色综合久久88色综合天天小说 | 久久久久久久国产精品影院 | 国产精品一区二区在线观看 | 在线播放国产视频 | 欧美91精品久久久久网免费 | 国产性自拍 | 成人午夜在线观看国产 | 久久机热综合久久国产 | 香港全黄一级毛片在线播放 | 亚洲精品中文字幕一区在线 | 91国在线视频 |