项目实现的功能

查询所有用户信息
通过Id查询用户信息
添加用户(回显主键)
修改用户信息
删除用户信息
通过用户名字模糊查询

一、引入依赖和工程结构

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.william</groupId><artifactId>MybatisCRUD</artifactId><version>1.0-SNAPSHOT</version><properties><maven.compiler.source>1.8</maven.compiler.source><maven.compiler.target>1.8</maven.compiler.target></properties><dependencies><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.47</version></dependency><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.4.5</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency></dependencies></project>

二、创建实体类

User

package com.william.domain;import java.util.Date;/*** @author :lijunxuan* @date :Created in 2019/7/9  19:28* @description :* @version: 1.0*/
public class User {private  Integer id;private String username;private String password;private String  sex;private Date birthday;@Overridepublic String toString() {return "User{" +"id=" + id +", username='" + username + '\'' +", password='" + password + '\'' +", sex='" + sex + '\'' +", birthday=" + birthday +'}';}public Date getBirthday() {return birthday;}public void setBirthday(Date birthday) {this.birthday = birthday;}public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getUsername() {return username;}public void setUsername(String username) {this.username = username;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}public String getSex() {return sex;}public void setSex(String sex) {this.sex = sex;}}

三、映射文件

1.UserMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.william.mapper.UserMapper"><!--查询所有用户信息--><select id="findAll" resultType="com.william.domain.User">select * from user</select><!--通过ID查询用户信息--><select id="findById" parameterType="java.lang.Integer" resultType="com.william.domain.User">select * from user where id=#{id}</select><!--模糊查询--><select id="findByUsername" parameterType="java.lang.String" resultType="com.william.domain.User">select * from user where username like "%"#{value}"%"</select><!--增加用户信息--><insert id="insert" parameterType="com.william.domain.User">-- 主键回显<selectKey resultType="java.lang.Integer" keyColumn="id" keyProperty="id" order="AFTER" >select last_insert_id()</selectKey>insert into user values (null ,#{username},#{password},#{sex},#{birthday})</insert><!--更新用户信息--><update id="update" parameterType="com.william.domain.User">update  user set username=#{username},password=#{password},sex=#{sex},birthday=#{birthday} where id=#{id}</update><!--删除用户信息--><delete id="delete" parameterType="java.lang.Integer">delete  from user where id =#{id}</delete>
</mapper>

2.Mybatis-configuration.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><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/web02"/><property name="username" value="root"/><property name="password" value="root"/></dataSource></environment></environments><mappers><mapper resource="com/william/mapper/UserMapper.xml"/></mappers>
</configuration>

四、引入log4j

log4j.properties

# Set root category priority to INFO and its only appender to CONSOLE.
#log4j.rootCategory=INFO, CONSOLE            debug   info   warn error fatal
log4j.rootCategory=debug, CONSOLE, LOGFILE, info# Set the enterprise logger category to FATAL and its only appender to CONSOLE.
log4j.logger.org.apache.axis.enterprise=FATAL, CONSOLE# CONSOLE is set to be a ConsoleAppender using a PatternLayout.
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=%d{ISO8601} %-6r [%15.15t] %-5p %30.30c %x - %m\n# LOGFILE is set to be a File appender using a PatternLayout.
log4j.appender.LOGFILE=org.apache.log4j.FileAppender
log4j.appender.LOGFILE.File=d:\axis.log
log4j.appender.LOGFILE.Append=true
log4j.appender.LOGFILE.layout=org.apache.log4j.PatternLayout
log4j.appender.LOGFILE.layout.ConversionPattern=%d{ISO8601} %-6r [%15.15t] %-5p %30.30c %x - %m\n

五、测试类

TestMybatis

package com.william;
import com.william.domain.User;
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.Test;
import java.io.InputStream;
import java.util.Date;
import java.util.List;
/*** @author :lijunxuan* @date :Created in 2019/7/9  19:45* @description :* @version: 1.0*/
public class TestMybatis {/*** 查询所有用户信息*/@Testpublic void selectList(){InputStream inputStream = Resources.class.getClassLoader().getResourceAsStream("Mybatis-configuration.xml");SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);SqlSession sqlSession = sqlSessionFactory.openSession();List<User> selectList = sqlSession.selectList("com.william.mapper.UserMapper.findAll");for (Object o : selectList) {System.out.println(o);}sqlSession.close();}/***通过Id查询用户信息**/@Testpublic void findById(){InputStream inputStream = Resources.class.getClassLoader().getResourceAsStream("Mybatis-configuration.xml");SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);SqlSession sqlSession = sqlSessionFactory.openSession();User selectOne = sqlSession.selectOne("com.william.mapper.UserMapper.findById", 43);System.out.println(selectOne.getUsername());sqlSession.close();}/*** 添加用户*/@Testpublic void InsertUser(){InputStream inputStream = Resources.class.getClassLoader().getResourceAsStream("Mybatis-configuration.xml");SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);SqlSession sqlSession = sqlSessionFactory.openSession();User user = new User();user.setUsername("黑衣人");user.setPassword("123456");user.setSex("男");user.setBirthday(new Date());sqlSession.insert("com.william.mapper.UserMapper.insert",user);//回显刚刚添加用户的IDSystem.out.println("添加之后的主键id为:"+user.getId());sqlSession.commit();sqlSession.close();}/*** 修改用户信息*/@Testpublic void UpdateUser(){InputStream inputStream = Resources.class.getClassLoader().getResourceAsStream("Mybatis-configuration.xml");SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);SqlSession sqlSession = sqlSessionFactory.openSession();User user = new User();user.setId(43);user.setUsername("黑衣人");user.setPassword("123456");user.setSex("男");user.setBirthday(new Date());sqlSession.update("com.william.mapper.UserMapper.update",user);sqlSession.commit();sqlSession.close();}/*** 删除用户信息*/@Testpublic void deleteUser(){InputStream inputStream = Resources.class.getClassLoader().getResourceAsStream("Mybatis-configuration.xml");SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);SqlSession sqlSession = sqlSessionFactory.openSession();sqlSession.delete("com.william.mapper.UserMapper.delete",42);sqlSession.commit();sqlSession.close();}/*** 模糊查询* 通过用户名字模糊查询*/@Testpublic void findByUsername(){InputStream inputStream = Resources.class.getClassLoader().getResourceAsStream("Mybatis-configuration.xml");SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);SqlSession sqlSession = sqlSessionFactory.openSession();List<User> selectList = sqlSession.selectList("com.william.mapper.UserMapper.findByUsername","a");for (Object o : selectList) {System.out.println(o);}sqlSession.close();}
}

