热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

MyBatis入门之增删改查+数据库字段和实体字段不一致问题处理方法

这篇文章主要介绍了MyBatis入门之增删改查+数据库字段和实体字段不一致问题处理方法,需要的朋友可以参考下

当数据库字段和实体bean中属性不一致时

之前数据库Person名字字段是name,PersonBean中属性也是name,但是之后数据库中修改为了user_name,

方法1:通过sql语句的字段起别名,别名和实体中的对象属性一致

SELECT id,user_name as name,sex,age from person

方法2: mybatis最强大的地方 : reslutMap对象

添加一个中介reslutMap标签,并将select标签中的resultType改为resultMap,并对应resultMap标签的id.

结果集:resultType 基础类型,int,string,Person,

resultMap 针对中介标签resultMap而存在.



 
 
  
  
  
  
 
 
 
 
 
 

    mybatis的增删改查

新增人员信息

首先在PersonMapper.xml中添加insert标签,我们的数据库字段user_name,Person实体属性为name,不一致,区别开来.然后在TestMybatis中写入代码.


 
  INSERT INTO person(id,user_name,age,sex) VALUES(#{id},#{name},#{age},#{sex})
 

package test;

import com.luogg.domain.Person;
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 org.junit.Before;
import org.junit.Test;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
/**
 * Created by luogg on 2017/2/17.
 */
public class TestMybatis {
 //SqlSessionFactory为线程安全的
 private SqlSessionFactory factory;
 @Before
 public void init() throws IOException {
  String resource = "sqlMapConfig.xml";
  InputStream is = Resources.getResourceAsStream(resource);
  factory = new SqlSessionFactoryBuilder().build(is);
 }
 @Test //查询所有
 public void findAll() throws IOException {
  /**
   * 测试数据库的连接
   * 1.定义一个String类型的变量resource,指向刚才配置的连接数据库的xml文件
   * 2.创建一个输入流,来读取我们的数据库配置文件
   * 3.输入流创建工厂.
   * 4.有了工厂之后open工厂
   * 5.通过session访问配置文件中的sql语句
   */
  SqlSession session = factory.openSession();
  //如何访问PersonMapper.xml中的sql语句呢? 命名空间+ .id
  List list = session.selectList("com.luogg.mapper.PersonMapper.find");
  System.out.println(list.size());
  for(Person p : list){
   System.out.println(p);
  }
 }
 @Test //通过ID查询人员信息
 public void selById(){
  SqlSession session = factory.openSession();
  Person p = session.selectOne("com.luogg.mapper.PersonMapper.selById",1);
  System.out.println(p);
 }
 @Test //添加人员信息
 public void add(){
  SqlSession session = factory.openSession();
  Person p = new Person();
  p.setId(4);
  p.setName("luogg");
  p.setAge(22);
  p.setSex(1);
  int i = session.insert("com.luogg.mapper.PersonMapper.insert",p);
  session.commit();
  if(i==1){
   System.out.print("添加人员成功");
  }
 }
}

修改人员信息 , 查询总的记录条数

prsonMapper.xml文件


 
  UPDATE person SET user_name=#{name},age=#{age} WHERE id=#{id}
 
 
 

TestMybatis.java文件

@Test //修改人员信息
 public void updatePer(){
  SqlSession session = factory.openSession();
  Person p = new Person();
  p.setId(4);
  p.setName("luoggg");
  //p.setSex(1);
  p.setAge(23);
  int i = session.update("com.luogg.mapper.PersonMapper.update",p);
  session.commit();
  if(i==1){
   System.out.print("修改信息成功");
  }
 }
 @Test //查询总的记录条数
 public void selCount(){
  SqlSession session = factory.openSession();
  int i = session.selectOne("com.luogg.mapper.PersonMapper.count");
  System.out.println(i);
 }

条件查询

根据条件查询


 
@Test //带条 件查询
 public void selByL(){
  SqlSession session = factory.openSession();
  Map map = new HashMap();
  map.put("name","luo%");
  map.put("sex",1);
  List list = session.selectList("com.luogg.mapper.PersonMapper.selByL",map);
  System.out.println(list.size());
  for(Person p : list){
   System.out.println(p);
  }
 }

以上所述是小编给大家介绍的MyBatis入门之增删改查+数据库字段和实体字段不一致问题处理方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!


推荐阅读
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文介绍了adg架构设置在企业数据治理中的应用。随着信息技术的发展,企业IT系统的快速发展使得数据成为企业业务增长的新动力,但同时也带来了数据冗余、数据难发现、效率低下、资源消耗等问题。本文讨论了企业面临的几类尖锐问题,并提出了解决方案,包括确保库表结构与系统测试版本一致、避免数据冗余、快速定位问题等。此外,本文还探讨了adg架构在大版本升级、上云服务和微服务治理方面的应用。通过本文的介绍,读者可以了解到adg架构设置的重要性及其在企业数据治理中的应用。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • MyBatis错题分析解析及注意事项
    本文对MyBatis的错题进行了分析和解析,同时介绍了使用MyBatis时需要注意的一些事项,如resultMap的使用、SqlSession和SqlSessionFactory的获取方式、动态SQL中的else元素和when元素的使用、resource属性和url属性的配置方式、typeAliases的使用方法等。同时还指出了在属性名与查询字段名不一致时需要使用resultMap进行结果映射,而不能使用resultType。 ... [详细]
  • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
    本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 本文介绍了使用cacti监控mssql 2005运行资源情况的操作步骤,包括安装必要的工具和驱动,测试mssql的连接,配置监控脚本等。通过php连接mssql来获取SQL 2005性能计算器的值,实现对mssql的监控。详细的操作步骤和代码请参考附件。 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • Activiti7流程定义开发笔记
    本文介绍了Activiti7流程定义的开发笔记,包括流程定义的概念、使用activiti-explorer和activiti-eclipse-designer进行建模的方式,以及生成流程图的方法。还介绍了流程定义部署的概念和步骤,包括将bpmn和png文件添加部署到activiti数据库中的方法,以及使用ZIP包进行部署的方式。同时还提到了activiti.cfg.xml文件的作用。 ... [详细]
  • 本文讨论了在shiro java配置中加入Shiro listener后启动失败的问题。作者引入了一系列jar包,并在web.xml中配置了相关内容,但启动后却无法正常运行。文章提供了具体引入的jar包和web.xml的配置内容,并指出可能的错误原因。该问题可能与jar包版本不兼容、web.xml配置错误等有关。 ... [详细]
  • 目录浏览漏洞与目录遍历漏洞的危害及修复方法
    本文讨论了目录浏览漏洞与目录遍历漏洞的危害,包括网站结构暴露、隐秘文件访问等。同时介绍了检测方法,如使用漏洞扫描器和搜索关键词。最后提供了针对常见中间件的修复方式,包括关闭目录浏览功能。对于保护网站安全具有一定的参考价值。 ... [详细]
  • Java如何导入和导出Excel文件的方法和步骤详解
    本文详细介绍了在SpringBoot中使用Java导入和导出Excel文件的方法和步骤,包括添加操作Excel的依赖、自定义注解等。文章还提供了示例代码,并将代码上传至GitHub供访问。 ... [详细]
  • 大数据Hadoop生态(20)MapReduce框架原理OutputFormat的开发笔记
    本文介绍了大数据Hadoop生态(20)MapReduce框架原理OutputFormat的开发笔记,包括outputFormat接口实现类、自定义outputFormat步骤和案例。案例中将包含nty的日志输出到nty.log文件,其他日志输出到other.log文件。同时提供了一些相关网址供参考。 ... [详细]
author-avatar
宅妈每日贴_889
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有