一:mybatis概念
1:简介
       MyBatis本是apache的一个开源项目iBatis,2010年改名为 MyBatis,
       MyBatis 是一个基于Java的持久层框架。(操作数据库)
2:优点
       1:半自动化的ORM实现(实体类和SQL语句之间建立映射关系)
       2:SQL代码从程序代码中彻底分离,可重用
       3:与JDBC相比,减少了50%以上的代码量
       4:小巧灵活、简单易学,是最简单的持久化框架
       5:提供XML标签,支持编写动态SQL
       6:提供映射标签,支持对象与数据库的ORM字段映射
3:MyBatis缺点
     1:SQL语句编写工作量大,对开发人员有一定sql技术要求
     2:数据库移植性差(不同数据库,sql语句语法有所不同)

*******************************************mybatis环境搭建开始******************************************

1:导入mybatis的jar包
    mybatis-3.2.2.jar
    mysql-connector-java-5.1.25-bin.jar

2:创建mybatis的核心配置文件(mybatis-config.xml)
   <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/y2t189?useUnicode=true&amp;characterEncoding=utf-8" />  数据库的url
    <property name="username" value="root" />   用户名
    <property name="password" value="zhangjiugui" />  密码
   </dataSource>
  </environment>
 </environments>
        <!--
           dao层的mapper映射文件(xml)
        -->
 <mappers>
  <mapper resource="com/accp/y2t189/dao/UserMapper.xml" />
 </mappers>
  </configuration>

3: 实体类

4:数据访问的接口(dao)

public List<User> findUsers();

5:接口与sql语句的映射  UserMapper.xml

命名空间必须是响应接口的全路径
   <mapper namespace="com.accp.y2t189.dao.UserMapper">
 
         id必须和接口中的方法名一致
         resultType返回值类型(返回集合的话,指定集合元素的类型)
 <select id="findUsers" resultType="com.accp.y2t189.entity.User">
  SELECT * FROM users
 </select>

</mapper>

*******************************************************************写好的粘贴可用*************************************************************************

6:mybatis的工具类

获得SqlSession
        ①:读取配置文件,创建session工厂
        ②:在session工厂里,获得session会话
    关闭session
        判断session实例是否创建,不为null,就关闭session

/**
      * mybatis的工具类
      * 获得session
      */
     public class MybatisUtil {
 
  public static SqlSessionFactory sf;  //session工厂
 
  //获得session工厂
         static { 
          try { 
          Reader  is= Resources.getResourceAsReader("mybatis-config.xml"); 
          sf= new SqlSessionFactoryBuilder().build(is);
         } catch (Exception e) { 
             e.printStackTrace(); 
         } 
  } 
   
  //获得session
         public static SqlSession getSession(){
           return sf.openSession();
         }
   
         //关闭session
         public static void  closeSession(SqlSession session){
      if(session !=null){
       session.close();
      }
      } 
     }

7: 数据操作
       //获得session
       session=MybatisUtil.getSession();
       //获得接口实例
       List<User> listUser=session.getMapper(UserMapper.class).findUsers();
       //关闭session

*******************************************mybatis环境搭建结束******************************************
*******************************************增删改开始***************************************************

/**
  * 查询所有数据
  * @return
  */
 public List<User> findAll();
******************
        <select id="findAll" resultType="entity.User">
  SELECT * FROM users
 </select>

**************************************************

/**
  * 根据编号查询对象
  * @param 用户表的主键
  * @return  一个对象user
  */
 public  User findById(Integer userId);
******************
        <select id="findById" parameterType="Integer" resultType="entity.User">
     select * from users where  id=#{userId}
 </select>

**************************************************

/**
  * 增加用户信息
  * @param 一个对象数据
  * @return  数据库的影响行数
  */
 public Integer add(User user);
