Ibatis.Net 输出SQL语句学习(七)
一、IBatis.net输出SQL语句
输出IBatis.net生成的SQL语句,能够方便调试。
在MapperHelper类中添加GetSql方法:
/// <summary>
/// 返回执行的Sql语句
/// </summary>
/// <param name="statementName"></param>
/// <param name="paramObject"></param>
/// <returns></returns>
public static string GetSql(string statementName, object paramObject)
{
IMappedStatement statement = MapperHelper.Instance().GetMappedStatement(statementName);
RequestScope scope = statement.Statement.Sql.GetRequestScope(statement, paramObject, MapperHelper.Instance().CreateSqlMapSession());
return scope.PreparedStatement.PreparedSql;
}
在执行DAO方法之前添加:
public IList<PersonModel> SelectPersonById(Hashtable ht)
{
string sql = MapperHelper.GetSql("SelectPersonById", ht);
IList<PersonModel> pList = mapper.QueryForList<PersonModel>("SelectPersonById", ht);
return pList;
}
在执行之前,得到执行Sql,可以记录日志方便调试等操作。
参考:http://www.cnblogs.com/caoyc/category/873268.html
Ibatis.Net 输出SQL语句学习(七)的更多相关文章
- IBatis.net 输出SQL语句(七)
		
一.IBatis.net输出SQL语句到控制台 输出IBatis.net生成的SQL语句到控制台,能够方便调试. 如果要想输出IBatis.net的SQL语句到控制台,那么只需要做如下配置即可: &l ...
 - Ibatis.Net 动态SQL语句学习(六)
		
在学习动态SQL语句之前,首先必须对条件查询有一定了解,先来学习如何向IBatis.Net的映射文件里传入参数吧. 一.条件查询 1.传递单个参数 如根据Id查询: <select id=&qu ...
 - ibatis运行的SQL语句的输出——通过配置log4j
		
将ibatis 的log4j运行级别调到DEBUG可以在控制台打印出ibatis运行的sql语句 ### 设置Logger输出级别和输出目的地 ###log4j.rootLogger=debug,st ...
 - mybatis和ibatis控制台打印sql语句方法
		
#将ibatis log4j运行级别调到DEBUG可以在控制台打印出ibatis运行的sql语句 log4j.rootLogger=debug,stdout,logfile### 把日志信息输出到控制 ...
 - ibatis/mybatis显示sql语句 log4j.properties配置文件
		
将ibatis/mybatis log4j运行级别调到DEBUG可以在控制台打印出ibatis运行的sql语句,方便调试: ### 设置Logger输出级别和输出目的地 ### log4j.rootL ...
 - yii2输出sql语句
		
yii2如何输出具体的查询的sql语句: $query = User::find() ->where(['id'=>[1,2,3,4]) ->select(['username']) ...
 - SQL语句学习手册实例版
		
SQL语句学习手册实例版 表操作 例1 对于表的教学管理数据库中的表 STUDENTS ,可以定义如下: CREATE TABLE STUDENTS (SNO NUMERIC (6, ...
 - NHibernate输出SQL语句
		
用了NHierbate之后,很少需要写原生的SQL语句,由于总是看不到SQL语句,所以有时候对SQL调优非常不利.因此产生了让NHibernate输出它所生成的SQL语句的想法,以便于后续调优. 一. ...
 - Spring3+MyBatis3整合log4j无法输出SQL语句问题的解决
		
今天遇到了跟下面文章一模一样的问题,下面文章的解决方案很好,在这里记录保存一下. Spring3+MyBatis3整合无法输出SQL语句问题的解决
 
随机推荐
- PHP + webuploader 视频上传
			
上传方式,PHP默认方式 和 FTP 上传 1.修改PHP 配置: php.ini 修改以下配置项为适合的数据 php中 php.ini 文件修改 file_uploads = On //允许文件上 ...
 - [转帖]Kubernetes及容器编排的总体介绍【译】
			
Kubernetes及容器编排的总体介绍[译] 翻译自The New Stack<Kubernetes 生态环境>作者:JANAKIRAM MSV和 KRISHNAN SUBRAMANIA ...
 - Cuba项目从远程Git仓库下载步骤
			
Cuba Studio 从Git远程仓库里下载代码,并且可以使用IDEA打开,需要注意的地方: 1.使用Git Gui克隆代码 也可以使用IDEA本身集成的Git下载,但是要保证:下载了项目以后,不能 ...
 - bzoj1052
			
Description 某人在山上种了N棵小树苗.冬天来了,温度急速下降,小树苗脆弱得不堪一击,于是树主人想用一些塑料薄 膜把这些小树遮盖起来,经过一番长久的思考,他决定用3个L*L的正方形塑料薄膜将 ...
 - maven的三种工程pom、jar、war的区别
			
转: maven的三种工程pom.jar.war的区别 2018年09月03日 10:02:53 houjx3 阅读数:2918更多 个人分类: maven 1.pom工程:用在父级工程或聚合工程 ...
 - Gulp安装笔记(转)已经测试过
			
前言 总的来说,玩gulp的流程是这样的: 安装nodejs -> 全局安装gulp -> 项目安装gulp以及gulp插件 -> 配置gulpfile.js -> 运行任务 ...
 - sqlserver收缩日志的几种方式
			
sqlserver收缩日志的几种方式 [sql] --参考 压缩日志及数据库文件大小 /*--特别注意 请按步骤进行,未进行前面的步骤,请不要做后面的步骤 否则可 ...
 - 在angularJs实现批量删除
			
原理:在js中定义一个数组,然后给每个复选框一个点击事件,点击事件的方法参数有两个,一个是事件源$event,一个是id.点击复选框根据事件源判断是否被选中,然后进而是向这个数组增加或者删除id. $ ...
 - 960网格,一个web时代的标志。
			
如果你不知道什么是CSS框架,可以回顾我的文章 css框架,一把锋利的剑 闲言少叙,废话不说,直入正题: 1.什么是CSS框架? 正如之前说的: CSS框架是一种你能够使用在你的web项目中概念上的结 ...
 - [原]Android 初遇Http错误 httpClient.execute
			
错误源头: HttpResponse response = httpClient.execute(httpget); 错误信息: android.os.NetworkOnMainThreadExcep ...