Mybatis优化

log4j日志显示

在pom.xml中的<dependencies>标签中加入

<!--log4j日志 -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>

在resources文件夹下创建log4j.xml


<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
<param name="Encoding" value="UTF-8"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-5p %d{MM-dd HH:mm:ss,SSS} %m (%F:%L) \n"/>
</layout>
</appender> <logger name="java.sql">
<level value="debug"></level>
</logger> <logger name="org.apache.ibatis">
<level value="info"></level>
</logger> <root>
<level value="debug"></level>
<appender-ref ref="STDOUT"/>
</root> </log4j:configuration>

创建GetSqlsession类

快速获取SqlSession,不在每次都定义这么多项


package com.getsqlsession;
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 java.io.IOException;
import java.io.InputStream; public class M_SelSession {
public static SqlSession getSqlSession() {
InputStream is=null;
try {
//加载核心配置文件
is = Resources.getResourceAsStream("mybatis-config.xml");
} catch (IOException ioException) {
ioException.printStackTrace();
}finally {
//工厂模式,获取SqlSessionFactoryBuilder
SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
//获取sqlSessionFactory
SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
//通过工厂获取sqlSession
SqlSession sqlSession = sqlSessionFactory.openSession(true); //自动提交事务
return sqlSession;
} } }

调用时


