- 浏览: 3423977 次
- 性别:
- 来自: 珠海
文章分类
- 全部博客 (1633)
- Java (250)
- Android&HTML5 (111)
- Struts (10)
- Spring (236)
- Hibernate&MyBatis (115)
- SSH (49)
- jQuery插件收集 (55)
- Javascript (145)
- PHP (77)
- REST&WebService (18)
- BIRT (27)
- .NET (7)
- Database (105)
- 设计模式 (16)
- 自动化和测试 (19)
- Maven&Ant (43)
- 工作流 (36)
- 开源应用 (156)
- 其他 (16)
- 前台&美工 (119)
- 工作积累 (0)
- OS&Docker (83)
- Python&爬虫 (28)
- 工具软件 (157)
- 问题收集 (61)
- OFbiz (6)
- noSQL (12)
最新评论
-
HEZR曾嶸:
你好博主,这个不是很理解,能解释一下嘛//左边+1,上边+1, ...
java 两字符串相似度计算算法 -
天使建站:
写得不错,可以看这里,和这里的这篇文章一起看,有 ...
jquery 遍历对象、数组、集合 -
xue88ming:
很有用,谢谢
@PathVariable映射出现错误: Name for argument type -
jnjeC:
厉害,困扰了我很久
MyBatis排序时使用order by 动态参数时需要注意,用$而不是# -
TopLongMan:
非常好,很实用啊。。
PostgreSQL递归查询实现树状结构查询
原文 http://3131854.blog.51cto.com/3121854/1147446
mybatis使用拦截器显示sql,使用druid配置连接信息 http://www.cnblogs.com/babyhhcsy/p/4500884.html
@Intercepts( {
@Signature(method = "query", type = Executor.class, args = {
MappedStatement.class, Object.class, RowBounds.class,
ResultHandler.class }),
@Signature(method = "prepare", type = StatementHandler.class, args = { Connection.class }) })
@Intercepts标记了这是一个Interceptor,然后在@Intercepts中定义了两个@Signature,即两个拦截点。第一个@Signature我们定义了该Interceptor将拦截Executor接口中参数类型为MappedStatement、Object、RowBounds和ResultHandler的query方法;第二个@Signature我们定义了该Interceptor将拦截StatementHandler中参数类型为Connection的prepare方法。
这次项目中要求把所有mybatis所执行的sql都记录到一个文件中,下面是自己写的一个插件(源是参考网上一个重写mybatis分页插件的例子):
1.配置插件(在mybatis的配置文件里mybatis.xml配置自己写的这个插件(拦截器)):
2.MyBatisSQLInterceptor的内容:
mybatis使用拦截器显示sql,使用druid配置连接信息 http://www.cnblogs.com/babyhhcsy/p/4500884.html
@Intercepts( {
@Signature(method = "query", type = Executor.class, args = {
MappedStatement.class, Object.class, RowBounds.class,
ResultHandler.class }),
@Signature(method = "prepare", type = StatementHandler.class, args = { Connection.class }) })
@Intercepts标记了这是一个Interceptor,然后在@Intercepts中定义了两个@Signature,即两个拦截点。第一个@Signature我们定义了该Interceptor将拦截Executor接口中参数类型为MappedStatement、Object、RowBounds和ResultHandler的query方法;第二个@Signature我们定义了该Interceptor将拦截StatementHandler中参数类型为Connection的prepare方法。
这次项目中要求把所有mybatis所执行的sql都记录到一个文件中,下面是自己写的一个插件(源是参考网上一个重写mybatis分页插件的例子):
1.配置插件(在mybatis的配置文件里mybatis.xml配置自己写的这个插件(拦截器)):
<plugins> <!-- mybatis写出sql记录控件(拦截器) --> <plugin interceptor="com.zqgame.interceptors.MyBatisSQLInterceptor"> <!-- 自己写的那个拦截器 --> <property name="dialect" value="mysql"/> <!-- mysql的方言 --> </plugin> </plugins>
2.MyBatisSQLInterceptor的内容:
package com.zqgame.interceptors; import java.io.File; import java.sql.Connection; import java.util.ArrayList; import java.util.Date; import java.util.HashMap; import java.util.List; import java.util.Properties; import net.sf.json.JSONObject; import org.apache.commons.io.FileUtils; import org.apache.commons.lang.time.DateFormatUtils; import org.apache.ibatis.executor.statement.StatementHandler; /*import org.apache.ibatis.mapping.BoundSql;*/ import org.apache.ibatis.plugin.Interceptor; import org.apache.ibatis.plugin.Intercepts; import org.apache.ibatis.plugin.Invocation; import org.apache.ibatis.plugin.Plugin; import org.apache.ibatis.plugin.Signature; import org.apache.ibatis.reflection.MetaObject; import com.zqgame.common.Constant; /** * 拦截StatementHandler里的 prepare方法把执行的sql进行记录到文件里 * @author panguixiang * */ @Intercepts({ @Signature(type = StatementHandler.class, method = "prepare", args = { Connection.class }) }) public class MyBatisSQLInterceptor implements Interceptor { public Object intercept(Invocation invocation) throws Throwable { StatementHandler statementHandler = (StatementHandler) invocation.getTarget(); MetaObject metaStatementHandler = MetaObject.forObject(statementHandler); String originalSql = (String) metaStatementHandler.getValue("delegate.boundSql.sql");//获得sql /* * if(log.isDebugEnabled()){ log.debug("生成分页SQL : "+boundSql.getSql());* }*/ File sqlFile = null; List<String> lines = null; @SuppressWarnings("unchecked") HashMap<String, String> mapParam = (HashMap<String, String>) metaStatementHandler.getValue("delegate.boundSql.parameterObject"); synchronized (this) { sqlFile = new File(Constant.SQLFILE.concat( DateFormatUtils.format(new Date(), "yyyyMMdd")).concat("-sql.txt"));/*此处是构造sql文件名称,那个Constant.SQLFILE是自己配的一个常量内容比如为:d:\\,可以随便写*/ lines = new ArrayList<String>(); lines.add(originalSql.replaceAll("\n", "").replaceAll("\t", "").replaceAll(" +", " ")); JSONObject jsonObject = JSONObject.fromObject(mapParam); lines.add(jsonObject.toString()); FileUtils.writeLines(sqlFile, "utf-8", lines, true);//将sqlString 写入文件 } return invocation.proceed(); } public Object plugin(Object target) { return Plugin.wrap(target, this); } public void setProperties(Properties properties) { // TODO Auto-generated method stub } }
发表评论
-
spring配置事物的方式:注解和aop配置
2016-05-14 00:26 4104参考: Spring AOP中pointcut express ... -
Mybatis分库分表扩展插件
2016-05-12 15:47 1625http://fangjialong.iteye.com/bl ... -
spring+mybatis+atomikos 实现JTA事务
2016-05-11 22:00 5523sping配置多个数据源 不同用户操作不同数据库 http:/ ... -
ibatis扩展支持主键生成的方法(非数据库方式)
2016-04-13 22:01 976http://blog.csdn.net/warison200 ... -
ibatis 动态 Mapped Statement
2016-03-31 17:02 858http://www.cnblogs.com/lcngu/p/ ... -
分布式事务管理
2016-03-31 16:43 1040http://my.oschina.net/pingpangk ... -
ibatis中动态查询表返回用resultClass="java.util.HashMap" 的问题
2016-03-11 10:49 1125http://blog.csdn.net/dyllove98/ ... -
Mybatis传多个参数(三种解决方案)
2016-03-07 17:46 1447http://my.oschina.net/ydsakyclg ... -
mybatis --mapper配置文件中大于小于怎么处理
2016-03-04 14:21 2408http://blog.csdn.net/nich002/ar ... -
Mybatis 数据库物理分页插件 PageHelper
2015-11-28 01:09 2792http://www.cnblogs.com/digdeep/ ... -
Druid 的SQL翻译功能如何使用
2015-11-27 21:40 1978Druid是阿里巴巴开源平台上的一个项目,整个项目由数据库连接 ... -
[MyBatis]mapperLocations属性通配符的使用
2015-11-26 10:49 6226http://blog.csdn.net/szwangdf/a ... -
Hibernate Validation使用示例及讲解
2015-11-22 21:06 2752http://wdmcygah.iteye.com/blog/ ... -
MyBatis排序时使用order by 动态参数时需要注意,用$而不是#
2015-11-17 17:54 20176http://blog.csdn.net/weibing_hu ... -
SpringMVC + Mybatis + Shiro 权限整合
2015-11-14 14:06 8747详细见参考文章: 基于Spring + Spring MVC ... -
MyBatis3 的Mapper XML 文件详解
2015-11-13 11:54 1358MyBatis3 的Mapper XML 文件http://m ... -
HibernateDao.java
2015-11-10 15:55 1164http://my.oschina.net/lizy/blog ... -
Hibernate envers开发指南
2015-10-24 00:44 1239http://www.blogjava.net/xmatthe ... -
Spring+Ibatis数据库水平分库
2015-09-13 21:15 1299Spring+Ibatis数据库水平分库 http://blo ... -
mybatis 功能 beetl 实现 beetlsql
2015-08-26 11:23 2087http://www.oschina.net/p/beetls ...
相关推荐
Mybatis拦截器(Interceptor)是一种插件机制,它允许我们在Mybatis执行SQL语句之前或之后进行自定义操作,比如统计SQL执行时间、添加日志等。拦截器基于Java的动态代理实现,可以拦截Mapper接口方法的调用。 接...
一种可能的做法是创建一个自定义的MyBatis插件或者拦截器,该插件能够解析XML中的“SQL”为Elasticsearch查询DSL。在XML配置文件中,我们可以定义一个类似于SQL查询的元素,比如`<es:query>`,并在其中写入Elastic...
2. **自定义插件**:通过创建一个 MyBatis 插件,我们可以拦截 SQL 语句,并在执行时动态修改 SQL,对敏感字段进行脱敏处理。这样,无论何时执行涉及敏感数据的 SQL,都可以自动应用脱敏规则。 二、实现步骤 1. **...
在原版MyBatis中,代理对象是通过动态代理机制生成的,用于拦截SQL执行过程中的方法调用,实现事务管理、缓存控制、参数映射等功能。在MyBatis修改版中,这一部分可能进行了如下优化: 1. **代理对象性能优化**:...
Mybatis是一个流行的Java持久层框架,它通过XML或注解的方式,将对象与数据库中的表进行映射,实现数据库操作的自动化。在Mybatis框架中,Mapper.xml文件是定义SQL映射的关键组件,它允许开发者编写SQL语句并执行...
MyBatis是一个流行的Java持久层框架,它简化了数据库操作,允许开发者将SQL查询与Java代码直接集成。在这个小例子中,我们将探索MyBatis的基本用法和核心概念。 首先,MyBatis的核心是XML配置文件,其中包含了...
Mybatis是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。Mybatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。在SpringBoot中整合Mybatis,可以使用Spring的注解来配置数据源、事务...
在MyBatis中,我们定义Mapper接口来操作数据库,然后创建对应的XML映射文件,将SQL语句写入其中。例如,有一个`UserMapper.java`接口: ```java public interface UserMapper { User selectUser(int id); } `...
本文将详细介绍如何将MyBatis与SpringMVC整合,以实现一个完整的增删改查(CRUD)应用,并涉及所需的库文件。 MyBatis是一个优秀的SQL映射框架,它允许开发者直接编写SQL语句,将数据库操作与业务逻辑解耦。而...
8. **插件机制**:Mybatis允许开发人员创建自定义插件,可以拦截SqlSession和Executor等接口的方法,实现如性能监控、日志记录等功能。 9. **Mybatis Plus**:作为Mybatis的扩展,Mybatis Plus提供了一些额外的功能...
这通常涉及到自定义拦截器或者插件,通过拦截Mybatis的SQL执行过程,实现对查询结果的缓存。 2. **配置**:了解如何在Mybatis的配置文件中设置Ehcache,包括设置缓存的策略(如时间过期、容量限制等),以及如何...
5. **插件扩展**: 通过拦截器实现对SQL执行的拦截,方便添加自定义功能。 **MyBatis 3.5.11的关键改进** 1. **错误修复**: 修复了若干已知问题,提高了框架的稳定性和兼容性。 2. **性能优化**: 对内部机制进行了...
前面一章,已经搭建好了eclipse,mybatis,mysql的环境,并且实现了一个简单的查询。请注意,这种方式是用SqlSession实例来直接执行已映射的SQL语句: session.selectOne(...
Mybatis允许自定义插件,可以拦截SqlSession中的方法,实现如日志、性能分析等功能。 7. **Mybatis的事务管理**: Mybatis支持手动和自动两种事务管理方式,可以通过SqlSessionFactory的getTransaction()方法进行...
下面我们将详细介绍如何使用SpringMVC4、MyBatis和SQL Server 2014实现读写分离。 首先,我们需要了解读写分离的原理。读写分离的主要思想是将数据库的读取和写入操作分离到不同的数据库服务器上,读取操作使用从库...
5. **创建Mapper接口和XML文件**:定义Mapper接口,包含SQL查询方法,同时编写对应的XML文件,写入具体的SQL语句。 6. **配置Mapper**:在Spring的配置文件中,为每个Mapper接口创建一个Bean,关联其XML文件。 7. ...
9. **Service和DAO**:创建Service层接口和实现类,以及DAO接口和实现类,通过MyBatis的SqlSession执行SQL。 10. **测试**:通过单元测试和集成测试确保所有组件正常工作。 这个案例适用于学习如何在实际项目中...
MyBatis是一个持久层框架,它简化了SQL操作,将SQL语句与Java代码分离,通过XML或注解配置,将接口方法与SQL语句绑定。在Spring中,MyBatis可以通过Spring的SqlSessionFactoryBean来配置,实现数据访问的事务管理和...
5. **plugins**:可以添加MyBatis插件,实现对SQL的拦截、日志等功能。例如,添加PageHelper分页插件: ```xml ``` 6. **objectFactory** 和 **typeHandler**:分别定义了对象工厂和类型处理器,用于...