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

相关文章

mysql数据库重置表主键id的实现

《mysql数据库重置表主键id的实现》在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,本文主要介绍了mysql数据库重置表主键id的实现,具有一定的参考价值,感兴趣的可以了... 目录关键语法演示案例在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,当我们

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma

MySQL中慢SQL优化的不同方式介绍

《MySQL中慢SQL优化的不同方式介绍》慢SQL的优化,主要从两个方面考虑,SQL语句本身的优化,以及数据库设计的优化,下面小编就来给大家介绍一下有哪些方式可以优化慢SQL吧... 目录避免不必要的列分页优化索引优化JOIN 的优化排序优化UNION 优化慢 SQL 的优化,主要从两个方面考虑,SQL 语

浅析CSS 中z - index属性的作用及在什么情况下会失效

《浅析CSS中z-index属性的作用及在什么情况下会失效》z-index属性用于控制元素的堆叠顺序,值越大,元素越显示在上层,它需要元素具有定位属性(如relative、absolute、fi... 目录1. z-index 属性的作用2. z-index 失效的情况2.1 元素没有定位属性2.2 元素处

Spring 中使用反射创建 Bean 实例的几种方式

《Spring中使用反射创建Bean实例的几种方式》文章介绍了在Spring框架中如何使用反射来创建Bean实例,包括使用Class.newInstance()、Constructor.newI... 目录1. 使用 Class.newInstance() (仅限无参构造函数):2. 使用 Construc

查看Oracle数据库中UNDO表空间的使用情况(最新推荐)

《查看Oracle数据库中UNDO表空间的使用情况(最新推荐)》Oracle数据库中查看UNDO表空间使用情况的4种方法:DBA_TABLESPACES和DBA_DATA_FILES提供基本信息,V$... 目录1. 通过 DBjavascriptA_TABLESPACES 和 DBA_DATA_FILES

Java实现数据库图片上传与存储功能

《Java实现数据库图片上传与存储功能》在现代的Web开发中,上传图片并将其存储在数据库中是常见的需求之一,本文将介绍如何通过Java实现图片上传,存储到数据库的完整过程,希望对大家有所帮助... 目录1. 项目结构2. 数据库表设计3. 实现图片上传功能3.1 文件上传控制器3.2 图片上传服务4. 实现

Mybatis从3.4.0版本到3.5.7版本的迭代方法实现

《Mybatis从3.4.0版本到3.5.7版本的迭代方法实现》本文主要介绍了Mybatis从3.4.0版本到3.5.7版本的迭代方法实现,包括主要的功能增强、不兼容的更改和修复的错误,具有一定的参考... 目录一、3.4.01、主要的功能增强2、selectCursor example3、不兼容的更改二、

mybatis-plus分页无效问题解决

《mybatis-plus分页无效问题解决》本文主要介绍了mybatis-plus分页无效问题解决,原因是配置分页插件的版本问题,旧版本和新版本的MyBatis-Plus需要不同的分页配置,感兴趣的可... 昨天在做一www.chinasem.cn个新项目使用myBATis-plus分页一直失败,后来经过多方

mybatis-plus 实现查询表名动态修改的示例代码

《mybatis-plus实现查询表名动态修改的示例代码》通过MyBatis-Plus实现表名的动态替换,根据配置或入参选择不同的表,本文主要介绍了mybatis-plus实现查询表名动态修改的示... 目录实现数据库初始化依赖包配置读取类设置 myBATis-plus 插件测试通过 mybatis-plu