1、配置全局文件,注意各个配置标签的顺序

  properties?, settings?, typeAliases?, typeHandlers?, objectFactory?,
    objectWrapperFactory?, reflectorFactory?, plugins?, environments?, databaseIdProvider?,
    mappers?

2、<settings>标签

  2.1 在mybatis全局配置文件中通过<settings>标签控制mybatis全局开关

  2.2  在mybatis 中开启log4j 日志功能

    2.2.1必须保证有log4j.jar

    2.2.2 在src下有log4j.properties文件

     <settings>
<setting name="logImpl" value="LOG4J"/>
</settings>

   2.3  log4j 中可以输出指定内容的日志(控制某个局部内容的日志级别)

            先在总体级别调成Error不输出无用信息

            在设置某个指定位置级别为DEBUG

      

    2.3.1 命名级别(包级别):namespace属性值

    2.3.2 类级别 :namespace 属性值 . namespace类名

    2.3.3 方法级别:使用namespace 属性值+标签id属性值

  <mapper namespace="com.bjsxt.mapper.Peoplemapper">   这里的com.bjsxt.mapper相当于包名,Peoplemapper相当于类
<select id="c" resultType="com.bjsxt.pojo.People"> c 相当于方法名
select * from people
</select>
<select id="d" resultType="com.bjsxt.pojo.People">
select * from people where id=3 or id=4
</select> </mapper>

      

3、parameterType属性

  3.1 在xxxMapper.xml中<select><delete>等标签的 parameterType 可以控制参数类型

      如果参数是map     使用#{key}

      select * from people where id=#{id} and name=#{name}

  3.2  SqlSession的selectList()和selectOne() 的第二个参数和selectMap()的第三个参数都表示的参数。

    3.2.1实例

        测试
1 InputStream is = Resources.getResourceAsStream("mybatis.xml");
SqlSessionFactory factory=new SqlSessionFactoryBuilder().build(is);
SqlSession session=factory.openSession(); People p= session.selectOne("a.b.selById",2); 2代表参数
System.out.println(p.toString());
      xxxMapper.xml                  控制参数类型 int
<select id="selById" resultType="com.bjsxt.pojo.People" parameterType="int">
select * from people where id=#{0}   #{0}表示第一个参数(索引从0开始)如果参数是对象 #{属性名} 属性必须有getset
</select>                   #{param1}也可以表示第一个参数
                      如果只有一个参数(基本数据类型或String),mybatis对#{}里面没有要求只要有内容即可

     #{  }  和 ${  } 的区别  (${}很少使用)

        #{  } 获取参数的内容支持,索引获取,param1获取指定位置参数,并且SQL使用?占位符

        ${  } 字符串拼接不使用?默认找${内容}的get/set方法,如果写数字就是一个数字。

   3.3  如果在xml文件中出现 "<",">",双引号等 特殊字符时 可以使用 XML文件转义标签(xml自身的)

        <![CDATA[内容]]>  

4、分页功能

    4.1 不允许在关键字前后进行数学运算,需要在代码中计算完成后传递到xxxmapper.xml中

    4.2 在java代码中计算

          //显示几个
int pageSize=2;
//第几页
int pageNumber=1;
//如果希望传递多个参数,可以使用对象或map
Map<String,Object> map=new HashMap<>();
map.put("pageSize",pageSize);
map.put("pageStart",pageSize*(pageNumber-1));
List<People> p= session.selectList("a.b.page",map);
System.out.println(p);

     4.3 在xxxmapper.xml中

      

     <select id="page" resultType="com.bjsxt.pojo.People" parameterType="map">
select * from people limit #{pageStart),#{pageSize}
</select>

5、别名

  5.1 系统内置别名:别名全小写

  5.2 给某个类取别名

    5.2.1 alias="自定义 "

     <typeAliases>
<typeAlias type="com.bjsxt.pojo.People" alias="peo"/> 这是给指定类 取别名
</typeAliases>

     5.2.2 在xxxMapper.xml 中通过peo 引用People类

      <select id="page" resultType="peo" parameterType="map">
select * from people limit #{pageStart},#{pageSize}
</select>

    5.3 直接给某包下所有的类取别名  (别名为类名,区分大小写)

     <typeAliases>
<package name="com.bjsxt.pojo"/>  
</typeAliases>

      5.3.1 在xxxMapper,xml中引用

      <select id="page" resultType="People" parameterType="map">
select * from people limit #{pageStart},#{pageSize}
</select>

