利用Mybatis对数据库进行增删改查操作

文章目录

  • mybatis模糊查找
    • 先来了解一下 #{}和${}的使用
    • parameterType和resultType的使用
    • selectOne和selectList的使用
    • mysql自增主键返回
      • 方法一:mysql的函数函数返回
    • 方法二:定义useGeneratedKeys为true返回
    • Mysql使用 uuid实现主键
    • 看到UUID和自增长的id想必大家想了解它们的区别?
      • 增删改查操作
        • 目标对象:
        • xml数据源配置
        • mybatis xml映射文件配置
        • 测试类

mybatis模糊查找

先来了解一下 #{}和${}的使用

#{}表示一个占位符号,通过#{}可以实现preparedStatement向占位符中设置值,自动进行java类型和jdbc类型转换。#{}可以有效防止sql注入。 #{}可以接收简单类型值或pojo属性值。 如果parameterType传输单个简单类型值,#{}括号中可以是value或其它名称。#{}默认加单引号

${}表示拼接sql串,通过${}可以将parameterType 传入的内容拼接在sql中且不进行jdbc类型转换, ${}可以接收简单类型值或pojo属性值,如果parameterType传输单个简单类型值,${}括号中只能是value**。${}默认不加单引号

1.查询sql:

SELECT * FROM `user` WHERE username LIKE '%王%'

2.在User.xml配置文件中添加如下内容:

	<!-- 如果传入的参数是简单数据类型,${}里面必须写value --><select id="queryUserByUsername2" parameterType="string"resultType="cn.itcast.mybatis.pojo.User">SELECT * FROM `user` WHERE username LIKE '%${value}%'</select>
  1. 测试程序
    MybatisTest中添加测试方法如下:
@Test
public void testQueryUserByUsername2() throws Exception {// 4. 创建SqlSession对象SqlSession sqlSession = sqlSessionFactory.openSession();// 5. 执行SqlSession对象执行查询,获取结果User// 查询多条数据使用selectList方法List<Object> list = sqlSession.selectList("queryUserByUsername2", "王");// 6. 打印结果for (Object user : list) {System.out.println(user);}// 7. 释放资源sqlSession.close();
}

parameterType和resultType的使用

parameterType:

指定输入参数类型,mybatis通过ognl从输入对象中获取参数值拼接在sql中。

resultType:

指定输出结果类型,mybatis将sql查询结果的一行记录数据映射为resultType指定类型的对象。如果有多条数据,则分别进行映射,并把对象放到容器List中

selectOne和selectList的使用

selectOne:查询一条记录

User user = openSession.selectOne("queryUserById", 1);

selectList可以查询一条或多条记录。

List<User> user = openSession.selectList("queryUserByName", "hexiang");

记住:查询操作openSession不需要提交事务,而如果是增删改需要openSession.commit()来提交事务

mysql自增主键返回

方法一:mysql的函数函数返回

LAST_INSERT_ID():是mysql的函数,返回auto_increment自增列新记录id值。

