myBatis也是一个持久型框架,相较于hibernate来说,算是轻量级的。

1.配置mybatis环境

  相关jar下载地址:mybatis+mysalJAR包

2.新建一个java project工程

2.1配置log4j.properties文件,用于日志输出

 log4j.rootCategory=DEBUG, Console

 log4j.appender.Console=org.apache.log4j.ConsoleAppender
 log4j.appender.Console.layout = org.apache.log4j.PatternLayout
 log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] -%m%n

 log4j.logger.java.sql.ResultSet = INFO
 log4j.logger.org.apache = INFO
 log4j.logger.java.sql.Connection = DEBUG
 log4j.logger.java.sql.Statement = DEBUG
 log4j.logger.java.sql.PreparedStatement = DEBUG

log4j

2.2配置MybatisConfig.xml,用于配置数据库连接

 <?xml version="1.0" encoding="UTF-8"?>

 <!DOCTYPE configuration
  PUBLIC "-//mynatis.org//DTD Config 3.0 EN"
  "http://mybatis.org/dtd/mybatis-3-config.dtd">

 <configuration>
     <!-- 别名 -->
     <typeAliases>
         <typeAlias alias="User" type="com.juin.entity.User" />
         <typeAlias alias="Person" type="com.juin.entity.Person" />
     </typeAliases>

     <environments default="development">
     <environment id="development">
     <transactionManager type="JDBC">

     </transactionManager>
     <dataSource type="POOLED">
     <property name="driver" value="com.mysql.jdbc.Driver"/>
     <property name="url" value="jdbc:mysql://localhost:3306/mybatis_test"/>
     <property name="username" value="juin"/>
     <property name="password" value="123654"/>
     </dataSource>
     </environment>
     </environments>

     <mappers>
         <mapper resource="com/juin/map/juinUser.xml"/>
         <mapper resource="com/juin/map/person.xml"/>
         <mapper class="com.juin.map.IUser"/>
     </mappers>
 </configuration>

MyBatisConfig.xml