Mybatis实现CRUD操作相关推荐

  1. 2021年3月8日:MyBatis框架学习笔记02:利用MyBatis实现CRUD操作

    MyBatis框架学习笔记02:利用MyBatis实现CRUD操作 在第一节课中我们在UserMapper.xml里定义了两个查询语句:findById和findAll,对应的在UserMapper接 ...

  2. 使用MyBatis实现CRUD操作

    MyBatis 1.使用MyBatis实现CRUD操作 1.1 根据id查询信息 1.2 实现存入用户信息 1.3 更新用户信息 1.4 删除用户信息 1.5 模糊查询 1.6 #{}和${}的区别 ...

  3. MyBatis教程– CRUD操作和映射关系–第1部分

    CRUD操作 MyBatis是一个SQL Mapper工具,与直接使用JDBC相比,它极大地简化了数据库编程. 步骤1:创建一个Maven项目并配置MyBatis依赖项. <project xm ...

  4. mybatis进行CRUD操作时返回值不为影响的条数,为null

    对应自己的情况多试试看,总有一种方法可以解决吧! 1.如果报期望的返回值为null而原始返回值类型为int的错误 则将Dao/mapper接口中的函数的返回值类型改为Integer,在方法调用时使用. ...

  5. 利用MyBatis实现CRUD操作

    文章目录 一.打开MyBatisDemo项目 二.查询表记录 (一)在映射器配置文件里引入结果映射元素 (二)添加按姓名查询用户记录功能 1.在UserMapper.xml里添加映射语句 - find ...

  6. MyBatis框架学习笔记02:使用MyBatis实现CRUD操作

    文章目录 Ⅰ.查询表记录 (Ⅰ).在映射器配置文件里引入结果映射元素 (Ⅱ).添加按姓名查询用户记录功能 1).在UserMapper.xml里添加映射语句 - findByName 2).在User ...

  7. MyBatis教程– CRUD操作和映射关系–第2部分

    为了说明这一点,我们正在考虑以下示例域模型: 会有用户,每个用户可能都有一个博客,每个博客可以包含零个或多个帖子. 这三个表的数据库结构如下: CREATE TABLE user (user_id i ...

  8. MyBatis的CRUD操作

    MyBatis的两个主要配置文件 mytatis.xml:放在src目录下,常见的配置如下 <?xml version="1.0" encoding="UTF-8& ...

  9. 封装mybatis简化CRUD操作增强包mybatis-plugs

    mybatis非常方便我们进行数据库的增删改查,sql语句可以方便的写在xml文件里面,减少代码的耦合性,方便解耦,但是简单的增删改查都要写,当我们的业务量比较大,表字段比较多的时候写起来比较费劲,这 ...

最新文章

  1. 一步步实现 Redis 搜索引擎
  2. mysql php 封装类_市面上几款常见的微信开发框架对比(PHP和JAVA)
  3. 57javabean简介
  4. DBShop电子商务系统
  5. 程序员输入法_解决Pycharm输入法不跟随光标
  6. golang语言os.Stat()用法及功能
  7. 训练集,验证集,测试集分别是什么
  8. 龙果学院Java并发编程原理与实战
  9. Java 10 大装 B 写法,装逼常用代码
  10. miniUI ExcelExport导出JAVA实现
  11. python是低级语言吗_低级语言和高级语言的区别
  12. java表示自然数,将一个正整数表示为连续自然数的和
  13. 电子设计教程30:温度滞回控制系统
  14. 二 名词性从句(2021-11-01)
  15. latex大括号 多行公式_问题百出的MathType公式编辑器,会有替代品吗?
  16. 专升本知识库系统思维导图
  17. 继承(下)----虚继承
  18. 极客大挑战2019php,[极客大挑战 2019]PHP
  19. 不同进程间的HOOK,用到共享数据段
  20. activiti5.22代理人、候选人改造--前端

热门文章

  1. cloudfoundry_在Cloudfoundry上部署RESTful服务
  2. web编程 端口分配_以编程方式衡量分配
  3. 为什么awt_为AWT的机器人创建DSL
  4. java处理注释_如何处理Java注释
  5. 纪事本 乱码_纪事地图和Yahoo Cloud服务基准
  6. 告诉我们您想要什么,我们将做到:消费者驱动的合同测试消息传递
  7. 使用Spring Boot 2使用OAuth2和不透明令牌进行集中授权
  8. JDK Bug系统浪费时间
  9. 与Spring的计划任务一起按时运行
  10. Packt和Java Code Geeks提供的$ 5 Java编程书籍!