<!-- 保存用户 -->
<insert id="saveUser" parameterType="cn.itcast.mybatis.pojo.User"><!-- selectKey 标签实现主键返回 --><!-- keyColumn:主键对应的表中的哪一列 --><!-- keyProperty:主键对应的pojo中的哪一个属性 --><!-- order:设置在执行insert语句前执行查询id的sql,孩纸在执行insert语句之后执行查询id的sql --><!-- resultType:设置返回的id的类型 --><selectKey keyColumn="id" keyProperty="id" order="AFTER"resultType="int">SELECT LAST_INSERT_ID()</selectKey>INSERT INTO `user`(username,birthday,sex,address) VALUES(#{username},#{birthday},#{sex},#{address})
</insert>

方法二:定义useGeneratedKeys为true返回

 <!-- 插入数据:返回记录主键id值 -->
<insert id="insert" useGeneratedKeys="true" keyProperty="id"  keyColumn="id">insert  into stu (name,age) values (#{name},#{age})
</insert>

获取新添加记录主键字段值

Integer rows = sqlSession.getMapper(StuMapper.class).insertOneTest(student);
System.out.println("rows = " + rows); // 添加操作返回记录数
System.out.println("id = " + student.getId()); // 执行添加操作之后通过Java对象获取主键属性值

推荐用方式二

Mysql使用 uuid实现主键

需要增加通过select uuid()得到uuid值,注意这里使用的order是“BEFORE”

<!-- 保存用户 -->
<insert id="saveUser" parameterType="cn.itcast.mybatis.pojo.User"><!-- selectKey 标签实现主键返回 --><!-- keyColumn:主键对应的表中的哪一列 --><!-- keyProperty:主键对应的pojo中的哪一个属性 --><!-- order:设置在执行insert语句前执行查询id的sql,孩纸在执行insert语句之后执行查询id的sql --><!-- resultType:设置返回的id的类型 --><selectKey keyColumn="id" keyProperty="id" order="BEFORE"resultType="string">SELECT LAST_INSERT_ID()</selectKey>INSERT INTO `user`(username,birthday,sex,address) VALUES(#{username},#{birthday},#{sex},#{address})
</insert>

看到UUID和自增长的id想必大家想了解它们的区别?

uuid是按照字符型存储(可以用string类型),正常自增长用的id是int类型占四个字节,当数据量非常大的时候就可以提现出id和uuid之间的区别,假设用500万个数据来模拟的话,id可以相对uuid节省2.5G空间,详细区别,可以问度娘.

增删改查操作

新建的项目中的列表用到的文件是User.java(目标对象)、TestDemo1.java(测试类)、SqlMapConfig.xml(数据库连接池配置)、User.xml(数据库增删查改配置)、jdbc.properties(配置信息:账户密码等)、log4j.properties(控制台打印日志):
这里写图片描述

目标对象:

User.java

package com.firtDay.sqlMapconFig;import java.io.Serializable;public class User implements Serializable {@Overridepublic String toString() {return "User [_name=" + _name + ", _money=" + _money + "]";}private Integer id;public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}private String _name;private int _money;public String get_name() {return _name;}public void set_name(String _name) {this._name = _name;}public int get_money() {return _money;}public void set_money(int _money) {this._money = _money;}}

xml数据源配置

SqlMapConfig.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>
<properties resource="jdbc.properties"></properties>
<typeAliases>
<!-- 给User类取别名 --><!-- <typeAlias type="com.firtDay.sqlMapconFig.User" alias="User"/> --><!-- 取别名以及其子包下所有类的别名,避免多个类都需要配置代码太多,利用包默认取包下类中所定义的名字 --><package name="com.firtDay.sqlMapconFig"/>
</typeAliases><!-- 和spring整合后 environments配置将废除 --><environments default="development"><environment id="development"><!-- 使用jdbc事务管理 --><transactionManager type="JDBC" /><!-- 数据库连接池 --><dataSource type="POOLED"><property name="driver" value="${driver}"/><property name="url"value="${url}" /><property name="username" value="${username}" /><property name="password" value="${password}" /></dataSource></environment></environments><!-- 加载映射文件的时候用到 --><mappers><!-- <mapper class="com.mapper.mapper"/> 使用这种方式加载mapper.xml必须把该xml文件放在mapper包下才能并且与mapper类名相同加载出来 。<package name=""/>package同理,用分最多的是package避免配置多个麻烦--><mapper resource="User.xml"/><mapper resource="mapper.xml"/> <!-- <package name="com.mapper"/> package用法,只需要把xml文件放在该mapper包下就会被扫描到,名称没有要求--></mappers>
</configuration>

mybatis xml映射文件配置

User.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">
<!-- namespace:命名空间,用于隔离sql,因为多个数据库都会用到queryUserById方法因此为了区分我们所调用的是哪个数据库中方法,因此设置名称空间来区别开来,调用方式:test.queryUserById。 -->
<mapper namespace="test"><!-- id="方法名" parameterType="参数类型" --><select id="queryUserById" parameterType="Integer"resultType="com.firtDay.sqlMapconFig.User">SELECT * FROM `t_user` WHERE id = #{id}</select><!-- like "%"#{v}"%"防SQL注入、默认不会自动添加单引号 '${value}'相反 --><select id="queryUserByName" parameterType="String"resultType="com.firtDay.sqlMapconFig.User">SELECT * FROM `t_user` WHERE _name like '%${value}%'</select><!-- 添加用户 --><insert id="addUser" parameterType="com.firtDay.sqlMapconFig.User"><!-- 获取主键  keyProperty="对应的主键的对象",resultType="主键数据类型",order="after:表示在下面insert语句后面执行,在mysql中是先插入再生成主键而Oracle中是先出主键在插入值因此用before"--><selectKey keyProperty="id" resultType="Integer" order="AFTER">select LAST_INSERT_ID()</selectKey>INSERT INTO t_user(_name,_money) values (#{_name},#{_money})</insert><update id="updateUser" parameterType="com.firtDay.sqlMapconFig.User">UPDATE t_user set _name = #{_name},_money = #{_money} WHERE id = #{id}</update><delete id="deleteUserById" parameterType="Integer">delete from t_user where id = #{id} </delete>
</mapper>

测试类

TestDemo1.java

package com.test;import java.io.InputStream;
import java.util.List;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 com.firtDay.sqlMapconFig.User;public class TestDemo1 {private SqlSessionFactory sqlSessionFactory=null;@Beforepublic void testDemo() throws Exception{// 1. 创建SqlSessionFactoryBuilder对象SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();String url="SqlMapConfig.xml";InputStream resource = Resources.getResourceAsStream(url);this.sqlSessionFactory = sqlSessionFactoryBuilder.build(resource);}@Testpublic void testDemo2(){SqlSession openSession = sqlSessionFactory.openSession();User user = openSession.selectOne("queryUserById", 1);System.out.println(user);openSession.close();}@Testpublic void testDemo3(){SqlSession openSession = sqlSessionFactory.openSession();List<User> user = openSession.selectList("queryUserByName", "hexiang");for (User user2 : user) {System.out.println(user2);}openSession.close();}	@Testpublic void testDemo4(){SqlSession openSession = sqlSessionFactory.openSession();User user = new User();user.set_name("hha");user.set_money(1000);int insert = openSession.insert("addUser", user);//返回值为影响的行数System.out.println(insert);openSession.commit();//需要提交事务System.out.println("id:"+user.getId());openSession.close();}//更新数据@Testpublic void testDemo5(){SqlSession openSession = sqlSessionFactory.openSession();User user = new User();user.setId(9);user.set_name("111xxxoooo");user.set_money(1000);int update = openSession.update("updateUser", user);openSession.commit();openSession.close();}//删除数据    @Testpublic void testDemo6(){SqlSession openSession = sqlSessionFactory.openSession();User user = new User();openSession.update("deleteUserById", 9);openSession.commit();openSession.close();}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/509390.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

原始Dao开发方法以及存在的问题

存在的问题&#xff1a; 原始Dao开发中存在以下问题&#xff1a; 1.Dao方法体存在重复代码&#xff1a;通过SqlSessionFactory创建SqlSession&#xff0c;调用SqlSession的数据库操作方法 2.调用sqlSession的数据库操作方法需要指定statement的id&#xff0c;这里存在硬编码&am…

聚合和组合的关系

转自&#xff1a;http://www.blogjava.net/lukangping/archive/2010/08/01/327693.html 记得在当时学习uml总是不好分清聚合与组合的关系&#xff0c;找工作时特地复习了这块的内容&#xff0c;结果正巧被面试官问道&#xff0c;这两天又在搞这块的内容&#xff0c;对聚合与组合…

Message Flood

题目描述 Well, how do you feel about mobile phone? Your answer would probably be something like that "Its so convenient and benefits people a lot". However, If you ask Merlin this question on the New Years Eve, he will definitely answer "Wh…

关联和依赖的区别

最近研究设计模式&#xff0c;看类图有点发虚&#xff01;有些关系搞的不是很清楚。所以整理一下&#xff1a; 类与类之间由弱到强关系是: 没关系 > 依赖 > 关联 > 聚合 > 组合。 类和类之间八竿子打不着那就是没关系&#xff0c;这个没啥歧义。 依赖(dependenc…

Mybatis解决jdbc编程的问题以及mybatis与hibernate的不同

Mybatis解决jdbc编程的问题: 1、 数据库连接创建、释放频繁造成系统资源浪费从而影响系统性能&#xff0c;如果使用数据库连接池可解决此问题。 解决&#xff1a;在SqlMapConfig.xml中配置数据连接池&#xff0c;使用连接池管理数据库链接。 2、 Sql语句写在代码中造成代码不…

C++继承详解:共有(public)继承,私有(private)继承,保护(protected)继承

转自&#xff1a;http://www.cnblogs.com/qlwy/archive/2011/08/25/2153584.html C继承&#xff1a;公有&#xff0c;私有&#xff0c;保护 公有继承(public)、私有继承(private)、保护继承(protected)是常用的三种继承方式。 1. 公有继承(public) 公有继承的特点是基类的公有成…

Mybatis中Mapper动态代理方式

文章目录开发规范Mapper接口开发需要遵循以下规范Mapper.xml(映射文件)UserMapper(接口文件)加载UserMapper.xml文件总结selectOne和selectList:namespace:开发规范 Mapper接口开发方法只需要程序员编写Mapper接口&#xff08;相当于Dao接口&#xff09;&#xff0c;由Mybatis…

数据结构实验之数组二:稀疏矩阵

题目描述 对于一个n*n的稀疏矩阵M(1 < n < 1000)&#xff0c;采用三元组顺序表存储表示&#xff0c;查找从键盘输入的某个非零数据是否在稀疏矩阵中&#xff0c;如果存在则输出OK&#xff0c;不存在则输出ERROR。稀疏矩阵示例图如下&#xff1a; 输入 连续输入多组数据…

C++模板-Traits

转自&#xff1a;http://blog.csdn.net/my_business/article/details/7891687介绍traits的文章很多&#xff0c;但感觉大部分文章的说明都很晦涩难懂&#xff0c;把一个并不很复杂的C模板的应用描述的过于复杂。忍不住想把自己的理解跟大家分享一下&#xff0c;或许我也只是掌握…

Mybatis中SqlMapConfig.xml配置文件的使用

文章目录SqlMapConfig.xml中配置的内容和顺序如下properties&#xff08;属性)SqlMapConfig.xml引用如下typeAliases&#xff08;类型别名)mybatis支持别名&#xff1a;自定义别名mappers&#xff08;映射器)Mapper引入映射器的几种方法:1.通过resource属性引入classpath路径的…

数据结构实验之数组三:快速转置

题目描述 转置运算是一种最简单的矩阵运算&#xff0c;对于一个m*n的矩阵M( 1 < m < 10000,1 < n < 10000 )&#xff0c;它的转置矩阵T是一个n*m的矩阵&#xff0c;且T( i , j )M( j , i )。显然&#xff0c;一个稀疏矩阵的转置仍然是稀疏矩阵。你的任务是对给…

主流服务器框架总结

libevent 编辑Libevent 是一个用C语言编写的、轻量级的开源高性能网络库&#xff0c;主要有以下几个亮点&#xff1a;事件驱动&#xff08; event-driven&#xff09;&#xff0c;高性能;轻量级&#xff0c;专注于网络&#xff0c;不如 ACE 那么臃肿庞大&#xff1b;源代码相当…

Mybatis输入映射和输出映射

Mapper.xml映射文件中定义了操作数据库的sql&#xff0c;每个sql是一个statement&#xff0c;映射文件是mybatis的核心。输入参数映射parameterType(输入类型)传递简单类型&#xff1a;如&#xff1a;<select id"queryUserById" parameterType"Integer"…

树结构练习——排序二叉树的中序遍历

题目描述 在树结构中&#xff0c;有一种特殊的二叉树叫做排序二叉树&#xff0c;直观的理解就是——(1).每个节点中包含有一个关键值 (2).任意一个节点的左子树&#xff08;如果存在的话&#xff09;的关键值小于该节点的关键值 (3).任意一个节点的右子树&#xff08;如果存在的…

陈硕知乎专栏

https://www.zhihu.com/people/giantchen/answers

Mybatis动态sql的使用

通过mybatis提供的各种标签方法实现动态拼接sql。 为什么用if标签? UserMapper.xml配置sql&#xff0c;如下&#xff1a; <!-- 根据条件查询用户 --> <select id"queryUserByWhere" parameterType"user" resultType"user">SELEC…

面向对象设计之CRC卡片

1.什么是 CRC card&#xff1f; CRC (Class-Responsibility-Collaborator) Card是目前比较流行的面向对象分析建模方法。在CRC建模中&#xff0c;用户、设计者、开发人员都有参与&#xff0c;完成对整个面向对象工程的设计。 CRC卡是一个标准索引卡集合&#xff0c;包括三个部分…

川藏线徒搭

http://www.mafengwo.cn/i/6296156.html

删数问题

Problem Description 键盘输入一个高精度的正整数n&#xff08;≤100位&#xff09;&#xff0c;去掉其中任意s个数字后剩下的数字按照原来的左右次序组成一个新的正整数。编程对给定的n与s&#xff0c;寻找一种方案&#xff0c;使得剩下的数字组成的新数最小。Input 输入有多组…

面试70问 经典回答

http://group.cnblogs.com/topic/37628.html