- 浏览: 3420791 次
- 性别:
- 来自: 珠海
文章分类
- 全部博客 (1633)
- Java (250)
- Android&HTML5 (111)
- Struts (10)
- Spring (236)
- Hibernate&MyBatis (115)
- SSH (49)
- jQuery插件收集 (55)
- Javascript (145)
- PHP (77)
- REST&WebService (18)
- BIRT (27)
- .NET (7)
- Database (105)
- 设计模式 (16)
- 自动化和测试 (19)
- Maven&Ant (43)
- 工作流 (36)
- 开源应用 (156)
- 其他 (16)
- 前台&美工 (119)
- 工作积累 (0)
- OS&Docker (83)
- Python&爬虫 (28)
- 工具软件 (157)
- 问题收集 (61)
- OFbiz (6)
- noSQL (12)
最新评论
-
HEZR曾嶸:
你好博主,这个不是很理解,能解释一下嘛//左边+1,上边+1, ...
java 两字符串相似度计算算法 -
天使建站:
写得不错,可以看这里,和这里的这篇文章一起看,有 ...
jquery 遍历对象、数组、集合 -
xue88ming:
很有用,谢谢
@PathVariable映射出现错误: Name for argument type -
jnjeC:
厉害,困扰了我很久
MyBatis排序时使用order by 动态参数时需要注意,用$而不是# -
TopLongMan:
非常好,很实用啊。。
PostgreSQL递归查询实现树状结构查询
Mybatis类型转换介绍 http://haohaoxuexi.iteye.com/blog/1847854
原文http://maimode.iteye.com/blog/1488620
mybatis提供了对自定义的类型转换器(typeHandler)的支持,因此我们可以自己编写类型转换器来实现这一自动转换的功能。
注意:
1. 使用的时候, resultMap也select的SQL的参数, 尽量要指定类型.
2. ibatis的方法: ibatis如何自动获取自定义的handler http://daizuan.iteye.com/blog/1122969. SQL使用方法: SHOW_NAV_ADMIN=#showNavAdmin,jdbcType=VARCHAR,javaType=boolean#
3. 如果是boolean类型, 那么bean里面应该定义为Booelean类型, 而不是基础类型boolean.
实现步骤:
第一步:编写自定义类型转换器
第二步:注册类型转换器
第三步: 指定类型转换
这样mybatis就能将数据库中的类型与java中的类型自动做转换了。其他类型转方法同上。
原文http://maimode.iteye.com/blog/1488620
mybatis提供了对自定义的类型转换器(typeHandler)的支持,因此我们可以自己编写类型转换器来实现这一自动转换的功能。
注意:
1. 使用的时候, resultMap也select的SQL的参数, 尽量要指定类型.
2. ibatis的方法: ibatis如何自动获取自定义的handler http://daizuan.iteye.com/blog/1122969. SQL使用方法: SHOW_NAV_ADMIN=#showNavAdmin,jdbcType=VARCHAR,javaType=boolean#
3. 如果是boolean类型, 那么bean里面应该定义为Booelean类型, 而不是基础类型boolean.
实现步骤:
第一步:编写自定义类型转换器
/** * */ package test.atfm.persistence.mybatis.handler; import java.sql.CallableStatement; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import org.apache.ibatis.type.JdbcType; import org.apache.ibatis.type.TypeHandler; /** * @author * java中的boolean和jdbc中的char之间转换;true-Y;false-N */ public class BooleanTypeHandler implements TypeHandler { /* (non-Javadoc) * @see org.apache.ibatis.type.TypeHandler#getResult(java.sql.ResultSet, java.lang.String) */ @Override public Object getResult(ResultSet arg0, String arg1) throws SQLException { String str = arg0.getString(arg1); Boolean rt = Boolean.FALSE; if (str.equalsIgnoreCase("Y")){ rt = Boolean.TRUE; } return rt; } /* (non-Javadoc) * @see org.apache.ibatis.type.TypeHandler#getResult(java.sql.CallableStatement, int) */ @Override public Object getResult(CallableStatement arg0, int arg1) throws SQLException { Boolean b = arg0.getBoolean(arg1); return b == true ? "Y" : "N"; } /* (non-Javadoc) * @see org.apache.ibatis.type.TypeHandler#setParameter(java.sql.PreparedStatement, int, java.lang.Object, org.apache.ibatis.type.JdbcType) */ @Override public void setParameter(PreparedStatement arg0, int arg1, Object arg2, JdbcType arg3) throws SQLException { Boolean b = (Boolean) arg2; String value = (Boolean) b == true ? "Y" : "N"; arg0.setString(arg1, value); } }
第二步:注册类型转换器
<?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> <properties resource="db.properties"></properties> <typeHandlers> <typeHandler javaType="Boolean" jdbcType="CHAR" handler="test.atfm.persistence.mybatis.handler.BooleanTypeHandler" /> </typeHandlers> <environments default="development"> <environment id="development"> <transactionManager type="JDBC" /> <dataSource type="POOLED"> <property name="driver" value="${driver}" /> <property name="url" value="${url}" /> <property name="username" value="${username}" /> <property name="password" value="${password}" /> </dataSource> </environment> </environments> </configuration>
第三步: 指定类型转换
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//ibatis.apache.org//DTD Mapper 3.0//EN" "http://ibatis.apache.org/dtd/ibatis-3-mapper.dtd"> <mapper namespace="test.atfm.persistence.mybatis.TestMapper"> <resultMap type="TestBean" id="TestBeanMap"> <id property="tname" column="tname" /> <result property="isCancel" column="iscancel" javaType="Boolean" jdbcType="CHAR"/> </resultMap> <select id="selectTest" resultMap="TestBeanMap"> select * from t_test </select> <insert id="insertTest" parameterType="TestBean"> insert into t_test(tname,iscancel) values(#{tname},#{isCancel jdbcType=CHAR javaType=Boolean}) </insert> </mapper>
这样mybatis就能将数据库中的类型与java中的类型自动做转换了。其他类型转方法同上。
发表评论
-
spring配置事物的方式:注解和aop配置
2016-05-14 00:26 4101参考: Spring AOP中pointcut express ... -
写个mybatis的拦截插件,实现将所有执行的sql写入文件里
2016-05-12 15:59 5104原文 http://3131854.blog.51cto.co ... -
Mybatis分库分表扩展插件
2016-05-12 15:47 1620http://fangjialong.iteye.com/bl ... -
spring+mybatis+atomikos 实现JTA事务
2016-05-11 22:00 5522sping配置多个数据源 不同用户操作不同数据库 http:/ ... -
ibatis扩展支持主键生成的方法(非数据库方式)
2016-04-13 22:01 976http://blog.csdn.net/warison200 ... -
ibatis 动态 Mapped Statement
2016-03-31 17:02 855http://www.cnblogs.com/lcngu/p/ ... -
分布式事务管理
2016-03-31 16:43 1037http://my.oschina.net/pingpangk ... -
ibatis中动态查询表返回用resultClass="java.util.HashMap" 的问题
2016-03-11 10:49 1124http://blog.csdn.net/dyllove98/ ... -
Mybatis传多个参数(三种解决方案)
2016-03-07 17:46 1445http://my.oschina.net/ydsakyclg ... -
mybatis --mapper配置文件中大于小于怎么处理
2016-03-04 14:21 2404http://blog.csdn.net/nich002/ar ... -
Mybatis 数据库物理分页插件 PageHelper
2015-11-28 01:09 2791http://www.cnblogs.com/digdeep/ ... -
Druid 的SQL翻译功能如何使用
2015-11-27 21:40 1972Druid是阿里巴巴开源平台上的一个项目,整个项目由数据库连接 ... -
[MyBatis]mapperLocations属性通配符的使用
2015-11-26 10:49 6219http://blog.csdn.net/szwangdf/a ... -
Hibernate Validation使用示例及讲解
2015-11-22 21:06 2752http://wdmcygah.iteye.com/blog/ ... -
MyBatis排序时使用order by 动态参数时需要注意,用$而不是#
2015-11-17 17:54 20171http://blog.csdn.net/weibing_hu ... -
SpringMVC + Mybatis + Shiro 权限整合
2015-11-14 14:06 8746详细见参考文章: 基于Spring + Spring MVC ... -
MyBatis3 的Mapper XML 文件详解
2015-11-13 11:54 1355MyBatis3 的Mapper XML 文件http://m ... -
HibernateDao.java
2015-11-10 15:55 1162http://my.oschina.net/lizy/blog ... -
Hibernate envers开发指南
2015-10-24 00:44 1234http://www.blogjava.net/xmatthe ... -
Spring+Ibatis数据库水平分库
2015-09-13 21:15 1295Spring+Ibatis数据库水平分库 http://blo ...
相关推荐
"Mybatis自定义类型转换器的使用技巧" Mybatis自定义类型转换器的使用技巧是指在Mybatis框架中,使用自定义类型转换器来实现类型之间的转换,以满足特殊的业务需求。在这篇文章中,我们将详细介绍Mybatis自定义类型...
在MyBatis中,自定义类型转换器是用于处理特定数据类型与数据库字段之间的转换,以便在持久化操作中满足特定需求,如本例中的加解密。在需求场景中,如果你希望数据库中存储的数据(如敏感信息)在存储前进行加密,...
注册自定义转换器有两种方式: - 直接在Spring配置文件中使用`<mvc:annotation-driven conversion-service="conversionServiceRef">`,然后在bean定义中指定`ConversionService`。 - 或者通过编程式注册,例如在...
本项目示例"1.springboot+mybatis项目demo2.mybatis自定义枚举类型的转换器以及各种使用场景"着重展示了如何在Spring Boot应用中集成MyBatis,并利用MyBatis处理枚举类型的数据。 首先,我们来了解Spring Boot。...
在某些场景下,MyBatis内置的类型转换器可能无法满足我们的需求,这时就需要我们自定义TypeHandler。下面将详细介绍如何在MyBatis中实现自定义类型转换器。 首先,我们需要了解MyBatis的基本概念。MyBatis是一个...
总的来说,这个定制版的MyBatis Generator不仅提供了中文注释以增强可读性,还优化了默认的类型转换,使得生成的代码更符合实际开发需求,特别是在处理可能超出`Byte`范围的整数字段时。通过理解这个工具的特点和...
1. 自定义TypeHandler:当MyBatis内置的TypeHandler无法满足需求时,可以编写自定义TypeHandler,覆盖默认的类型转换逻辑,如处理自定义枚举类型、复杂对象等。 2. 自定义Executor:Executor是MyBatis的执行器,...
在本项目中,我们主要探讨了四个核心主题:Spring Boot与MyBatis的整合、MyBatis中的枚举转换器、前后端分离项目的统一JSON返回格式以及Spring Boot集成Quartz框架来实现定时任务。让我们逐一深入这些关键知识点。 ...
在本项目中,我们主要探讨的是如何将Spring Boot与MyBatis、Druid以及自定义消息转换器(MessageConverter)进行集成,以构建一个高效、可扩展的应用程序。Spring Boot以其简洁的配置和快速的开发体验深受开发者喜爱...
4. 字段类型转换:生成器可能无法准确识别所有数据库类型的Java对应类型,可能需要手动调整。 5. 更新维护:生成的代码只是一个基础模板,随着业务需求的变化,可能需要对生成的代码进行适当的修改和扩展。 综上所...
此外,代码生成器还支持自定义类型转换,如果内置的数据库字段类型转换不能满足需求,可以通过实现ITypeConvert接口来自定义转换规则。同时,还支持自定义数据库查询SQL语句,通过实现IDbQuery接口即可。 在自定义...
MyBatis拦截器是MyBatis框架中的一种插件机制,允许用户自定义代码来扩展MyBatis的功能。在这个特定的实例中,我们讨论的是一个用于给参数对象属性赋值的拦截器。这个拦截器的主要目标是在执行增删改操作时,自动为...
在MyBatis中,我们可以创建自定义拦截器来处理分页逻辑,避免在每个Mapper接口或Service层都需要手动添加分页代码。`PaginationInterceptor`通常会自动计算总页数,根据请求的页码和每页数量对SQL进行修改,添加...
4. **字段处理**:对于数据库表中的字段,MyBatis-Plus代码生成器会自动进行驼峰命名转换,使得Java变量名更符合编程规范。同时,还可以配置哪些字段需要生成,哪些不需要。 5. **主键策略**:MyBatis-Plus支持多种...
"CXF3.1.16 +Spring4 +MyBatis + Maven自定义拦截器 WebService实例源码下载" 这个标题揭示了该项目的核心技术栈,包括: 1. CXF 3.1.16:这是一个开源的服务框架,用于构建和开发服务,支持SOAP和RESTful Web服务...
3. 自动类型映射:MyBatis能自动将数据库结果集转换为Java对象,同时也支持自定义的类型处理器以处理特定类型的映射。 4. 缓存机制:MyBatis内置了本地缓存和二级缓存,能够提高数据读取效率,减少对数据库的访问。...
或者研究TypeHandler,针对特定类型开发自定义的类型处理器;还可以研究Mapper的动态加载机制,提高应用的灵活性。总之,掌握源码对于深入理解MyBatis的工作机制、提升开发效率和解决实际问题具有重要意义。
结果映射则可以处理单表查询、多表联查及自定义类型转换。 7. **缓存机制** MyBatis提供了本地缓存和二级缓存,可以提高查询效率,减少对数据库的访问。 8. **事务管理** MyBatis3允许开发者自定义事务管理器,...
8. 自动类型匹配:Mybatis能自动识别JDBC驱动返回的类型并将其转换为Java类型,同时允许开发者通过`typeHandler`自定义类型处理器。 9. 异常处理:Mybatis有一套完整的异常体系,如`...
- 当需要处理自定义类型时,可以通过实现`TypeHandler`接口,自定义类型转换逻辑。 总的来说,MyBatis 3.2.7版提供了全面的数据库操作支持,简化了传统的JDBC编程,让开发者更专注于业务逻辑,而不用过多关注底层...