Mybatis框架搭建

思路:

  1. 搭建环境

  2. 导入Mybatis

  3. 编写代码

  4. 测试

一.搭建环境

  • 创建数据库

    1. /*
      Navicat Premium Data Transfer

      Source Server         : Mybatis
      Source Server Type   : MySQL
      Source Server Version : 50528
      Source Host           : localhost:3306
      Source Schema         : mybatis

      Target Server Type   : MySQL
      Target Server Version : 50528
      File Encoding         : 65001

      Date: 03/03/2022 13:11:06
      */

      SET NAMES utf8mb4;
      SET FOREIGN_KEY_CHECKS = 0;

      -- ----------------------------
      -- Table structure for employee
      -- ----------------------------
      DROP TABLE IF EXISTS `employee`;
      CREATE TABLE `employee`  (
       `id` int(10) NOT NULL AUTO_INCREMENT,
       `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
       `age` int(10) NOT NULL,
       `position` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
       PRIMARY KEY (`id`) USING BTREE
      ) ENGINE = InnoDB AUTO_INCREMENT = 4 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Compact;

      -- ----------------------------
      -- Records of employee
      -- ----------------------------
      INSERT INTO `employee` VALUES (1, '张三', 20, '员工');
      INSERT INTO `employee` VALUES (2, '李四', 18, '员工');
      INSERT INTO `employee` VALUES (3, '王五', 35, '经理');

      SET FOREIGN_KEY_CHECKS = 1;
  • 创建数据库连接信息配置文件db.properties

    1. db.driver = com.mysql.jdbc.Driver
      db.url = jdbc:mysql://localhost:3306/learn-test?useUnicode=true&characterEncoding=utf8
      db.username = root
      db.password = root
  • 新建项目,并且在pom.xml中添加项目依赖

    1. <?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.wfy</groupId>
         <artifactId>Worker</artifactId>
         <packaging>pom</packaging>
         <version>1.0-SNAPSHOT</version>
         <modules>
             <module>worker-01</module>
         </modules>
         <!--导入依赖-->
         <dependencies>
             <!--mybatis-->
             <dependency>
                 <groupId>org.mybatis</groupId>
                 <artifactId>mybatis</artifactId>
                 <version>3.5.2</version>
             </dependency>
             <!--mysql驱动-->
             <dependency>
                 <groupId>mysql</groupId>
                 <artifactId>mysql-connector-java</artifactId>
                 <version>8.0.11</version>
             </dependency>
             <!--junit-->
             <dependency>
                 <groupId>junit</groupId>
                 <artifactId>junit</artifactId>
                 <version>4.12</version>
                 <scope>test</scope>
             </dependency>
         </dependencies>
         <build>
             <resources>
                 <resource>
                     <directory>src/main/java</directory>
                     <includes>
                         <include>**/*.xml</include>
                         <include>**/*.properties</include>
                     </includes>
                 </resource>

                 <resource>
                     <directory>src/main/resources</directory>
                     <includes>
                         <include>**/*.xml</include>
                         <include>**/*.properties</include>
                     </includes>
                 </resource>
             </resources>
         </build>
      </project>

    二、创建模块

    • 创建Mybatis的核心配置文件mybatis-config.xml

      1. <?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>
         <environments default="development">
           <environment id="development">
             <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 resource="mapper/UserMapper"/>
         </mappers>
        </configuration>
  • 编写Mybatis工具类

    1. package utils;

      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 java.io.IOException;
      import java.io.InputStream;

      //SqlSessionFactory --->SqlSession
      public class MybatisUtil {

         private static SqlSessionFactory sqlSessionFactory;

         static {
             try {
                 //使用Mybatis的第一步---->获取SqlSessionFactory对象
                 String resource = "mybatis-config.xml";
                 InputStream inputStream = Resources.getResourceAsStream(resource);
                  sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
            } catch (IOException e) {
                 e.printStackTrace();
            }
        }
         //既然有了 SqlSessionFactory,顾名思义,我们可以从中获得 SqlSession 的实例。
         // SqlSession 提供了在数据库执行 SQL 命令所需的所有方法。你可以通过 SqlSession 实例来直接执行已映射的 SQL 语句
         public static SqlSession getSqlSession()
        {
             return  sqlSessionFactory.openSession();

        }

      }

三.编写代码

  • 实体类User 创建Pojo实体

    1. package pojo;

      //实体类
      public class User {
         private int id ;
         private  String name;
         private  int age;
         private  String position;

         public User() {
        }

         public User(int id, String name, int age, String position) {
             this.id = id;
             this.name = name;
             this.age = age;
             this.position = position;
        }

         public int getId() {
             return id;
        }

         public void setId(int id) {
             this.id = id;
        }

         public String getName() {
             return name;
        }

         public void setName(String name) {
             this.name = name;
        }

         public int getAge() {
             return age;
        }

         public void setAge(int age) {
             this.age = age;
        }

         public String getPosition() {
             return position;
        }

         public void setPosition(String position) {
             this.position = position;
        }

         @Override
         public String toString() {
             return "User{" +
                     "id=" + id +
                     ", name='" + name + '\'' +
                     ", age=" + age +
                     ", position='" + position + '\'' +
                     '}';
        }
      }
  • Dao接口

    1. <?xml version="1.0" encoding="UTF-8" ?>
      <!--namespace=绑定一个Mapper/Dao接口-->
      <!DOCTYPE mapper
             PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
             "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
      <mapper namespace="dao.UserDao">
         <!--执行select查询语句-->
       <select id="getUserList" resultType="pojo.User">
          select * from mybatis.employee;
       </select>
      </mapper>
  • 接口实现类

    1. package dao;

      import pojo.User;

      import java.util.List;

      //Dao接口
      public interface UserDao {

         List<User> getUserList();

      }
  • 编写测试类

    1. package dao;

      import org.apache.ibatis.session.SqlSession;
      import org.junit.Test;
      import pojo.User;
      import utils.MybatisUtil;

      import java.util.List;

      public class UserDaoTest {
         @Test
         public void test ()
        {
             //第一步:获得SqlSession对象
            SqlSession sqlSession= MybatisUtil.getSqlSession();
            //第二步:执行SQL
             UserDao mapper=sqlSession.getMapper(UserDao.class);
            List<User> userList= mapper.getUserList();
             for (User user : userList) {
                 System.out.println(user);
            }

             //关闭sqlSession
             sqlSession.close();
        }
      }

Mybatis框架搭建的更多相关文章

  1. mybatis框架搭建学习初步

    mybatis框架搭建步骤:1. 拷贝jar到lib目录下,而且添加到工程中2. 创建mybatis-config.xml文件,配置数据库连接信息 <environments default=& ...

  2. SpringMVC+Mybatis框架搭建

    一.新建javaweb项目,并建好相应的包结构 二.添加项目jar到lib目录下 三.在config包中新建配置文件 sping-mvc.xml,内容如下: <?xml version=&quo ...

  3. SSM(Spring +SpringMVC + Mybatis)框架搭建

    SSM(Spring +SpringMVC + Mybatis)框架的搭建 最近通过学习别人博客发表的SSM搭建Demo,尝试去搭建一个简单的SSMDemo---实现的功能是对用户增删改查的操作 参考 ...

  4. spring+springmvc+mybatis框架搭建

    一.开发前准备 1)ecplise4.11.0 百度网盘:https://pan.baidu.com/s/1wO9_I52lp0mYNeNTdnj80w 提取码:booa 2)jdk1.6.0_45  ...

  5. Mybatis 框架搭建实例

    前言 MyBatis是一个优秀的持久层框架.原生的jdbc操作存在大量的重复性代码(如注册驱动,创建连接,创建statement,结果集检测等).框架的作用就是把这些繁琐的代码封装. MyBatis通 ...

  6. 【SSM 6】Spring+SpringMVC+Mybatis框架搭建步骤

    一.整体概览 首先看maven工程的创建 二.各层的文件配置 2.1,SSM父工程 <span style="font-family:KaiTi_GB2312;font-size:18 ...

  7. sonne_game网站开发02spring+mybatis框架搭建

    从最开始搭框架谈起,而且,我不仅仅会讲how,还会努力讲why.因为对于web开发,由于有太多好的框架.组件.工具,使得how往往不是那么深刻,背后的why更值得专研.如果有初学者关注我这个系列,也一 ...

  8. Spring+Struts2+Mybatis框架搭建时的常见典型问题

    搭建SSM框架时,总是遇到这样那样的问题,有的一眼就能看出来,有的需要经验的积累.现将自己搭建SSM框架时遇到的典型问题总结如下: 一.Struts2框架下的action中无法使用@Autowired ...

  9. 基于Maven的ssm(spring+springMvc+Mybatis)框架搭建

    前言 本demo是在idea下搭建的maven项目,数据库使用Mysql,jdk版本是1.8.0_171,ideal:2017.3.5 一.新建项目 1.file->new->porjec ...

随机推荐

  1. HTML知识点概括——一篇文章带你完全掌握HTML

    HTML知识点概括 前端三件套分别是HTML3,CSS5,JavaScript 稍微介绍一下W3C标准: 结构化标准语言(HTML) 表现标准语言(CSS) 行为标准(DOM,JavaScript) ...

  2. Tapdata PDK 生态共建计划启动!Doris、OceanBase、PolarDB、SequoiaDB 等十余家厂商首批加入

      2022年4月7日,Tapdata 正式启动 PDK 插件生态共建计划,致力于全面连接数据孤岛,加速构建更加开放的数据生态,以期让各行各业的使用者都能释放数据的价值,随时获取新鲜的数据.截至目前, ...

  3. 记录一下第一次在CodeForces供题的事(未完待续)

    3月11日 因为想出题而开始打比赛上分 (Rating 1727) (期间最低掉到 1669) 6月4日凌晨 上分,有了权限 (Rating 2141) 6月4-6日 出了七道题 6月8-12日 又出 ...

  4. NLM5系列中继采集仪的常见问题

    NLM5系列中继采集采发仪常见问题 1.UART 通讯问题使用 UART 接口时一定要确认收发双方的通讯参数完全一致,包括通讯速率.数据位.校验位.停止位参数.NLM 在上电时会主动输出设备基本信息, ...

  5. python+tkinter 的布局

    from tkinter import * win = Tk() win.title("布局") # #窗口标题 win.geometry("600x500+200+20 ...

  6. 中国顶级程序员,从金山WPS走出来,自研了“表格编程”神器

    程序员的圈子里有很多如明星般闪耀的牛人! 有中国"第一代程序员"--求伯君,有在微信获得巨大成功的张小龙,有图灵奖获得者姚期智,有商业巨子张一鸣,更有开源影响力人物--章亦春. 章 ...

  7. P4289 【一本通提高篇广搜的优化技巧】[HAOI2008]移动玩具

    [HAOI2008]移动玩具 题目描述 在一个 4 × 4 4\times4 4×4 的方框内摆放了若干个相同的玩具,某人想将这些玩具重新摆放成为他心中理想的状态,规定移动时只能将玩具向上下左右四个方 ...

  8. MySQL客户端工具的使用与MySQL SQL语句

    MySQL客户端工具的使用 1.MySQL程序的组成 客户端 mysql:CLI交互式客户端程序 mycli:CLI交互式客户端程序;使用sql语句时会有提示信息 mysql_secure_insta ...

  9. mysql show操作

    SHOW CHARACTER SET 显示所有可用的字符集 SHOW CHARACTER SET; SHOW CHARACTER SET LIKE 'latin%'; SHOW COLLATION 输 ...

  10. 基于ABP和Magicodes实现Excel导出操作

      前端使用的vue-element-admin框架,后端使用ABP框架,Excel导出使用的Magicodes.IE.Excel.Abp库.Excel导入和导出操作几乎一样,不再介绍.文本主要介绍E ...