4、Mybatis中实体类bean的属性名与数据库表中对应字段名不同

本文主要是介绍4、Mybatis中实体类bean的属性名与数据库表中对应字段名不同,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

例如一个USER表中一个字段为name,在工程中创建的USER表对应的bean为User,其中一个属性为user_name,在Mybaits中的sql映射文件中一定要映射字段,否则会操作sql不正确。下面以两种方式为示例:
表如下:
这里写图片描述

一、在sql语句中进行映射

1、创建表对应的实体类User,类中的属性名与表USER中的字段名不一致。

package com.lzj.mybaits.test1;public class User {private int user_id;private String user_name;private int user_age;public User() {super();}public User(int user_id, String user_name, int user_age) {super();this.user_id = user_id;this.user_name = user_name;this.user_age = user_age;}public int getUser_id() {return user_id;}public void setUser_id(int user_id) {this.user_id = user_id;}public String getUser_name() {return user_name;}public void setUser_name(String user_name) {this.user_name = user_name;}public int getUser_age() {return user_age;}public void setUser_age(int user_age) {this.user_age = user_age;}@Overridepublic String toString() {return "User [user_id=" + user_id + ", user_name=" + user_name + ", user_age=" + user_age + "]";}}

2、以查询语句为例,定义sql的映射userMapper.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.lzj.mybaits.test1.userMapper"><!--由于conf.xml文件中已经配置了<typeAliases><package name="com.lzj.mybaits.test1"/></typeAliases>所以select语句返回的类型不用带包名,直接写类的名字User就可以了。--><select id="getUser" parameterType="int" resultType="User"><!--在select语句中,直接把表中的id、name、age字段分别映射成实体类User中的user_id、user_name、user_age属性-->select id user_id, name user_name, age user_agefrom users where id=#{id}</select></mapper>

3、定义Mybaits的配置文件conf.xml

<?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><typeAliases><package name="com.lzj.mybaits.test1"/></typeAliases><environments default="development"><environment id="development"><transactionManager type="JDBC" /><dataSource type="POOLED"><property name="driver" value="com.mysql.jdbc.Driver" /><property name="url" value="jdbc:mysql://localhost:3306/lzj_database" /><property name="username" value="root" /><property name="password" value="lzjlzj" /></dataSource></environment></environments><mappers><mapper resource="com/lzj/mybaits/test1/userMapper.xml"/></mappers></configuration>

4、定义测试类

package com.lzj.mybaits.test1;
import java.io.InputStream;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;public class MybaitsTest {public static void main(String[] args) throws Exception {String resource = "conf.xml";InputStream in = MybaitsTest.class.getClassLoader().getResourceAsStream(resource);SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in);/*自动提交事务*/SqlSession session = factory.openSession(true);String statement = "com.lzj.mybaits.test1.userMapper.getUser";User user = session.selectOne(statement, 3);System.out.println(user);session.close();}}

运行测试类,输出结果如下

User [user_id=3, user_name=lzj, user_age=25]

二、通过<resultMap>指定字段映射

大多数情况下可以通过<resultMap> 标签指定表中字段和实体类中属性的映射。修改上面sql的userMapper.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.lzj.mybaits.test1.userMapper"><!--type属性指定要映射的那个实体类,由于在conf.xml中已经用`<typeAliases>`配置了包名,故此地不用写全类名--><resultMap type="User" id="userResult"><!--主键用<id>标签,表示把表中的id字段映射到实体类User中的user_id属性--><id property="user_id" column="id"/><!--非主键用<reslut>标签,表示把表中的name字段映射到实体类User的user_name属性--><result property="user_name" column="nane"/><result property="user_age" column="age"/></resultMap><!--resultMap属性指定该select语句返回的结果要映射到User实体类中,并对字段和属性之间进行了映射-><!--#{id}为指定的int类型的传入的参数--><select id="getUser" parameterType="int" resultMap="userResult">select id, name, agefrom users where id=#{id}</select></mapper>

这篇关于4、Mybatis中实体类bean的属性名与数据库表中对应字段名不同的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/994230

相关文章

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

数据库面试必备之MySQL中的乐观锁与悲观锁

《数据库面试必备之MySQL中的乐观锁与悲观锁》:本文主要介绍数据库面试必备之MySQL中乐观锁与悲观锁的相关资料,乐观锁适用于读多写少的场景,通过版本号检查避免冲突,而悲观锁适用于写多读少且对数... 目录一、引言二、乐观锁(一)原理(二)应用场景(三)示例代码三、悲观锁(一)原理(二)应用场景(三)示例

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

Spring Boot项目中结合MyBatis实现MySQL的自动主从切换功能

《SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能》:本文主要介绍SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能,本文分步骤给大家介绍的... 目录原理解析1. mysql主从复制(Master-Slave Replication)2. 读写分离3.

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Mybatis 传参与排序模糊查询功能实现

《Mybatis传参与排序模糊查询功能实现》:本文主要介绍Mybatis传参与排序模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、#{ }和${ }传参的区别二、排序三、like查询四、数据库连接池五、mysql 开发企业规范一、#{ }和${ }传参的

CSS will-change 属性示例详解

《CSSwill-change属性示例详解》will-change是一个CSS属性,用于告诉浏览器某个元素在未来可能会发生哪些变化,本文给大家介绍CSSwill-change属性详解,感... will-change 是一个 css 属性,用于告诉浏览器某个元素在未来可能会发生哪些变化。这可以帮助浏览器优化

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

基于SpringBoot+Mybatis实现Mysql分表

《基于SpringBoot+Mybatis实现Mysql分表》这篇文章主要为大家详细介绍了基于SpringBoot+Mybatis实现Mysql分表的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录基本思路定义注解创建ThreadLocal创建拦截器业务处理基本思路1.根据创建时间字段按年进