//书写我的第一个mybaits程序,主要讲的是mybatis-config.xml的文件

需求:根据用户名查询用户信息;

1、  通过session调用selectOnt(statme,"zhangsan")

2、  创建User的实体类

3、  创建UserMapper.xml文件

4、  在Mybatis-config.xml中将mapper.xml文件导入

public static void main(String[] args) throws Exception {

// 定义配置文件路径

String resource = "mybatis-config.xml";

// 读取配置文件

InputStream inputStream = Resources.getResourceAsStream(resource);

// 通过SqlSessionFactoryBuilder构建一个SqlSessionFactory

SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

System.out.println(sqlSessionFactory);

// 通过sqlSessionFactory获得SqlSession对象

SqlSession session = sqlSessionFactory.openSession();

System.out.println(session);

User user = session.selectOne("cn.itcast.mybatis.user.queryUserByUserName", "zhangsan");

System.out.println(user);

}

//mapper.xml

<mapper namespace="cn.itcast.mybatis.user">

<select id="queryUserByUserName" resultType="cn.itcast.mybatis.pojo.User">

SELECT *, user_name userName  FROM tb_user WHERE user_name = #{userName}

</select>

</mapper>

//注意:

其中namespace是接口的全路径,id是方法名,保证唯一,

<?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>
           <!-- 引入外部的配置文件 -->
      <properties resource="jdbc.properties"/>
  <settings>
      <!-- 开启驼峰自动映射 -->
    <setting name="mapUnderscoreToCamelCase" value="true"/>
  </settings>
  <typeAliases>
      <!-- 设置别名 -->
      <!-- <typeAlias type="cn.itcast.mybatis.pojo.User" alias="user"/> -->
      <package name="cn.itcast.mybatis.pojo"/>
   </typeAliases>
      <!-- 指定环境 -->
  <environments default="development">
        <environment id="development">
        <transactionManager type="JDBC" />
             <dataSource type="POOLED">
              <property name="driver" value="${jdbc.driver}" />
          <property name="url" value="${jdbc.url}" />
        <property name="username" value="${jdbc.username}" />
        <property name="password" value="${jdbc.password}" />
        </dataSource>
    </environment>

<!-- 配置测试环境的数据库  -->
         <environment id="test">
        <transactionManager type="JDBC" />
          <dataSource type="POOLED">
              <property name="driver" value="${jdbc.test.driver}" />
              <property name="url" value="${jdbc.test.url}" />
              <property name="username" value="${jdbc.test.username}" />
              <property name="password" value="${jdbc.test.password}" />
          </dataSource>
      </environment>
  </environments>
<mappers>

<!--  配置单个mapper.xml文件    -->
<!-- <mapper resource="UserMapper.xml" /> -->
<!-- <mapper resource="UserMapper2.xml" /> -->
<!-- <mapper class="cn.itcast.mybatis.dao.IUser"/> -->

<!-- 配置扫描包,此包下的文件全部被读取到  -->
<package name="cn.itcast.mybatis.dao"/>
</mappers>
</configuration>

//注意:

// 构造SqlSessionFactory
// 定义配置文件路径
String resource = "mybatis-config.xml";
// 读取配置文件
InputStream inputStream = Resources.getResourceAsStream(resource);
// 通过SqlSessionFactoryBuilder构建一个SqlSessionFactory
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream,"test");
this.sqlSession = sqlSessionFactory.openSession(false);
this.userDAO = sqlSession.getMapper(IUser.class);

总结:

如果手动实现接口实现类,namespace和Statement的id随便定义;

如果使用动态代理实现类,namespace和Statement必须按照约定来定义;

使用mapper接口不用写接口实现类即可完成数据库操作,使用非常简单,也是官方所推荐的使用方法。

使用mapper接口的必须具备以几个条件:

1)       Mapper的namespace必须和mapper接口的全路径一致。

2)       Mapper接口的方法名必须和sql定义的id一致。

3)       Mapper接口中方法的输入参数类型必须和sql定义的parameterType一致。

4)       Mapper接口中方法的输出参数类型必须和sql定义的resultType一致。