package com.test;
import com.getsqlsession.M_SelSession;
import com.mapper.UserMapper;
import com.pojo.User;
import org.apache.ibatis.session.SqlSession; import java.util.List; public class Test { public static void main(String[] args) {
SqlSession sqlSession= M_SelSession.getSqlSession(); //快速获取sqlSession
UserMapper userMapper=sqlSession.getMapper(UserMapper.class); //获取实体类 } }

引入properties文件

  1. 在resources下创建data.properties文件
  2. 在文件中写入

jdbc.Driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/test
jdbc.user=root
jdbc.pwd=3124

注意将user和pwd的内容改为自己登陆的MySQL用户名和密码

  1. 在mybatis-config.xml中的<configuration>中加入<properties>标签,resources属性内容为刚刚创建的文件名

<properties resource="data.properties"/>
  1. 修改mybatis-config.xml文件中的内容,使用${}用于接收properties文件中的内容,{}中的内容为properties文件中的key名

<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.user}"/>
<property name="password" value="${jdbc.pwd}"/>
</dataSource>
</environment>
</environments>

给类型起别名

  1. 在mybatis-config.xml中的<configuration>标签中的内部标签顺序
(properties?,settings?,typeAliases?,typeHandlers?,objectFactory?,
objectWrapperFactory?,reflectorFactory?,plugins?,environments?,
databaseIdProvider?,mappers?)
  1. 我们在<configuration>标签中加入<typeAliases>标签用于起别名,注意其位置在<properties>标签后面

<typeAliases>中的<typeAlias type="com.pojo.User" alias="user"></typeAlias>标签,用于添加单个的类别名,type属性为该类的全类名,alias属性为别名名称,如果不写alias默认别名为类名

<package>标签用于将该包下的全部类起默认别名,便于后面在mapper.xml中使用


<!--给类起别名,在mapper.xml中可以对于查询的resultType直接使用别名进行使用,不需要全类名了-->
<typeAliases>
<typeAlias type="com.pojo.User" alias="user"></typeAlias> <package name="com.pojo"/>
</typeAliases>
  1. 在mapper.xml中使用,在查询时直接使用user作为resultType属性的内容,这里的user是我们上面起的别名,也是User类的默认别名,不区分大小写.

<select id="selectAllUser" resultType="User">
select * from user
</select> <select id="selectUserById" resultType="user">
select * from user where userid=2
</select>

引入映射文件

  1. 在mybatis-config.xml的<mappers>中使用<mapper>标签或者<package>标签引入映射文件

<mappers>
<!--方式一,resource属性值为:UserMapper.xml文件的路径+文件名-->
<mapper resource="com/mapper/UserMapper.xml"/>
<!--
使用包的方式引入,会将包下的映射文件都引入
要求:1.UserMapper.xml文件的各个文件夹名必须和对应接口的各级文件夹一致
2. UserMapper.xml必须和其对应的接口名一致.
-->
<package name="com/mapper"/>
</mappers>

Mybatis优化的更多相关文章

  1. 05_ssm基础(二)之mybatis优化

    06.mybatis优化之Mybatis工具类提取 优化原则(见官方文档): mybatis工具类存放位置: mybatis工具类代码: package com.day01.ssm.mybatisDe ...

  2. Mybatis 优化:

    Mybatis 的优化: ** 第一个 对于数据库配置的优化: 创建一个 DB.properties 的文件 里面编写Key = value 形式的数据库信息 比如: driver = com.mys ...

  3. MyBatis——优化MyBatis配置文件中的配置

    原文:http://www.cnblogs.com/xdp-gacl/p/4264301.html 一.连接数据库的配置单独放在一个properties文件中 之前,我们是直接将数据库的连接配置信息写 ...

  4. MyBatis优化技巧

    ☬配置日志文件 封装工具类 代码贴一下: package com.shxt.utils; import java.io.InputStream; import org.apache.ibatis.io ...

  5. mybatis优化配置

    在src下建立db.properties driver=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/mybatis name=root ...

  6. Mybatis原理和代码剖析

    参考资料(官方) Mybatis官方文档: https://mybatis.org/mybatis-3/ Mybatis-Parent : https://github.com/mybatis/par ...

  7. MyBatis快速上手与知识点总结

    目录 1.MyBatis概述 1.1 MyBatis概述 1.2 JDBC缺点 1.3 MyBatis优化 2.MyBatis快速入门 3.Mapper代理开发 3.1 Mapper代理开发概述 3. ...

  8. MyIbatis和Hibernate的区别--2019-04-26

    1.MyBatis 真正实现了java代码和sql的分离 2.Hibernate 是全自动的,MyBatis是半自动的 Hibernate实现了部分自动生成SQL 3.SQL优化上 MyBatis 强 ...

  9. 阿里P7Java最全面试296题:阿里天猫、蚂蚁金服含答案文档解析

    [阿里天猫.蚂蚁.钉钉面试专题题目加答案] 不会做别着急:文末有答案以及视频讲解,架构师资料 1. junit用法,before,beforeClass,after, afterClass的执行顺序 ...

  10. 【转】MyBatis学习总结(三)——优化MyBatis配置文件中的配置

    [转]MyBatis学习总结(三)——优化MyBatis配置文件中的配置 一.连接数据库的配置单独放在一个properties文件中 之前,我们是直接将数据库的连接配置信息写在了MyBatis的con ...

随机推荐

  1. Pointers and Constants

    Pointers and Constants char * const q = "abc"; // q is const *q = 'c'; // OK q++; //ERROR ...

  2. 互斥锁 线程理论 GIL全局解释器锁 死锁现象 信号量 event事件 进程池与线程池 协程实现并发

    目录 互斥锁 multiprocessing Lock类 锁的种类 线程理论 进程和线程对比 开线程的两种方式(类似进程) 方式1 使用Thread()创建线程对象 方式2 重写Thread类run方 ...

  3. 解决Win10更新后远程桌面提示CredSSP加密Oracle修正的问题

    1.以管理员身份打开cmd,运行命令提示符:2.执行REG ADD HKLM\Software\Microsoft\Windows\CurrentVersion\Policies\System\Cre ...

  4. Apache Kafka 移除 ZK Proposals

    Zookeeper 和 KRaft 这里有一篇 Kafka 功能改进的 proposal 原文.要了解移除 ZK 的原因,可以仔细看看该文章.以下是对该文章的翻译. 动机 目前,Kafka 使用 Zo ...

  5. cmd无限弹窗

    记一次写 .bat 文件时犯的低级错误,搞的重启了好几次才发现问题所在 如下 文件名 和 批处理 内容 会造成 无限弹出cmd窗口 原因是一般情况下会启动系统的 cmd.exe,而此处用的简写,在执行 ...

  6. VSCode运行C/C++配置

    将MinGw安装目录下的 1.安装 VSCode 2.安装 MinGW 链接:点击跳转 3.MinGW 内安装两个模块 1.右键 Mark for Installation 勾选 (此处已安装好,所以 ...

  7. 华为云Stack新版发布:构筑行业云底座,共创行业新价值

    摘要:在以"政企深度用云,释放数字生产力"为主题的华为云Stack战略暨新品发布会上,华为云提出深度用云三大关键举措,并发布华为云Stack 8.2版本,以智能进化推动创造行业新价 ...

  8. 买不到的数目【第四届蓝桥杯省赛C++A组,第四届蓝桥杯省赛JAVAC组】

    买不到的数目 小明开了一家糖果店. 他别出心裁:把水果糖包成4颗一包和7颗一包的两种. 糖果不能拆包卖. 小朋友来买糖的时候,他就用这两种包装来组合. 当然有些糖果数目是无法组合出来的,比如要买 10 ...

  9. 【大型软件开发】浅谈大型Qt软件开发(一)开发前的准备——在着手开发之前,我们要做些什么?

    前言 最近我们项目部的核心产品正在进行重构,然后又是年底了,除了开发工作之外项目并不紧急,加上加班时间混不够了....所以就忙里偷闲把整个项目的开发思路聊一下,以供参考. 鉴于接下来的一年我要操刀这个 ...

  10. (10)go-micro微服务发送邮件

    目录 一 获取QQ邮箱Pass 二 安装gomail 三 初始化发送邮件 四 发送注册邮件 五 发送重置密码邮件 六 最后 一 获取QQ邮箱Pass 1.登录QQ邮箱 2.点击设置,点击账户,下拉找到 ...