• MyBatis简单使用


    MyBatis


      MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。

    搭建MyBatis


    第一步:先创建一个项目,平常的Java project就行,项目结构先看看

    第二步:导入相关的jar包(可以上官网下,开源的):

    • mybatis-3.4.4.jar  MyBatis的jar包
    • mysql-connector-java-5.1.13-bin.jar  Mysql的jar包

    第三步:编写一个配置文件。是一个XML文件mybatis-config.xml,位置放在src下

    <?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="com.mysql.jdbc.Driver"/>
            <property name="url" value="jdbc:mysql://localhost:3306/mobile"/>
            <property name="username" value="zhou"/>
            <property name="password" value="123456"/>
          </dataSource>
        </environment>
      </environments>
      <mappers>
        <mapper resource="com/entity/UserMapper.xml"/>
      </mappers>
    </configuration>

    有关MyBatis中xml文件的属性说明:

    <!-- 配置文件的根元素 -->  
    <configuration>  
        <!-- 属性:定义配置外在化 -->  
        <properties></properties>  
        <!-- 设置:定义mybatis的一些全局性设置 -->  
        <settings>  
           <!-- 具体的参数名和参数值 -->  
           <setting name="" value=""/>   
        </settings>  
        <!-- 类型名称:为一些类定义别名 -->  
        <typeAliases></typeAliases>  
        <!-- 类型处理器:定义Java类型与数据库中的数据类型之间的转换关系 -->  
        <typeHandlers></typeHandlers>  
        <!-- 对象工厂 -->  
        <objectFactory type=""></objectFactory>  
        <!-- 插件:mybatis的插件,插件可以修改mybatis的内部运行规则 -->  
        <plugins>  
           <plugin interceptor=""></plugin>  
        </plugins>  
        <!-- 环境:配置mybatis的环境 -->  
        <environments default="">  
           <!-- 环境变量:可以配置多个环境变量,比如使用多数据源时,就需要配置多个环境变量 -->  
           <environment id="">  
              <!-- 事务管理器 -->  
              <transactionManager type=""></transactionManager>  
              <!-- 数据源 -->  
              <dataSource type=""></dataSource>  
           </environment>   
        </environments>  
        <!-- 数据库厂商标识 -->  
        <databaseIdProvider type=""></databaseIdProvider>  
        <!-- 映射器:指定映射文件或者映射类 -->  
        <mappers></mappers>  
    </configuration> 

    第四步:创建实体类,这个不用多说了,正常创建就ok

    第五步:创建实体类的mapper映射xml文件,位置跟实体类同级,是对实体类的一些操作,在我认为就是配置了sql语句的赶脚,再去方法里调一下

    <?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可以不加xml后缀 -->
    <mapper namespace="com.entity.UserMapper">
    <!-- 单个对象查询 -->
      <select id="selectUser" parameterType="int"  resultType="com.entity.User">
        select * from user where id = #{id}
      </select>
      <!--查询列表  -->
      <resultMap id="userList" type="com.entity.User">
      <result property="id" column="id" />
      <result property="username" column="username"/>
      <result property="password" column="password"/>
    </resultMap>
      <select id="selectAll"  resultMap="userList">
        select * from user
      </select>
      <!--插入数据  -->
       <insert id="insert"  >
        insert into User (username,password) values(#{username},#{password})
      </insert>
      <!--更新数据  -->
    <update id="update">
      update User set username = #{username},password = #{password} where id = #{id}
    </update>
    <!--删除数据  -->
    <delete id="delete">
      delete from User where id = #{id}
    </delete>
    </mapper>

    实体类映射的属性说明:先看前几个后面的遇到再说,百度就可以

    第六步:编写一下测试类,测试一下你搭建的是否有用

    package com.test;
    
    import java.io.IOException;
    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 com.entity.User;
    /**
     * 
     * @author 坚持到你GL
     *
     */
    public class Test {
        private static SqlSession session=null;
        public static SqlSession mySession() {
            //你的MyBatis的配置文件地址
            String resource = "mybatis-config.xml";
            InputStream inputStream=null;
            try {
                //IO解析xml文件
                inputStream = Resources.getResourceAsStream(resource);
            } catch (IOException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            //创建一个SqlSessionFactoryBuilder对象,获得SqlSessionFactory 的实例
            SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
            //开启SqlSession
             session=sqlSessionFactory.openSession();
            return session;
        }
        private static void select(){
            //selectUser是实体类映射文件的中设置的id
            User user=mySession().selectOne("selectUser",2);
            System.out.println(user);
        }
        private static void selectAll() {
            List<User> list=mySession().selectList("selectAll");
            for (User user : list) {
                System.out.println(user);
            }
        }
        private static void insert() {
            User insertuser=new User("zhou","123456");
            mySession().insert("insert",insertuser);
            session.commit();
        }
        private static void update() {
            User updateuser =new User(9,"admin","admin");
            mySession().update("update", updateuser);
            session.commit();
        }
        private static void delect() {
            mySession().delete("delete", 10);
            session.commit();
        }
        public static void main(String[] args) {
        
        selectAll();
        }
    }

    小项目微服务简单的开发,运用MyBatis是非常不错的选择

         【版本声明】本文为博主原创文章,转载请注明出处

  • 相关阅读:
    centos 更改root密码
    朋友新站http://www.1010yhq.com(1010优惠券网)
    NHibernate从入门到精通系列(3)——第一个NHibernate应用程序
    Windows 进化图
    NHibernate从入门到精通系列(1)——NHibernate概括
    Windows 7最全的硬盘安装方法
    C#面向对象设计模式纵横谈(4):Builder 生成器模式(创建型模式)
    NHibernate从入门到精通系列(2)——NHibernate环境与结构体系
    C#面向对象设计模式纵横谈(5):Factory Method 工厂方法模式(创建型模式)
    C#面向对象设计模式纵横谈(6):Prototype 原型模式(创建型模式)
  • 原文地址:https://www.cnblogs.com/zhouguanglin/p/7643603.html
Copyright © 2020-2023  润新知