mybati之入门demo的更多相关文章

  1. 【SSH系列】初识spring+入门demo

    学习过了hibernate,也就是冬天,经过一个冬天的冬眠,当春风吹绿大地,万物复苏,我们迎来了spring,在前面的一系列博文中,小编介绍hibernate的相关知识,接下来的博文中,小编将继续介绍 ...

  2. 基于springboot构建dubbo的入门demo

    之前记录了构建dubbo入门demo所需的环境以及基于普通maven项目构建dubbo的入门案例,今天记录在这些的基础上基于springboot来构建dubbo的入门demo:众所周知,springb ...

  3. apollo入门demo实战(二)

    1. apollo入门demo实战(二) 1.1. 下载demo 从下列地址下载官方脚本和官方代码 https://github.com/nobodyiam/apollo-build-scripts ...

  4. lua入门demo(HelloWorld+redis读取)

    1. lua入门demo 1.1. 入门之Hello World!! 由于我习惯用docker安装各种软件,这次的lua脚本也是运行在docker容器上 openresty是nginx+lua的各种模 ...

  5. netty入门demo(一)

    目录 前言 正文 代码部分 服务端 客服端 测试结果一: 解决粘包,拆包的问题 总结 前言 最近做一个项目: 大概需求: 多个温度传感器不断向java服务发送温度数据,该传感器采用socket发送数据 ...

  6. canal入门Demo

    关于canal具体的原理,以及应用场景,可以参考开发文档:https://github.com/alibaba/canal 下面给出canal的入门Demo (一)部署canal服务器 可以参考官方文 ...

  7. C#中缓存的使用 ajax请求基于restFul的WebApi(post、get、delete、put) 让 .NET 更方便的导入导出 Excel .net core api +swagger(一个简单的入门demo 使用codefirst+mysql) C# 位运算详解 c# 交错数组 c# 数组协变 C# 添加Excel表单控件(Form Controls) C#串口通信程序

    C#中缓存的使用   缓存的概念及优缺点在这里就不多做介绍,主要介绍一下使用的方法. 1.在ASP.NET中页面缓存的使用方法简单,只需要在aspx页的顶部加上一句声明即可:  <%@ Outp ...

  8. SpringBoot 入门 Demo

    SpringBoot   入门 Demo Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从 ...

  9. ReactJs 入门DEMO(转自别人)

    附件是分享的一些他人的ReactJs入门DEMO,以前版本使用的是JSXTransformer.js,新版的用browser.min.js替代了. DEMO 下载地址:http://files.cnb ...

随机推荐

  1. oracle中 connect by prior 递归算法 -- 理解

    oracle中 connect by prior 递归算法 -- 理解 http://blog.163.com/xxciof/blog/static/7978132720095193113752/  ...

  2. Asp.net Repeater控件

    Repeater控件和DataList控件,可以用来一次显示一组数据项.比如,可以用它们显示一个数据表中的所有行.     Repeater控件完全由模板驱动,提供了最大的灵活性,可以任意设置它的输出 ...

  3. ios视图切换之push与present混用

    在变成过程中,经常遇到两个视图控制器之间的切换,导航控制器即UINaVigation是最常用的一种,有时为了某些效果又需要进行模态切换,即present. 我们的布局经常是在window上加一个nav ...

  4. Ubuntu最小化桌面快捷键Super+D不生效解决

    之前用的Debian,最近研发老大让统一使用Ubuntu来开发,安装了Ubuntu 15.10之后,设置了最小化桌面的快捷键为Super+D(在Systm Settings/系统设置—>Keyb ...

  5. PHPCMS 插件开发教程及经验谈

    虽说 PHPCMS 开源,但其它开发文档及参考资料实在少得可怜.进行二次开发时,自己还得慢慢去研究它的代码,实在让人郁闷. PHPCMS 的“Baibu/Google地图”实在有待改进,对于数据量比较 ...

  6. phpcms v9二次开发之模型类的应用(2)

    二.模型操作方法select()--查询语句         //查询级别管理列表信息    public function levellists() { $lelists = $this->l ...

  7. php入门自学小展示

    <!doctype html> <html> <head> <title>PHP函数小展示</title> </head> &l ...

  8. Centos+nginx+uwsgi+Python多站点环境搭建

    前言 新公司的第一个项目,服务器端打算用python作为restful api.所以需要在Centos上搭建nginx+fastcgi+python的开发环境,但后面网上很多言论都说uwsgi比fas ...

  9. 【学习笔记】【oc】copy与mutableCopy

    copy 返回一个不可变的对象: mutableCopy 返回一个可变的对象: 使用copy方法时 类必须实现:<NSCopying>协议中的-(id)copyWithZone:(NSZo ...

  10. 『局域网安全』利用ARP欺骗劫持Cookie

    0x 00 ARP欺骗说明 欺骗原理相关内容就不多叙述了,百度一大堆 实施ARP欺骗在Windows下,Linux下都相关工具 由于在Linux下可以开启ip_forward功能,个人认为Linux下 ...