文档章节

MyBatis笔记(六)——类属性名与表字段名不一致该怎么办

HappyBKs
 HappyBKs
发布于 2015/07/05 15:07
字数 1082
阅读 307
收藏 2

 之前的博客我们介绍了如何将类与表进行映射,如何在此基础上CRUD操作。在那些例子中,我们假定表的字段名称与类的属性名称是相同且一一对应的。但实际情况是,类的设计人与数据库的设计人往往没有那种默契,对于小小的coder来说应该怎么办呢?一个人很多时候需要当别人的润滑剂和连接点,就像搞定导师和老板的关系一样、搞定老妈和MM的关系一样、搞定开发和运维的关系一样,还有搞定类的属性名和表的字段名的命名不一致一样。

好吧,我们首先将类和表都定义好。(本文出自:http://my.oschina.net/happyBKs/blog/474840)

CREATE TABLE orders(
	order_id INT PRIMARY KEY AUTO_INCREMENT,
	order_no VARCHAR(20), 
	order_priceorders FLOAT
);
INSERT INTO orders(order_no, order_price) VALUES('aaaa', 23);
INSERT INTO orders(order_no, order_price) VALUES('bbbb', 33);
INSERT INTO orders(order_no, order_price) VALUES('cccc', 22);

类定义:

package com.happyBKs.mybatis.C1_1.beans;

public class Order {
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getOrderNo() {
		return orderNo;
	}
	public void setOrderNo(String orderNo) {
		this.orderNo = orderNo;
	}
	public float getPrice() {
		return price;
	}
	public void setPrice(float price) {
		this.price = price;
	}
	private int id;
	private String orderNo;
	private float price;
	public Order(int id, String orderNo, float price) {
		super();
		this.id = id;
		this.orderNo = orderNo;
		this.price = price;
	}
	public Order() {
		super();
	}
	@Override
	public String toString() {
		return "Order [id=" + id + ", orderNo=" + orderNo + ", price=" + price
				+ "]";
	}
	
	
}

好,现在我们正式介绍当表与类的属性命名不一致的解决办法。办法有两种:

利用SQL语句的返回字段指定字段别名,别名需要与类的属性名一致,这样mybatis会自动将表的字段名和类的属性名进行关联匹配。但是,这种方法一般只适合用于select的情况,update、delete、insert不方便指定字段别名。

所以,按照这种方法,我写了一个orderMapper.xml:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> 
<mapper namespace="com.happyBKs.mybatis.C1_1.orderMapper"> 

	<!-- 根据id查询对象 -->
	<select id="getOrder" parameterType="int" resultType="com.happyBKs.mybatis.C1_1.beans.Order">
		select order_id id, order_no orderNo,order_price price from orders where order_id=#{id}
	</select>

</mapper>

如果我们想在CUD中解决这个问题,就需要应用第二种方法,即指定parameterMap或resultMap。parameterMap会对输入参数的类进行字段属性映射,resultMap会对返回的对象进行字段属性映射。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.happyBKs.mybatis.C1_1.orderMapper2">

	<select id="selectOrderResultMap" parameterType="int" resultMap="orderResultMap">
		select * from orders where order_id=#{id}
	</select>

	<resultMap type="com.happyBKs.mybatis.C1_1.beans.Order" id="orderResultMap">
		<id property="id" column="order_id" />
		<result property="orderNo" column="order_no" />
		<result property="price" column="order_price" />
	</resultMap>

	<parameterMap type="com.happyBKs.mybatis.C1_1.beans.Order" id="orderParameterMap">
		<parameter property="id" />
		<parameter property="orderNo" />
		<parameter property="price" />
	</parameterMap>
	
	<insert id="insertOrderResultMap" parameterMap="orderParameterMap">
		insert into orders(order_id,order_no,order_price) values (#{id},#{orderNo},#{price})
	</insert>

</mapper>

测试一下上面的例子吧:

package com.happyBKs.mybatis.C1_1;

import java.io.IOException;
import java.io.Reader;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import com.happyBKs.mybatis.C1_1.beans.Order;

/**
 * Hello world!
 *
 */
public class App 
{
    public static void main( String[] args )
    {
		test3();
    }

	private static void test1() {
		String resource = "config.xml"; 
		//加载mybatis的配置文件(它也加载关联的映射文件)
		Reader reader=null;
		try {
			reader = Resources.getResourceAsReader(resource);
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} 
		//构建sqlSession的工厂
		SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(reader);
		//创建能执行映射文件中sql的sqlSession
		SqlSession session = sessionFactory.openSession();
		//映射sql的标识字符串
		String statement = "com.happyBKs.mybatis.C1_1.orderMapper"+".getOrder";//先找映射文件,后找标签
		//执行查询返回一个唯一user对象的sql
		Order order = session.selectOne(statement, 2);
		System.out.println(order);
	}
	
	
	private static void test2() {
		String resource = "config.xml"; 
		//加载mybatis的配置文件(它也加载关联的映射文件)
		Reader reader=null;
		try {
			reader = Resources.getResourceAsReader(resource);
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} 
		//构建sqlSession的工厂
		SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(reader);
		//创建能执行映射文件中sql的sqlSession
		SqlSession session = sessionFactory.openSession();
		//映射sql的标识字符串
		String statement = "com.happyBKs.mybatis.C1_1.orderMapper2"+".selectOrderResultMap";//先找映射文件,后找标签
		//执行查询返回一个唯一user对象的sql
		Order order = session.selectOne(statement, 1);
		System.out.println(order);
	}
	
	
	private static void test3() {
		String resource = "config.xml"; 
		//加载mybatis的配置文件(它也加载关联的映射文件)
		Reader reader=null;
		try {
			reader = Resources.getResourceAsReader(resource);
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} 
		//构建sqlSession的工厂
		SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(reader);
		//创建能执行映射文件中sql的sqlSession
		SqlSession session = sessionFactory.openSession(true);
		//映射sql的标识字符串
		String statement = "com.happyBKs.mybatis.C1_1.orderMapper2"+".insertOrderResultMap";//先找映射文件,后找标签
		//执行查询返回一个唯一user对象的sql
		int n = session.insert(statement, new Order(-1,"hhhh",12.0f));
		System.out.println(n);
	}
}


© 著作权归作者所有

HappyBKs

HappyBKs

粉丝 654
博文 306
码字总数 481268
作品 0
浦东
程序员
私信 提问
jingrenlang/mybatis-mapper

#mybatis-mapper Mapper继承CrudMapper后,无需编写mapper.xml文件,即可获得CRUD功能 MyBatis的sql默认加载规则 MyBatis通过xml、SqlProvider两种方式获取sql,xml的优先级高于SqlProvider...

jingrenlang
2015/08/05
0
0
继承 Crud Mapper 的--mybatis-mapper

Mybatis-mapper Mapper 继承 CrudMapper 后,无需编写 mapper.xml 文件,即可获得 CRUD 功能 MyBatis 的 sql 默认加载规则 MyBatis通过xml、SqlProvider两种方式获取sql,xml的优先级高于Sql...

jingrenlang
2015/08/05
2.7K
1
JeeSite|保存信息修改记录续

接上一篇JeeSite|保存信息修改记录 - 简书。 遗留问题 上篇文章中遗留了一个问题,就是为了要关联类属性与注释,注释与字典的地方使用了两个map来逐个添加了相关的信息,如下所示: 在例子中...

秋风似刀
2017/11/08
0
0
Golang 学习笔记(12)—— ORM实现

本文为转载,原文:Golang 学习笔记(12)—— ORM实现 Golang 介绍 本文将利用之前所学习到的内容实现一个简单的orm,实现比较简单,没有考虑过多的设计原则,以及性能安全之类的,只是单纯...

ChainZhang
2018/01/10
0
0
SpringJDBC与MyBatis

SpringJDBC与MyBatis;实体类属性与数据库表字段名不一致的解决方法; -----------------------------------------------------------------------------------------------------------------......

Romanceling
2016/06/02
35
0

没有更多内容

加载失败,请刷新页面

加载更多

微信小程序和百度小程序开发的一些不同点

1: initActive从onload放到onready中 2: bindtap='{{childTickeData.freeadd?"childticket":""}}',语法错误。会导致页面加载不出来,而且也不报任何错。 3:使用搬家工具,支付api名称转换......

醉雨
5分钟前
0
0
最近执行过的SQL语句查询

SELECT TOP 1000 ST.text AS '执行的SQL语句' , QS.execution_count AS '执行次数' , QS.total_elapsed_time / 10000 AS '耗时' , QS.total_logical_reads AS '逻辑读取次数' , QS.total_lo......

神手--追魂
6分钟前
0
0
从濒临解散到浴火重生,OceanBase 这十年经历了什么?

阿里妹导读:谈及国产自研数据库,就不得不提 OceanBase。与很多人想象不同的是,OceanBase 并非衔着金钥匙出生的宠儿。相反,它曾无人看好、困难重重,整个团队甚至数度濒临解散。 从危在旦...

阿里云官方博客
10分钟前
0
0
阿里开发者招聘节 | 面试题02-04:给定一个二叉搜索树(BST),找到树中第K小的节点

为帮助开发者们提升面试技能、有机会入职阿里,云栖社区特别制作了这个专辑——阿里巴巴资深技术专家们结合多年的工作、面试经验总结提炼而成的面试真题这一次将陆续放出(面试题官方参考答案...

阿里云云栖社区
26分钟前
1
0
使用Redis SETNX 命令实现分布式锁

基于setnx和getset http://blog.csdn.net/lihao21/article/details/49104695 使用Redis的 SETNX 命令可以实现分布式锁,下文介绍其实现方法。 SETNX命令简介 命令格式 SETNX key value 将 ke...

彬彬公子
26分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部