MyBatis中log4j 和 参数 和 分页和别名 功能的更多相关文章

  1. 2018.2.28 PHP中使用jQuery+Ajax实现分页查询多功能如何操作

    PHP中使用jQuery+Ajax实现分页查询多功能如何操作 1.首先做主页Ajax_pag.php 代码如下 <!DOCTYPE html> <html> <head& ...

  2. Mybatis中多个参数的问题&&动态SQL&&查询结果与类的对应

    ### 1. 抽象方法中多个参数的问题 在使用MyBatis时,接口中的抽象方法只允许有1个参数,如果有多个参数,例如: Integer updatePassword( Integer id, Str ...

  3. Mybatis中Log4j日志的使用

    参考资料: (1). 百度百科:https://baike.baidu.com/item/log4j/480673?fr=aladdin (2). B站狂神的视频:https://www.bilibi ...

  4. Mybatis中使用PageHelper插件进行分页

    分页的场景比较常见,下面主要介绍一下使用PageHelper插件进行分页操作: 一.概述: PageHelper支持对mybatis进行分页操作,项目在github地址: https://github ...

  5. 解决springboot+vue+mybatis中,将后台数据分页显示在前台,并且根据页码自动跳转对应页码信息

    文章目录 先看效果 1.要考虑的问题,对数据进行分页查询 2.前端和后台的交互 先看效果 1.要考虑的问题,对数据进行分页查询 mapper文件这样写 从每次开始查询的位置,到每页展示的条数, < ...

  6. mybatis中的oracle和mysql分页

    这段时间一直在用mybatis+spring+springMVC的框架,总结点东西吧. mybatis的oracle分页写法: <?xml version="1.0" enc ...

  7. Mybatis 中遍历map 参数中的 list 和 array 属性

    原文:https://blog.csdn.net/liudongdong0909/article/details/51048835 问题在项目有中遇到批量删除操作时,需要根据两个属性去删除数据,其中一 ...

  8. MyBatis中foreach传入参数为数组

    一.当只有一个参数,并且这个参数是数组时 接口方法的参数不需要添加@Param注释,collection="array" 示例 接口的方法 void deleteMulti(Str ...

  9. mybatis中如果存在参数不再实体中的是如何处理

    <select id="queryMapByType" parameterType="int" resultType="my.geomap.VO ...

随机推荐

  1. 188. Best Time to Buy and Sell Stock IV (Array; DP)

    Say you have an array for which the ith element is the price of a given stock on day i. Design an al ...

  2. Java 的静态工厂方法

    本文转载自:https://www.jianshu.com/p/ceb5ec8f1174 序:什么是静态工厂方法 Effective Java 2.1 静态工厂方法与构造器不同的第一优势在于,它们有名 ...

  3. Python: AES加密与解密

    起源: 视频下载,解析到一个网站时,发现其视频id是用AES加密过的,用的是https://code.google.com/archive/p/crypto-js/这个库.解密很简单的一句js代码: ...

  4. docker数据卷(转)

    原文地址:http://www.cnblogs.com/zydev/p/5809616.html Docker-数据卷和数据容器卷 容器中管理数据主要有两种方式: 数据卷(Data Volumes) ...

  5. Fresco加载显示gif图片

    第一步:首先要导包 Android Studio 或者 Gradle dependencies { compile 'com.facebook.fresco:fresco:0.6.0+' } 第二步: ...

  6. @params、@PathVariabl和@RequestParam用法与区别

    [1]params params: 指定request中必须包含某些参数值是,才让该方法处理. @RequestMapping(value = "testParamsAndHeaders&q ...

  7. SVO+PL-SVO+PL-StVO

    PL-SVO是基于点.线特征的半直接法单目视觉里程计,我们先来介绍一下基于点特征的SVO,因为是在这个基础上提出的. [1]References:      SVO: Fast Semi-Direct ...

  8. python 基础数据类型 之 列表

    列表:定义 和特性 列表定义和创建: 定义:[,]内以逗号分隔,按照索引,存放各种数据类型,一般没有限制,每个位置代表一个元素 range_create = list(range(0, 10))pri ...

  9. mysql学习笔记-1.下载与安装

    1.到mysql官网下载操作系统对应的数据库,下载地址https://dev.mysql.com/downloads/mysql/ 2.有msi安装版本和zip压缩版本,2种安装方式不同, 3.安装后 ...

  10. PAT 1067 试密码(20)(代码)

    1067 试密码(20 分) 当你试图登录某个系统却忘了密码时,系统一般只会允许你尝试有限多次,当超出允许次数时,账号就会被锁死.本题就请你实现这个小功能. 输入格式: 输入在第一行给出一个密码(长度 ...