******************
        <insert id="add"  parameterType="entity.User">
       INSERT INTO users VALUES(NULL,#{userName},#{password},#{realName})
 </insert>

**************************************************

/**
  * 根据编号删除对象
  * @param  用户表的主键
  * @return 数据库的影响行数
  */
 public Integer delete(Integer id);
******************
        <delete id="delete" parameterType="Integer">
       delete from users where id=#{id}
 </delete>

**************************************************

/**
  * 修改用户信息
  * @param 一个对象数据
  * @return  数据库的影响行数
  */
 public Integer update(User user);
******************
        <!-- 根据属性的主键修改其他的属性值-->
        <update id="update" parameterType="entity.User">
             update users set userName=#{userName} ,password=#{password},realName=#{realName}
             where id=#{id}
        </update>

**************************************************

/**
  * 连表查询用户信息
         * 在从表的实体类中添加级联查询主表中的属性
         * SELECT u.*,rolename  在用户表中添加角色表的属性-角色名称
  */
  public List<User> findUserAndRole();
******************
         <select id="findUserAndRole" resultType="entity.User">
  SELECT u.*,rolename FROM users u INNER JOIN role  r
                ON u.`roleid`=r.`roleid`
  </select>
**************************************************
   
    模糊查询

//根据角色名称,模糊查询角色列表
    public List<Role>  findRoleByRoleName(String rolename);
  
    <!--
 <select id="findRoleByRoleName" resultMap="roleMapping">
  SELECT * FROM role
  where  roleName  like  concat('%',#{rolename},'%')
 </select>
    -->
    <select id="findRoleByRoleName" resultMap="roleMapping">
  SELECT * FROM role
  where  roleName  like  "%"#{rolename}"%"
    </select>
*******************************************增删改查结束***************************************************

如何搭建环境---初识mybatis的更多相关文章

  1. 【One Day菜鸟到大鸟】MyBatis搭建环境

    一.概述     MyBatis是一个持久化框架和Hiberante差不多.比起JDBC来说MyBatis封装了JDBC让我们能够面向对象开发.比起Hiberante来说卸下了Hiberante那种重 ...

  2. 初识Mybatis之工程搭建

    简介:MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可以使用简单的 ...

  3. 初识mybatis(二)

    上篇博客我们介绍通过Java代码来创建mybatis的配置文件,港真,这种方式看起来有意思实际在开发中用的并不多,mybatis的配置还是以xml配置为主,本文我们就来看看如何通过xml文件来配置my ...

  4. MyBatis学习01(初识MyBatis和CRUD操作实现)

    1.初识MyBatis 环境说明: jdk 8 + MySQL 5.7.19 maven-3.6.1 IDEA 学习前需要掌握: JDBC MySQL Java 基础 Maven Junit 什么是M ...

  5. 搭建Spring + SpringMVC + Mybatis框架之二(整合Spring和Mybatis)

    整合Spring和Mybatis 首先给出完整的项目目录: (1)引入项目需要的jar包 使用http://maven.apache.org作为中央仓库即可. Spring核心包,mybatis核心包 ...

  6. mybatis入门--初识mybatis

    初识mybatis 今天,一起来说说mybits这个框架吧.这是一个持久层的框架.之前叫做ibatis.所以,在它的代码中出现ibatis这个词的时候,不要感到惊讶.不是写错了,它确实就是这个样子的. ...

  7. MyBatis For .NET学习- 初识MyBatis

    MyBatis的框架. Introduction MyBatis本是apache的一个开源项目iBatis,2010年这个项目由 apache software foundation迁移到了googl ...

  8. ssm整合:搭建环境

    解决配置中文过滤器后,存入数据库时依旧乱码问题:在web.xml中修改数据库url如下: <property name="jdbcUrl" value="jdbc: ...

  9. 手把手Maven搭建SpringMVC+Spring+MyBatis框架(超级详细版)

    手把手Maven搭建SpringMVC+Spring+MyBatis框架(超级详细版) SSM(Spring+SpringMVC+Mybatis),目前较为主流的企业级架构方案.标准的MVC设计模式, ...

随机推荐

  1. kuangbin专题 专题一 简单搜索 Oil Deposits HDU - 1241

    题目链接:https://vjudge.net/problem/HDU-1241 题意:问有几个油田,一个油田由相邻的‘@’,组成. 思路:bfs,dfs都可以,只需要遍历地图,遇到‘@’,跑一遍搜索 ...

  2. Bzoj: 2073 [POI2004]PRZ 题解

    2073: [POI2004]PRZ Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 401  Solved: 296[Submit][Status][D ...

  3. ~~核心编程(二):面向对象——类&属性~~

    进击のpython 类&属性 虽然我们上一part写了一个面向对象的程序:人狗大战 但是如果在面向对象来看 你这些的就不够规范 你既然选择用面向对象的思想来写 那你就要符合人家的定义规范和操作 ...

  4. Netty-Channel架构体系源码解读

    全文围绕下图,Netty-Channel的简化版架构体系图展开,从顶层Channel接口开始入手,往下递进,闲言少叙,直接开撸 概述: 从图中可以看到,从顶级接口Channel开始,在接口中定义了一套 ...

  5. ServiceFabric极简文档-1.1 附属文件:规划和准备 Service Fabric 独立群集部署

    准备好要充当节点的计算机 下面是要添加到群集的每台计算机的建议规格: 至少 16 GB RAM 至少 40 GB 可用磁盘空间 4 核或更高规格的 CPU 所有计算机与安全网络连接 Windows S ...

  6. 各类最短路算法基本模板-C++

    原文转自:https://blog.csdn.net/changjiale110/article/details/77394650 感谢. #define Max 0x3f3f3f3f #define ...

  7. 开源一个好用的nodejs访问mysql类库

    一.背景问题 自nodejs诞生以来出现了一大批的web框架如express koa2 egg等等,前端可以不再依赖后端可以自己控制服务端的逻辑.原来的后端开发同学的阵地前端如今同样也写的风生水起,撸 ...

  8. C语言入门5-键盘的输入和屏幕输出

    C程序中的键盘输入和屏幕输出都是通过  调用输入/输出函数  实现的. 一.数据的格式化    屏幕输出 函数printf()的一般格式  (有两种) (1)第一种: printf(格式控制字符串): ...

  9. C#4.0新增功能03 泛型中的协变和逆变

    连载目录    [已更新最新开发文章,点击查看详细] 协变和逆变都是术语,前者指能够使用比原始指定的派生类型的派生程度更大(更具体的)的类型,后者指能够使用比原始指定的派生类型的派生程度更小(不太具体 ...

  10. django中ORM的model对象和querryset 简单解析

    欢迎大家查看我的博客,我会不定时的用大白话发一些看了就能懂的文章,大家多多支持!如您对此文章内容有独特见解,欢迎与笔者练习一起探讨学习!原创文创!转载请注明出处! ORM是干嘛的? 介绍orm之前我应 ...