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

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作

在 Spring Boot 中使用 @Autowired和 @Bean注解的示例详解

《在SpringBoot中使用@Autowired和@Bean注解的示例详解》本文通过一个示例演示了如何在SpringBoot中使用@Autowired和@Bean注解进行依赖注入和Bean... 目录在 Spring Boot 中使用 @Autowired 和 @Bean 注解示例背景1. 定义 Stud

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

SpringBoot+MyBatis-Flex配置ProxySQL的实现步骤

《SpringBoot+MyBatis-Flex配置ProxySQL的实现步骤》本文主要介绍了SpringBoot+MyBatis-Flex配置ProxySQL的实现步骤,文中通过示例代码介绍的非常详... 目录 目标 步骤 1:确保 ProxySQL 和 mysql 主从同步已正确配置ProxySQL 的

MyBatis-Flex BaseMapper的接口基本用法小结

《MyBatis-FlexBaseMapper的接口基本用法小结》本文主要介绍了MyBatis-FlexBaseMapper的接口基本用法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具... 目录MyBATis-Flex简单介绍特性基础方法INSERT① insert② insertSelec

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多