新建数据库my_db,新建表student_tb

id为主键,不自动递增。

不必插入数据。


下载MyBatis

https://github.com/mybatis/mybatis-3/releases

解压。


新建Java项目,什么都不用勾选(如果要在IDEA中操作数据库,可勾选SQL Support)。

勾选后,IDEA右侧会有一个Database的工具,可在IDEA中直接操作数据库。


导入mybatis所有的jar包、数据库驱动

mybatis.jar是必需的。

lib是mybatis依赖的第三方jar包,根据需要选择,嫌麻烦或者小白,可全部导入lib中的jar。

pdf是mybatis的文档。


设置MyBatis的日志

在src下新建文件 log4j.properties ,内容如下:

  1. # Global logging configuration
  2. log4j.rootLogger=DEBUG, stdout,D
  3.  
  4. # MyBatis logging configuration...
  5. log4j.logger.org.mybatis.example.BlogMapper=TRACE
  6.  
  7. # Console output...
  8. log4j.appender.stdout=org.apache.log4j.ConsoleAppender
  9. log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
  10. # log4j.appender.stdout.Threshold = ERROR
  11. log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n
  12.  
  13. # File output...
  14. log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
  15. log4j.appender.D.File = D:/log.txt
  16. log4j.appender.D.Append = true
  17. log4j.appender.D.Threshold = ERROR
  18. log4j.appender.D.layout = org.apache.log4j.PatternLayout
  19. log4j.appender.D.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
  20. log4j.appender.D.encoding=UTF-8

可到 mybatis.pdf   8.1.1.2小节复制来修改。

这个配置会在控制台输出DEBUG级的日志,我们可以看到程序的执行过程,如果觉得打印的东西太多看着烦,可以把红色部分的#去掉,这样只打印错误信息。

log4j的配置可参考:

https://www.cnblogs.com/chy18883701161/p/12117192.html


src下新建包com.chy.pojo,包下新建POJO类Student:

  1. package com.chy.pojo;
  2.  
  3. public class Student {
  4. private Integer id;
  5. private String name;
  6. private Integer age;
  7. private Integer score;
  8.  
  9. public Integer getId() {
  10. return id;
  11. }
  12.  
  13. public void setId(Integer id) {
  14. this.id = id;
  15. }
  16.  
  17. public String getName() {
  18. return name;
  19. }
  20.  
  21. public void setName(String name) {
  22. this.name = name;
  23. }
  24.  
  25. public Integer getAge() {
  26. return age;
  27. }
  28.  
  29. public void setAge(Integer age) {
  30. this.age = age;
  31. }
  32.  
  33. public Integer getScore() {
  34. return score;
  35. }
  36.  
  37. public void setScore(Integer score) {
  38. this.score = score;
  39. }
  40.  
  41. @Override
  42. public String toString() {
  43. return "Student{" +
  44. "id=" + id +
  45. ", name='" + name + '\'' +
  46. ", age=" + age +
  47. ", score=" + score +
  48. '}';
  49. }
  50. }
 
POJO(Plain Ordinary Java Object)简单的Java对象,属性及其getter、setter方法,开发时t可以加oString()便于调试。
PO,Persistent Object,持久层对象,对应数据表,即数据表的映射,po也算是pojo。
pojo、po的包名也常使用model、domain。
 
VO ,value object,值对象,一般是在po、pojo的基础上进行扩展,封装数据进行传输或者接受前台传递的数据
DTO(Data Transform Object)  数据传输对象,可以把po、pojo、vo作为dto。
 
pojo类的基本类型的成员变量,尽量使用包装类型。

