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

MyBatis查询、新增、更新与删除操作指南

这篇文章主要给大家介绍了关于MyBatis查询、新增、更新与删除操作的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MyBatis具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

调试之控制台打印SQL

Mybatis的使用流程

先来回顾一下mybatis的使用流程

  • 创建mybatis-config.xml 全局的配置⽂件
  • 创建XXXMapper.xml配置⽂件
  • 创建SqlSessionFactory
  • ⽤SqlSessionFactory创建SqlSession对象
  • ⽤SqlSession执⾏增删改查CRUD

打印sql的配置

内置的⽇志⼯⼚提供⽇志功能, 使⽤log4j配置打印sql,添加依赖


 org.slf4j
 slf4j-log4j12
 1.7.30

在应⽤的classpath中创建名称为 log4j.properties 的⽂件

log4j.rootLogger=ERROR, stdout
log4j.logger.cn.junko=DEBUG
#打印更多的TRACE内容
#log4j.logger.cn.junko=TRACE
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.COnversionPattern=%5p [%t] - %m%n

这样,我们在执行操作数据库的时候就会有日志打印出来

查询

多个参数

当需要多个参数进行查询的时候,一般用到取别名,方便识别和使用

List

驼峰映射

前面也讲到,数据库字段是下划线,java属性是驼峰,怎么查询映射上去

方法: select cover_img as coverImg from video

但是多字段的时候怎么办,每个参数都进行as操作吗?这里就用到Mybatis的自带配置

 
 
 
 

这样就能够进行自动映射,例如cover_img会自动映射为coverImg

Mybatis入参parameterType

parameterType 参数类型

可以是基本类型

parameterType="java.lang.Long"
parameterType="java.lang.String"

也可以是JAVA集合List或者Map

parameterType="java.util.Map"
parameterType="java.util.List"

或者是自定义的对象

parameterType="cn.junko.domain.Video"

取参数值,具体某个字段的类型,从java类型映射到数据库类型

例⼦ #{title, jdbcType=VARCHAR}

注意:

  • 多数情况不加是正常使⽤,但是如果出现报错:⽆效的列类型,则是缺少jdbcType;
  • 只有当字段可为NULL时才需要jdbcType属性

常见的数据库类型和java列席对比

JDBC Type Java Type
CHAR String
VARCHAR String
LONGVARCHAR String
NUMERIC java.math.BigDecimal
DECIMAL java.math.BigDecimal
BIT boolean
BOOLEAN boolean
TINYINT byte
SMALLINT short
INTEGER INTEGER
INTEGER int
BIGINT long
REAL float
FLOAT double
DOUBLE double
BINARY byte[]
VARBINARY byte[]
LONGVARBINARY byte[]
DATE java.sql.Date
TIME java.sql.Time
TIMESTAMP java.sql.Timestamp
CLOB Clob
BLOB Blob
ARRAY Array
DISTINCT mapping of underlying type
STRUCT Struct
REF Ref
DATALINK java.net.URL

插入

