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. ajax跨域,这应该是最全的解决方案了

    前言 从刚接触前端开发起,跨域这个词就一直以很高的频率在身边重复出现,一直到现在,已经调试过N个跨域相关的问题了,16年时也整理过一篇相关文章,但是感觉还是差了点什么,于是现在重新梳理了一下. 个人见 ...

  2. 赵雅智_Swift(4)_断言

    可选能够让你推断值是否存在.你能够在代码中优雅地处理值缺失的情况.然而,在某些情况下,假设值缺失或者值并不满足特定的条件.你的代码可能并不须要继续执行.这时.你能够在你的代码中触发一个断言(asser ...

  3. python使用requests发送application/x-www-form-urlencoded请求数据

    def client_post_formurlencodeddata_requests(request_url,requestJSONdata): #功能说明:发送以form表单数据格式(它要求数据名 ...

  4. Cocos2dx项目在各种IDE中新建类之后的可行编译方式

    注:这里说可行,但是并不是最好的,只是可以完成编译. 1.linux+code::blocks下的cocos2dx项目新建一个类TestScene.h 新建的TestScene.h和TestScene ...

  5. 手写LRU算法

    import java.util.LinkedHashMap; import java.util.Map; public class LRUCache<K, V> extends Link ...

  6. Golang 笔记 3 if、switch、for、select语句

    一.if语句 Go的流程控制主要包括条件分支.循环和并发.  if语句一般由if关键字.条件表达式和由花括号包裹的代码块组成.在Go中,代码块必须由花括号包裹.这里的条件表达式是结果类型为bool的表 ...

  7. mui---获取设备的网络状态

    在用mui做音乐或视频播放器的时候,往往会考虑当前音乐+视频的播放环境.例如是4G ,WIFI,无网络,给出特定的提示: 具体做法:根据 getCurrentType来进行获取当前网络的类型: plu ...

  8. poj 1556

    哦天哪这个萨比提又浪费了我好几个小时. 我们在check的时候只考虑严格相交就行了,想了很久才注意到这一点. 然后就建图跑最短路,over. #include <cstdio> #incl ...

  9. arch 将 普通用户添加到 docker 组

    如果还没有 docker group 就添加一个: sudo groupadd docker 如果你想用你的使用者帳戶(非root帳戶)來使用Docker,把你的帳戶加到Docker的群組中 sudo ...

  10. swust oj 1068

    图的按录入顺序深度优先搜索     5000(ms)         10000(kb)   Tags: 深度优先     图的深度优先搜索类似于树的先根遍历,即从某个结点开始,先访问该结点, 然后深 ...