BeanPropertyRowMapper使用注意事项
来源:互联网 发布:怎样在淘宝上做供货商 编辑:程序博客网 时间:2024/06/05 09:40
query过程都可以进行数据类型自动转换,而且不仅仅按标准命名,还可以支持下划线分隔后拼接成驼峰式字符
完全轻量级.
BeanPropertyRowMapper/ParameterizedBeanPropertyRowMapper ,如果PO和数据库模型的字段完全对应(字段名字一样或者驼峰式与下划线式对应),如果使用JdbcTemplate则可以使用这个RowMapper作为PO和数据库的映射
Spring 2.5 提供了一个便利的RowMapper实现-----BeanPropertyRowMapper
它可自动将一行数据映射到指定类的实例中 它首先将这个类实例化,然后通过名称匹配的方式,映射到属性中去。
例如:属性名称(vehicleNo)匹配到同名列或带下划线的同名列(VEHICLE_NO)。
如果某个属性不匹配则返回属性值为Null;
//用BeanPropertyRowMapper自动匹配
new BeanPropertyRowMapper(User.class)
SpringJDBC BeanPropertyRowMapper 查询的时候 一般的数据库字段都可以正常映射到 bean!
字段 bean属性
USER_NAME --> userName
USER_ID --> userId
但是碰到一些特殊的(暂不考虑命名是否合理)这就映射不上了!
比如:
ORDER_NUM2 --> OrderNum2 (should be orderNum2)
ORDER_NUM_3 OrderNum3
spring 提供框架的同时还提供了一种规范,包括命名规范,自动转换就会要求你javabean的成员变量命名符合规则,这个确实不太好搞,匹配不成功就变成null。
BeanPropertyRowMapper是根据字段名和实体类中的标准Setter方法进行映射滴。也就是说,我们需要使表中的字段名和实体类的成员变量名称一致。
大概看了下源码,ORDER_NUM2 --> OrderNum2 ORDER_NUM_3--> OrderNum3映射是有问题的。
protected void initialize(Class<T> mappedClass) {
this.mappedClass = mappedClass;
this.mappedFields = new HashMap<String, PropertyDescriptor>();
this.mappedProperties = new HashSet<String>();
PropertyDescriptor[] pds = BeanUtils.getPropertyDescriptors(mappedClass);
for (PropertyDescriptor pd : pds) {
if (pd.getWriteMethod() != null) {
this.mappedFields.put(pd.getName().toLowerCase(), pd);
String underscoredName = underscoreName(pd.getName());
if (!pd.getName().toLowerCase().equals(underscoredName)) {
this.mappedFields.put(underscoredName, pd);
}
this.mappedProperties.add(pd.getName());
}
}
}
/**
* Convert a name in camelCase to an underscored name in lower case.
* Any upper case letters are converted to lower case with a preceding underscore.
* @param name the string containing original name
* @return the converted name
*/
private String underscoreName(String name) {
StringBuilder result = new StringBuilder();
if (name != null && name.length() > 0) {
result.append(name.substring(0, 1).toLowerCase());
for (int i = 1; i < name.length(); i++) {
String s = name.substring(i, i + 1);
if (s.equals(s.toUpperCase())) {
result.append("_");
result.append(s.toLowerCase());
}
else {
result.append(s);
}
}
}
return result.toString();
}
着重看下underscoreName()方法,映射的字段只能映射到camel的javabean属性,所以你的映射是不是应该这样子的:ORDER_NUM2->orderNum2
- BeanPropertyRowMapper使用注意事项
- BeanPropertyRowMapper使用注意事项
- BeanPropertyRowMapper
- spring JdbcTemplate 查询,使用BeanPropertyRowMapper
- 使用NamedParameterJdbcTemplate 通过BeanPropertyRowMapper 返回一个对象或List 集合
- spring 2.5中的BeanPropertyRowMapper
- BeanPropertyRowMapper小错误
- BeanPropertyRowMapper类详解
- BeanPropertyRowMapper注意与访问权限
- Nhibernate实现类似 BeanPropertyRowMapper 的类型映射
- Masonry使用注意事项,原生约束使用注意事项
- String 使用注意事项
- 笔记本使用前注意事项
- HashMap使用的注意事项
- Hibnerate Annotation使用注意事项
- JChatbox使用注意事项
- Gridview+sqldatasource使用注意事项
- SVN使用注意事项之一
- iOS UI篇 - plist文件字典转模型
- Android开发错误集锦
- Agile Java(第一章)
- 关于ssh: connect to host master port 22: Connection timed out问题的总结
- 15个最容易得罪人的行为,却常常被我们忽略
- BeanPropertyRowMapper使用注意事项
- 防止c程序运行一闪而过
- android开发书籍推荐 重零开始
- 二维码生成工厂
- java程序运行时,数据的存储地!
- 线程的sleep()方法和yield()方法的区别
- 近期系统更新出现的问题记录
- Bochs 2.6.8的配置文件bochsrc.bxrc修改
- 为已有的web项目添加maven支持