编写mapper


  INSERT INTO `video`(`title`, `summary`, `cover_img`, `price`, `create_time`, `c_id`, `point`)
  VALUES (#{title},#{summary},#{coverImg},#{price},#{createTime},#{cid},#{point});
 

获取自增主键,则需要在标签头加入这三段,即可自动映射到实体类中
useGeneratedKeys="true" keyProperty="id" keyColumn="id"

测试

@Test
 public void addVideo(){
  Video video = new Video();
  video.setTitle("测试数据3");
  video.setSummary("nihao.com");
  video.setCoverImg("wangyi");
  video.setPrice(8777);
  video.setCreateTime(new Date());
  video.setCid(7);
  video.setPoint(5.7);
  int rows = videoMapper.addVideo(video);
  System.out.println("自增主键:"+video.getId());
  System.out.println(video.toString());
 }

foreach 批量插入

foreach批量插⼊多条视频记录,⽤于循环拼接的内置标签,常⽤于 批量新增、in查询等常⻅

包含以下属性:

collection:必填,值为要迭代循环的集合类型,情况有多种
 ⼊参是List类型的时候,collection属性值为list
 ⼊参是Map类型的时候,collection 属性值为map的key值

item:每⼀个元素进⾏迭代时的别名
index:索引的属性名,在集合数组情况下值为当前索引值,当迭代对象是map时,这个值是
map的key
open:整个循环内容的开头字符串
close:整个循环内容的结尾字符串
separator: 每次循环的分隔符

例子
需要注意的是item别名取值iteam.xxx


  INSERT INTO `video`(`title`, `summary`, `cover_img`, `price`, `create_time`, `c_id`, `point`)
  VALUES
  
  (#{video.title},#{video.summary},#{video.coverImg},#{video.price},#{video.createTime},#{video.cid},#{video.point})
  
 
list.add(video1);
  list.add(video2);
  int rows = videoMapper.addVideoList(list);
  System.out.println(list);

主键自增同样适用

更新

普通的更新比较简单,这里使用一下if test标签

  • 可以选择性更新⾮空字段
  • if test标签介绍
    • if 标签可以通过判断传⼊的值来确定查询条件,test 指定⼀个OGNL表达式
    • 常⻅写法
//当前字段符合条件才更新这个字段的值
 title = #{title}, 
 title = #{title}, 

代码


 
  UPDATE `video`
  
   `title` = #{title},
   `summary` = #{summary},
   `cover_img` = #{coverImg},
   `price` = #{price},
   `create_time` = #{createTime},
   `c_id` = #{cid},
   `point` = #{point}
  
  WHERE `id` = #{id};
 

⼀定要看pojo类⾥⾯的是基本数据类型,还是包装数据类型

删除

delete删除语法

需求:删除某个时间段之后 且⾦额⼤于 10元的数据


 delete from video where create_time  ]]> #{createTime}
and price = ]]> #{price}

为什么要转义字符:

由于MyBatis的sql写在XML⾥⾯, 有些sql的语法符号和xml⾥⾯的冲突

⼤于等于 = ]]>
⼩于等于

总结

到此这篇关于MyBatis查询、新增、更新与删除操作指南的文章就介绍到这了,更多相关MyBatis查询、新增、更新删除操作内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!


推荐阅读
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
    本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 本文介绍了使用cacti监控mssql 2005运行资源情况的操作步骤,包括安装必要的工具和驱动,测试mssql的连接,配置监控脚本等。通过php连接mssql来获取SQL 2005性能计算器的值,实现对mssql的监控。详细的操作步骤和代码请参考附件。 ... [详细]
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • r2dbc配置多数据源
    R2dbc配置多数据源问题根据官网配置r2dbc连接mysql多数据源所遇到的问题pom配置可以参考官网,不过我这样配置会报错我并没有这样配置将以下内容添加到pom.xml文件d ... [详细]
  • 本文是关于自学Android的笔记,包括查看类的源码的方法,活动注册的必要性以及布局练习的重要性。通过学习本文,读者可以了解到在自学Android过程中的一些关键点和注意事项。 ... [详细]
  • 本文讨论了如何在codeigniter中识别来自angularjs的请求,并提供了两种方法的代码示例。作者尝试了$this->input->is_ajax_request()和自定义函数is_ajax(),但都没有成功。最后,作者展示了一个ajax请求的示例代码。 ... [详细]
  • 突破MIUI14限制,自定义胶囊图标、大图标样式,支持任意APP
    本文介绍了如何突破MIUI14的限制,实现自定义胶囊图标和大图标样式,并支持任意APP。需要一定的动手能力和主题设计师账号权限或者会主题pojie。详细步骤包括应用包名获取、素材制作和封包获取等。 ... [详细]
  • 网络请求模块选择——axios框架的基本使用和封装
    本文介绍了选择网络请求模块axios的原因,以及axios框架的基本使用和封装方法。包括发送并发请求的演示,全局配置的设置,创建axios实例的方法,拦截器的使用,以及如何封装和请求响应劫持等内容。 ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
author-avatar
077是个好姑娘
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有