共计 2286 个字符,预计需要花费 6 分钟才能阅读完成。
这篇文章主要讲解了“怎么理解 MyBatis 中的 JdbcType 映射”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着丸趣 TV 小编的思路慢慢深入,一起来研究和学习“怎么理解 MyBatis 中的 JdbcType 映射”吧!
Java 项目涉及到数据库交互,以往常用的是 JDBC,现在则有 Hibernate、Mybatis 等这些持久化支持。
项目中用到了 MyBatis,和 JDBC 最显著的区别,就是 SQL 语句配置化,通过 xml 文件定义 SQL 语句,当然 JDBC 也可以将 SQL 配置化,需要定制开发,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,或者注解,就能完成数据库交互。
xml 配置文件,可用 MyBatis 自己定义的数据类型,引自: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 参数类型为 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
另外,这篇文章,给出了 JdbcType 和 Oracle 以及 MySQL,相互之间的映射关系,比较详细,引自:http://blog.csdn.net/loongshawn/article/details/50496460
JdbcTypeOracleMySqlJdbcTypeARRAY
JdbcTypeBIGINT
BIGINTJdbcTypeBINARY
JdbcTypeBIT
BITJdbcTypeBLOBBLOBBLOBJdbcTypeBOOLEAN
JdbcTypeCHARCHARCHARJdbcTypeCLOBCLOB 修改为 TEXTJdbcTypeCURSOR
JdbcTypeDATEDATEDATEJdbcTypeDECIMALDECIMALDECIMALJdbcTypeDOUBLENUMBERDOUBLEJdbcTypeFLOATFLOATFLOATJdbcTypeINTEGERINTEGERINTEGERJdbcTypeLONGVARBINARY
JdbcTypeLONGVARCHARLONG VARCHAR
JdbcTypeNCHARNCHAR
JdbcTypeNCLOBNCLOB
JdbcTypeNULL
JdbcTypeNUMERICNUMERIC/NUMBERNUMERIC/JdbcTypeNVARCHAR
JdbcTypeOTHER
JdbcTypeREALREALREALJdbcTypeSMALLINTSMALLINTSMALLINTJdbcTypeSTRUCT
JdbcTypeTIME
TIMEJdbcTypeTIMESTAMPTIMESTAMPTIMESTAMP/DATETIMEJdbcTypeTINYINT
TINYINTJdbcTypeUNDEFINED
JdbcTypeVARBINARY
JdbcTypeVARCHARVARCHARVARCHAR
感谢各位的阅读,以上就是“怎么理解 MyBatis 中的 JdbcType 映射”的内容了,经过本文的学习后,相信大家对怎么理解 MyBatis 中的 JdbcType 映射这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是丸趣 TV,丸趣 TV 小编将为大家推送更多相关知识点的文章,欢迎关注!