2.3配置juinUser.xml,前面忘记说了,mybatis实现了代码与数据库连接语句的分离。

 <?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="domain.blog.mappers.AuthorMapper">
     <select id="findById" parameterType="int" resultType="com.juin.entity.User">
         select * from user where id=#{id}
     </select>

     <insert id="insertUser" parameterType="User" statementType="PREPARED"
         keyProperty = "id" useGeneratedKeys = "true">
         insert into user (username,psw) values
         (#{username},#{psw})
     </insert>

     <update id="updateUser" parameterType="User">
         UPDATE User SET
         username=#{username},
         psw=#{psw}
         where id = #{id}
     </update>

     <select id="loginSelect" parameterType="hashmap" resultType="User">
         select * from user where username = #{username} and psw = #{psw}
     </select>

     <select id="loginSelect2" parameterType="User" resultType="User">
         select * from user where username = #{username} and psw = #{psw}
     </select>

     <select id="selectList" resultType="User">
         select * from user
     </select>

     <resultMap id="UserMap" type="User">
         <id property="id" column="id"/>
         <result property="username" column="username"/>
         <result property="psw" column="psw"/>
     </resultMap>
     <select id="selectUsers" resultMap="UserMap">
         select * from user
     </select>
 </mapper>

juinUser.xml

2.4创建User实体类

 package com.juin.entity;

 public class User {
     private int id;
     private String username;
     private String psw;

     public int getId() {
         return id;
     }

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

     public String getUsername() {
         return username;
     }

     public void setUsername(String username) {
         this.username = username;
     }

     public String getPsw() {
         return psw;
     }

     public void setPsw(String psw) {
         this.psw = psw;
     }
 }

User.java

2.5创建测试类

 package com.juin.test;

 import java.io.IOException;
 import java.io.Reader;
 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.juin.entity.User;

 public class test1 {

     public static void main(String[] args) {

         String resource = "com/juin/map/MybatisConfig.xml";
         Reader reader = null;
         SqlSession session = null;

         try {
             reader = Resources.getResourceAsReader(resource);
         } catch (IOException e) {
             // TODO Auto-generated catch block
             e.printStackTrace();
         }
         SqlSessionFactory sqlMapper = new SqlSessionFactoryBuilder().build(reader);
         session = sqlMapper.openSession();
         User temp = session.selectOne("findById", 2);
         System.out.println(temp.getUsername());
         session.close();
     }

 }

test

myBatis学习之路1-基本功能实现的更多相关文章

  1. mybatis学习之路----批量更新数据两种方法效率对比

    原文:https://blog.csdn.net/xu1916659422/article/details/77971696/ 上节探讨了批量新增数据,这节探讨批量更新数据两种写法的效率问题. 实现方 ...

  2. mybatis学习之路

    MyBatis 是支持普通SQL查询.存储过程和高级映射的优秀持久层框架. MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装. MyBatis可以使用简单的XML或注解 ...

  3. MyBatis学习之路之configuration配置

    1.首先讲解的是MyBatis核心配置文件configuration.xml的配置 一个完整的configuration.xml配置顺序如下: properties,settings,typeAlia ...

  4. mybatis学习之路----mysql批量新增数据

    原文:https://blog.csdn.net/xu1916659422/article/details/77971867 接下来两节要探讨的是批量插入和批量更新,因为这两种操作在企业中也经常用到. ...

  5. springboot 学习之路 3( 集成mybatis )

    目录:[持续更新.....] spring 部分常用注解 spring boot 学习之路1(简单入门) spring boot 学习之路2(注解介绍) spring boot 学习之路3( 集成my ...

  6. 中小研发团队架构实践之生产环境诊断工具WinDbg 三分钟学会.NET微服务之Polly 使用.Net Core+IView+Vue集成上传图片功能 Fiddler原理~知多少? ABP框架(asp.net core 2.X+Vue)模板项目学习之路(一) C#程序中设置全局代理(Global Proxy) WCF 4.0 使用说明 如何在IIS上发布,并能正常访问

    中小研发团队架构实践之生产环境诊断工具WinDbg 生产环境偶尔会出现一些异常问题,WinDbg或GDB是解决此类问题的利器.调试工具WinDbg如同医生的听诊器,是系统生病时做问题诊断的逆向分析工具 ...

  7. 新篇章之我的java学习之路下

    昨天写下了人生的第一篇博客,今天接着写我的java学习之路有关开发及框架的学习过程. 想要学好java语言,只学习一些java的基本语法对实际开发中的用处还是不大的,所以我们还要掌握一些有关javaW ...

  8. springboot 学习之路 1(简单入门)

    目录:[持续更新.....] spring 部分常用注解 spring boot 学习之路1(简单入门) spring boot 学习之路2(注解介绍) spring boot 学习之路3( 集成my ...

  9. springboot 学习之路 4(日志输出)

    目录:[持续更新.....] spring 部分常用注解 spring boot 学习之路1(简单入门) spring boot 学习之路2(注解介绍) spring boot 学习之路3( 集成my ...

随机推荐

  1. java的ThreadLocal类的使用方法

    java的ThreadLocal类的使用方法,ThreadLocal是一个支持泛型的类,用在多线程中用于防止并发冲突问题. 比如以下的一个样例,就是用于线程添加1,可是相互不冲突 package co ...

  2. UIWebView使用app内自定义字体

    最近,做了个小需求.因为app是使用的自定义字体,所以产品想让h5的字体跟app的字体一致,减少脱离感.而一般来说,app内的h5页面,都是显示系统的默认字体.要想使用自定义字体,一般的做法是在h5里 ...

  3. javascript数组的内置对象Array

    javascript的内置对象Array是用于构造数组的全局对象,数组是类似于列表的高阶对象. 创建数组的方法: 1通过字面量:var arr = [1,2,3]; 里面的参数直接作为数组里的值 2通 ...

  4. Caused by: java.lang.ClassNotFoundException: Could not load requested class :XXX.XXX.XXX 异常处理

    在ssh整合中:出现的异常 Exception sending context initialized event to listener instance of class org.springfr ...

  5. mysql中主外键关系

    一.外键: 1.什么是外键 2.外键语法 3.外键的条件 4.添加外键 5.删除外键 1.什么是外键: 主键:是唯一标识一条记录,不能有重复的,不允许为空,用来保证数据完整性 外键:是另一表的主键, ...

  6. javascript 关键字高亮显示实现代码

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <t ...

  7. VS code -python 使用笔记本

    1--使用虚拟环境 |----setting->search: python.venv->设置  venv path (你创建的虚拟环境文件夹所在路径,此处我的是 - 目录下) |---- ...

  8. [Day11]接口、多态

    1.接口 (1)接口定义:interface关键字 ,所在文件仍然是.java文件,编译后仍产生.class文件.       定义格式 public interface 接口名{ 抽象方法1: 抽象 ...

  9. 使用hashlib进行文件校验

    import hashlib import os path = r'D:\CentOS 64 位' def file_md5(path): """ 文件校验 :param ...

  10. Elasticsearch学习笔记(二)Search API 与 Query DSL

    一. Search API eg: GET /mall/product/_search?q=name:productName&sort=price desc 特点:search的请求参数都是以 ...