关键词:
注意,这篇文章只介绍mybatis单独使用时如何操作,是没有用到spring的,如果需要了解mybatis和spring如何搭建,请移步这里Mybatis(六):spring与mybatis三种整合方法。
方式一:不使用mapper接口
步骤
1.pom文件里添加jar包
<dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.3.0</version> </dependency>
2.准备Mybatis的配置文件
<?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> <settings> <!-- 打印查询语句 --> <setting name="logImpl" value="STDOUT_LOGGING" /> </settings> <!-- 和Spring整合后environment配置都会被干掉 --> <environments default="development"> <environment id="development"> <!-- 使用jdbc事务管理,目前由mybatis来管理 --> <transactionManager type="JDBC" /> <!-- 数据库连接池,目前由mybatis来管理 --> <dataSource type="POOLED"><!--有关于mysql数据库的各种信息--> <property name="driver" value="com.mysql.jdbc.Driver" /> <property name="url" value="jdbc:mysql://localhost:3306/mybatis" /> <property name="username" value="root" /> <property name="password" value="123456" /> </dataSource> </environment> </environments> <mappers> <!--将操作配置文件User.xml系添加进mapper--> <mapper resource="mybatis/user.xml" /> </mappers> </configuration>
更多的参数配置,参阅:Mybatis(一):MyBatis配置文件config.xml详解
3.准备实体类
public class User { private String id; private String password; private String username; public String getId() { return id; } public void setId(String id) { this.id = id; } public String getPassword(){ return password; } public void setPassword(String password){ this.password=password; } public String getUsername(){ return username; } public void setUsername(String username){ this.username=username; } }
4.准备实体对应的mapper映射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="user"> <!-- 注意,因为这边没有用到mapper接口,所以这里的namespace不需要是完全的类名 --> <!-- 通过id查询用户 --> <select id="findUserById" parameterType="int" resultType="com.mvc.User"> <include refid="selectStr"/> id = #{id} </select> <!--通过name查找一个list的用户,模糊匹配--> <select id="findUserByName" parameterType="java.lang.String" resultType="com.mvc.User"> select * from user where name like '%${value}%' </select> <!--插入用户信息--> <insert id="insertUser" parameterType="com.mvc.User"> <selectKey keyProperty="id" order="BEFORE" resultType="java.lang.String"> select uuid() <!-- 这里是对于主键属性的id进行赋值 --> </selectKey> insert into user(id,username,password) values(#{id},#{username},#{password}) </insert> <!--删除用户信息--> <delete id="deleteUser" parameterType="java.lang.Integer"> delete from user where id=#{id} </delete> <!--更新用户信息--> <update id="updateUser" parameterType="com.mvc.User"> <!-- update user set name=#{name},password=#{password} where id=#{id} --> update user <set> <if test="username != null && username != ''">username=#{username},</if> <if test="password != null && password != ''">password=#{password},</if> </set> where id= #{id} </update> </mapper>
5.准备一个获取sqlsession的工具类
import java.io.IOException; import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class MybatisSessionUtil { static SqlSessionFactory sqlSessionFactory = null; static{ SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder(); try { sqlSessionFactory = sqlSessionFactoryBuilder.build(Resources.getResourceAsStream("mybatis-config.xml")); } catch (IOException e) { e.printStackTrace(); } } public static SqlSession getSession(){ return sqlSessionFactory.openSession(); } }
6.准备dao
import org.apache.ibatis.session.SqlSession; import com.mvc.User; import com.mybatis.mapper.User2Mapper; public class UserDao { SqlSession session = MybatisSessionUtil.getSession(); public int insert(User user){ int rint = session.insert("user.insertUser",user); // 第一个参数是mapper xml里的namespace+MappedStatement对应的id session.commit();// 不要忘记提交 return rint; } }
7.看下数据里user表
8.测试类
import com.mvc.User; import com.mybatis.util.UserDao; public class MybatisNoSpringTest { public static void main(String[] args) { UserDao userDao = new UserDao(); User user = new User(); user.setUsername("wwwttt"); user.setPassword("33333"); if (userDao.insert(user) == 1) { System.out.println("insert success..."); }else{ System.out.println("insert fail..."); } } }
方式二:使用mapper接口
步骤
1.pom文件里添加jar包
同方式一
2.准备Mybatis的配置文件
同方式一,就是换成新的user mapper xml
<mappers> <!--将操作配置文件系添加进mapper--> <mapper resource="mybatis/User2Mapper.xml" /> </mappers>
3.准备实体类
同方式一
4.准备mapper接口(这个是比方式一多出来的)
import com.mvc.User; // 这边接口名要和xml映射的文件名一致 public interface User2Mapper { int insertUser(User user); // 其它方法略。。。 }
5.准备实体对应的mapper映射xml文件
同方式一,只是namespace需要注意
<?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一定要写完整正确 --> <mapper namespace="com.mybatis.mapper.User2Mapper"> <!-- 通过id查询用户 --> <select id="findUserById" parameterType="int" resultType="com.mvc.User"> select * from user where id = #{id} </select> <!--通过name查找一个list的用户,模糊匹配--> <select id="findUserByName" parameterType="java.lang.String" resultType="com.mvc.User"> select * from user where name like '%${value}%' </select> <!--插入用户信息--> <insert id="insertUser" parameterType="com.mvc.User"> <selectKey keyProperty="id" order="BEFORE" resultType="java.lang.String"> select uuid() <!-- 这里是对于主键属性的id进行赋值 --> </selectKey> insert into user(id,username,password) values(#{id},#{username},#{password}) </insert> <!--删除用户信息--> <delete id="deleteUser" parameterType="java.lang.Integer"> delete from user where id=#{id} </delete> <!--更新用户信息--> <update id="updateUser" parameterType="com.mvc.User"> update user set name=#{name},password=#{password} where id=#{id} </update> </mapper>
6.准备一个获取sqlsession的工具类
同方式一
7.准备dao
import org.apache.ibatis.session.SqlSession; import com.mvc.User; import com.mybatis.mapper.User2Mapper; public class UserDao { SqlSession session = MybatisSessionUtil.getSession(); // 使用接口方式 public int insert2(User user){ User2Mapper user2Mapper = session.getMapper(User2Mapper.class); int rint = user2Mapper.insertUser(user); session.commit(); return rint; } }
8.测试类
import com.mvc.User; import com.mybatis.util.UserDao; public class MybatisNoSpringTest { public static void main(String[] args) { UserDao userDao = new UserDao(); User user = new User(); user.setUsername("wwwttt"); user.setPassword("33333"); // 使用mapper接口方式 if (userDao.insert2(user) == 1) { System.out.println("insert success..."); }else{ System.out.println("insert fail..."); } } }
方式三:使用mybatis框架的注解编写sql
这种方式,我不推荐使用,本来我们使用mybatis就是为了sql编写和java代码能分开解耦,有更大的灵活性,使用这种方式反而不好。
另外,myatis官方也不推荐这种方式,官方说了,要想使用mybatis强大的sql编写功能,写在注解里是受到限制的,只有写在mapper xml里才能发挥的玲离尽致。
所以,这种方法我就不记录了,有需要的同学自行百度。
mybatis查询的三种方式
查询最需要关注的问题:①resultType自动映射,②方法返回值; interfaceEmpSelectMapper:packagecom.atguigu.mapper;importjava.util.List;importjava.util.Map;importorg.apache.ibatis.annotations.MapKey;importcom.atguigu.bean.Em 查看详情
mybatis查询的三种方式
查询最需要关注的问题:①resultType自动映射,②方法返回值; interfaceEmpSelectMapper:packagecom.atguigu.mapper;importjava.util.List;importjava.util.Map;importorg.apache.ibatis.annotations.MapKey;importcom.atguigu.bean.Em 查看详情
mybatis模糊查询like的三种方式
第一种publicvoidselectBykeyWord(Stringkeyword){ Stringid="%"+keyword+"%"; StringroleType="%"+keyword+"%"; StringroleName="%"+keyword+"%"; userDao.selectBykeyWord(id,roleName,roleType);}在Dao层指定各个参数的别名 查看详情
springboot整合mybatis实现数据库操作的三种方式
前提:使用MySql数据库一、引进依赖方式一:在构建项目时,通过选择方式引入方式二:配置pom.xml方式<dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter&l 查看详情
springboot整合mybatis实现数据库操作的三种方式(代码片段)
前提:使用MySql数据库一、引进依赖方式一:在构建项目时,通过选择方式引入方式二:配置pom.xml方式<dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter&l 查看详情
mybatis的三种分页方式,你用过几种?
前言分页是我们在开发中绕不过去的一个坎!当你的数据量大了的时候,一次性将所有数据查出来不现实,所以我们一般都是分页查询的,减轻服务端的压力,提升了速度和效率!也减轻了前端渲染的压力... 查看详情
mybatis的三种分页方式,你用过几种?
前言分页是我们在开发中绕不过去的一个坎!当你的数据量大了的时候,一次性将所有数据查出来不现实,所以我们一般都是分页查询的,减轻服务端的压力,提升了速度和效率!也减轻了前端渲染的压力... 查看详情
mybatis延迟加载的三种加载方式深入,你get了吗?
延迟加载 延迟加载对主对象都是直接加载,只有对关联对象是延迟加载。 延迟加载可以减轻数据库的压力, 延迟加载不可是一条SQL查询多表信息,这样构不成延迟加载,会形成直接加载。 延迟加载分为三种类型... 查看详情
上手springboot项目之springboot整合mybatis进行增删改查的三种方式。
1.引入依赖<!--springboot的web起步依赖--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--Myba 查看详情
什么?mybatis-plus的多表查询,你还在写sql语句?!crud2多表联查的三种方式(代码片段)
⚠⚠⚠自信攻城狮小名又来攻城啦⚠⚠⚠文章目录公用部分:1.VO2.PracticeTeacherService一、SQL1.PracticeTeacherMapper.xml2.PracticeTeacherMapper.java3.PracticeTeacherServiceImpl.java4.结果:二、链式调用lambda式,lambdaQuery( 查看详情
mybatis中foreachcollection的三种用法
foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合。foreach元素的属性主要有item,index,collection,open,separator,close。item表示集合中每一个元素进行迭代时的别名,index指定一个名字,用于表示在迭代过程中,... 查看详情
mybatis-spring框架整合
目的:使用Spring容器用单例模式管理MyBatis的sqlSessionFactory;使用Spring管理连接池、数据源等;将Dao/Mapper动态代理对象注入到Spring容器中,使用时直接获取;整合的三种方式:链接??https://www.jianshu.com/p/412051d41d73实例● 导入所... 查看详情
mybatis+oracle--批量插入
...增长ID:参考博客:Oracle数据库创建表ID字段的自动递增mybatis语句参考博客:点评ibatis+oracle批量插入的三种方法. 参考第三种参考博客:mybatis中批量插入的两种方式(高效插入) Oracle自增长ID,如下:序列:CREATESEQUENCE"ENERGY... 查看详情
mybatis多参数处理问题
这里总结了关于多参数传递时,MyBatis接收的三种方式。(1)接口中编写方法1 publicEmpgetEmpByParams(Integerid,StringlastNmae);23publicEmpgetEmpByParam(@Param("id")Integerid,@Param("lastName")StringlastNmae);45publicEmpgetEmpByParam(Ma 查看详情
mybatis个人笔记(1.2版本)(代码片段)
MyBatis个人笔记MyBatis一、Mybatis介绍二、mybatis快速入门1.1准备开发环境Mybatis核心配置文件解析根节点内的子节点的顺序是固定的:2.2用mybatis去访问数据库的三种编码方式(一)xml映射文件+sqlSession调用相应的方法(... 查看详情
转:spring与mybatis三种整合方法
...,csdn没转载功能,只能复制了。。本文主要介绍Spring与Mybatis三种常用整合方法,需要的整合架包是mybatis-spring.jar,可通过链接http://code.google.com/p/mybatis/下载到。 1、采用数据映射器(MapperFactoryBean)的方式,不用写mybatis... 查看详情
mybatis应用开发应用之开发方式xml文件篇
1.1. 开发方法有三种使用MyBatis的方法:(1)使用XML配置文件的方式。(2)使用注解方式。(3)使用API方式。 1.2. XML方式1.2.1. 开发步骤目标:使用MyBatis从数据库中查询t_person表的全部记录。 MyBatis使用XML文件来配置... 查看详情
初始mybatis
1.session.commit()能够提交事务2.session.close()回滚事务二.模糊查询的三种方法1.select*fromstudentInfowherestunamelike‘%‘#{stuname}‘%‘2.select*fromstudentInfowherestunamelikeconcat{‘%‘,#{stuname},‘%‘}3.select*fromstudentIn 查看详情