src下新建包com.chy.mapper,mapper下创建实体-数据表的映射文件  StudentMapper.xml:

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper
  3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5.  
  6. <mapper namespace="com.chy.mapper.StudentMapper">
  7. <insert id="insertStudent" parameterType="com.chy.pojo.Student">
  8. INSERT INTO student_tb(id,name,age,score)VALUES (#{id},#{name},#{age},#{score})
  9. </insert>
  10.  
  11. <select id="queryById" parameterType="Integer" resultType="com.chy.pojo.Student">
  12. SELECT * FROM student_tb WHERE id=#{id}
  13. </select>
  14.  
  15. <update id="updateStudent" parameterType="com.chy.pojo.Student">
  16. UPDATE student_tb SET name=#{name},age=#{age},score=#{score} WHERE id=#{id}
  17. </update>
  18.  
  19. <delete id="deleteStudent" parameterType="Integer">
  20. DELETE FROM student_tb WHERE id=#{id}
  21. </delete>
  22. </mapper>

可以到mybatis.pdf  2.1.5小节复制来修改。

我们把映射文件都放在mapper包下,映射文件常以 实体类名+Mapper 命名。

<mapper>的namespace常设置为  包名.映射文件名。

通过namepace和id调用相应的sql语句,这两者组合起来要唯一。

parameterType指定参数类型,resultType指定要把查询结果映射到哪种数据类型。如果数据类型是pojo类,尽量写全限定类名,这样Ctrl+B可以转到定义处。

映射文件的写法可参考:

https://www.cnblogs.com/chy18883701161/p/12122079.html


src下新建数据库配置文件mysql.properties:

  1. driver=com.mysql.cj.jdbc.Driver
  2. url=jdbc:mysql://localhost:3306/my_db?serverTimezone=GMT
  3. username=chy
  4. password=abcd

对应信息要换为自己的。

src下新建mybatis的核心(全局)配置文件mybatis-config.xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE configuration
  3. PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-config.dtd">
  5. <configuration>
  6. <!--指定数据库配置文件的位置-->
  7. <properties resource="mysql.properties"></properties>
  8.  
  9. <!--指定日志实现使用的是log4j-->
  10. <settings>
  11. <setting name="logImpl" value="LOG4J"/>
  12. </settings>
  13.  
  14. <!--指定实体类-->
  15. <typeAliases>
  16. <typeAlias type="com.chy.pojo.Student" alias="Student"/>
  17. </typeAliases>
  18.  
  19. <!--指定数据库配置文件中的变量名-->
  20. <environments default="development">
  21. <environment id="development">
  22. <transactionManager type="JDBC"></transactionManager>
  23. <dataSource type="POOLED">
  24. <property name="driver" value="${driver}"/>
  25. <property name="url" value="${url}"/>
  26. <property name="username" value="${username}"/>
  27. <property name="password" value="${password}"/>
  28. </dataSource>
  29. </environment>
  30. </environments>
  31.  
  32. <!--指定映射文件的位置-->
  33. <mappers>
  34. <mapper resource="com/chy/mapper/StudentMapper.xml"/>
  35. </mappers>
  36. <!-- Continue going here -->
  37.  
  38. </configuration>

可到mybatis.pdf  2.1.2小节复制来改。

<configuration>的子元素是有一定顺序的,顺序不对会报红。

mybatis全局配置文件的写法可参考:

https://www.cnblogs.com/chy18883701161/p/12120023.html


src下新建包com.chy.test,包下新建测试类Test:

  1. package com.chy.test;
  2.  
  3. import com.chy.pojo.Student;
  4. import org.apache.ibatis.io.Resources;
  5. import org.apache.ibatis.session.SqlSession;
  6. import org.apache.ibatis.session.SqlSessionFactory;
  7. import org.apache.ibatis.session.SqlSessionFactoryBuilder;
  8. import java.io.IOException;
  9. import java.io.Reader;
  10.  
  11. public class Test {
  12. public static void main(String[] args) throws IOException {
  13. //加载mybatis的全局配置文件
  14. String resources="mybatis-config.xml";
  15. Reader reader = Resources.getResourceAsReader(resources);
  16.  
  17. //根据配置文件构建SqlSessionFactory
  18. SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
  19. //通过SqlSessionFactory创建SqlSession
  20. SqlSession sqlSession=sqlSessionFactory.openSession();
  21.  
  22. //增
  23. Student student = new Student();
  24. student.setId(1);
  25. student.setName("chy");
  26. //第一个参数对应映射文件中的namespace+id,通过namespace+id调用相应的sql语句,第二个参数是传给sql语句的参数
  27. sqlSession.insert("com.chy.mapper.StudentMapper.insertStudent", student);
  28.  
  29. //修改数据库(增、删、改)后,需要commit()提交给数据库,才会同步本次会话做的修改。只有查询的,可以不commit()。
  30. sqlSession.commit();
  31. //关闭会话
  32. sqlSession.close();
  33. }
  34. }
  1.      //改
  2. Student student = new Student();
  3. student.setId(1);
  4. student.setName("chenghongyong");
  5. sqlSession.update("updateStudent", student);
  1. //查
  2. Student student=sqlSession.selectOne("queryById", 1);
  3. System.out.println(student);

如果本次session期间,只有查询,可以不用commit()。

  1. //删
  2. sqlSession.delete("deleteStudent", 1);

可参考:https://www.cnblogs.com/chy18883701161/p/12150758.html


说明

(1)版本声明部分,最好不要复制其他人的,如果你和ta用的mybatis库版本不同,会出错。最好到mybatis.pdf中去复制。

  1. <!DOCTYPE mapper
  2. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  3. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

(2)配置文件的文件名问题

log4j.properties这个文件名是约定的,不能自己取。

映射文件、数据库配置文件需要在mybatis全局配置文件中指定,它们的文件名可以自己取。

mybatis全局配置文件要在程序中指定,文件名可以自己取。

(3)配置文件的位置问题

配置文件必须放在资源根目录下。常见的做法有2种:

  • 在项目的根目录下新建文件夹resource,右键标识为资源根目录

注意是Resource Root,不是Source Root。

在里面放配置文件:

  • 也可以像demo中一样放置在src下,因为src就是默认的资源根目录。

mapper中的映射文件放哪儿都行,只要路径配置对得上就ok。

log4j.properties必须直接放在资源根目录下(不能放在子文件夹里)。

MyBatis 入门Demo的更多相关文章

  1. Mybatis入门Demo(单表的增删改查)

    1.Mybatis 什么是Mybatis: mybatis是一个持久层框架,用java编写的 它封装了jdbc操作的很多细节,使开发者只需要关注sql语句本身,而无需关注注册驱动.创建连接等繁杂过程 ...

  2. Mybatis入门DEMO

    下面将通过以下步骤说明如何使用MyBatis开发一个简单的DEMO: 步骤一:新建表STUDENTS 字段有: Stu_Id.Stu_Name.Stu_Age.Stu_Birthday CREATE ...

  3. 最基础的mybatis入门demo

    demo结构 数据库情况 (不会转sql语句 骚瑞) 数据库连接信息 jdbc.properties jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:m ...

  4. Mybatis入门和简单Demo

    一.Mybatis的诞生 回顾下传统的数据库开发,JDBC和Hibernate是使用最普遍的技术,但这两种ORM框架都存在一定的局限性: JDBC:最原生的技术,简单易学,执行速度快,效率高,适合大数 ...

  5. 【SSH系列】初识spring+入门demo

    学习过了hibernate,也就是冬天,经过一个冬天的冬眠,当春风吹绿大地,万物复苏,我们迎来了spring,在前面的一系列博文中,小编介绍hibernate的相关知识,接下来的博文中,小编将继续介绍 ...

  6. netty入门demo(一)

    目录 前言 正文 代码部分 服务端 客服端 测试结果一: 解决粘包,拆包的问题 总结 前言 最近做一个项目: 大概需求: 多个温度传感器不断向java服务发送温度数据,该传感器采用socket发送数据 ...

  7. SpringBoot 入门 Demo

    SpringBoot   入门 Demo Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从 ...

  8. 写给新手看的 MyBatis 入门

    目录 MyBatis 使用前的准备 什么是 MyBatis 使用Maven 进行 MyBatis 开发环境搭建 MyBatis 入门 项目整体结构一览 MyBatis 的简单生命周期 1.获取 Sql ...

  9. springboot + mybatisPlus 入门实例 入门demo

    springboot + mybatisPlus 入门实例 入门demo 使用mybatisPlus的优势 集成mybatisplus后,简单的CRUD就不用写了,如果没有特别的sql,就可以不用ma ...

随机推荐

  1. 抽象类和final修饰符

    抽象类和抽象方法的特点: 1.都通过abstract关键字来修饰. 2.抽象类不能实例化. 3.抽象类中可以有 0~多个抽象方法.(可以没有抽象方法) 4.抽象方法只有方法声明,没有方法实现.(没有方 ...

  2. DVWA全级别之Brute Force(暴力破解)

    Brute Force Brute Force,即暴力(破解),是指黑客利用密码字典,使用穷举法猜解出用户口令. 首先我们登录DVWA(admin,password),之后我们看网络是否为无代理,: ...

  3. 吴裕雄 python 机器学习——支持向量机SVM非线性分类SVC模型

    import numpy as np import matplotlib.pyplot as plt from sklearn import datasets, linear_model,svm fr ...

  4. java 实体类 时间格式字段注解

    @DatetimeFormat是将String转换成Date,一般前台给后台传值时用 @JsonFormat(pattern="yyyy-MM-dd") 将Date转换成Strin ...

  5. 多种语言输出helloworld

  6. 流式计算(三)-Flink Stream 篇一

    原创文章,谢绝任何形式转载,否则追究法律责任! ​流的世界,有点乱,群雄逐鹿,流实在太多,看完这个马上又冒出一个,也不知哪个才是真正的牛,据说Flink是位重量级选手,能流计算,还能批处理, 和其他伙 ...

  7. 安装和配置Linux系统虚拟机

    1.打开虚拟机软件 2.点击创建新的虚拟机,选择典型(推荐)类型的配置. 3.点击稍后安装操作系统. 4.客户机操作系统选择Linux,版本选择CentOS 7 64位. 5.虚拟机名称可自行更改,位 ...

  8. celery参考

    1,https://www.wandouip.com/t5i377365/ 2,https://www.cnblogs.com/zhangmingcheng/p/6050270.html (syste ...

  9. jmeter beanshell 使用参数引用

    1.直接使用beanshell 写代码引用: 2. beanshell  引用.java 文件 3.beanshell 引用jar 包

  10. 2.1.FastDFS-单机拆分版-调度器安装配置

    Centos610系列配置 我们在Centos610FastDFS单机模式-FastDFS安装 中已经完成了FastDFS的安装,接下来我们进行FastDFS调度器的安装. 1.找到FastDFS配置 ...