mybatis随意sql语句

mybatis的mapper.xml随意sql语句, 不管表之间存不存在关系, 都可以使用, 但注意resultMap中一定要指定查询数据返回的列 或 对象(其实就是多列封装到一个对象中)

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="SmTaskMapper" >
  <resultMap id="BaseResultMap" type="com.ldrc.srm.jczx.dal.dataobject.construction.projectinfo.SmTask" >
    <id column="STASK_ID" property="staskId" jdbcType="INTEGER" />
    <result column="SBI_ID" property="sbiId" jdbcType="INTEGER" />
    <result column="STASK_NUMBER" property="staskNumber" jdbcType="VARCHAR" />
    <result column="STASK_NAME" property="staskName" jdbcType="VARCHAR" />
    <result column="STASK_SHORT_NAME" property="staskShortName" jdbcType="VARCHAR" />
    <result column="STASK_ORDERBY" property="staskOrderby" jdbcType="INTEGER" />
    <result column="STASK_TYPE" property="staskType" jdbcType="INTEGER" />
    <result column="STASK_CHANGE_DATE" property="staskChangeDate" jdbcType="DATE" />
    <result column="STASK_ISCHANGE_STATE" property="staskIschangeState" jdbcType="INTEGER" />
    <result column="PCCI_ID" property="pcciId" jdbcType="INTEGER" />
    <result column="STASK_PARENT_ID" property="staskParentId" jdbcType="INTEGER" />
    <result column="IS_INVALID" property="isInvalid" jdbcType="INTEGER" />
    <result column="spart_name" property="spartName" jdbcType="VARCHAR"/>  <!-- 这个就是我指定的研究人员的列 -->
    <association property="smTaskPlan" resultMap="SmTaskPlanMapper.BaseResultMap"/> <!-- association中没有select就不需要column, column给select的方法传参 , 我这里的方式随意查, 表随意些就像正常的sql语句一样, 可以吧association看做封装多列数据-->
    <association property="smTaskStatus" resultMap="SmTaskStatusMapper.BaseResultMap"/>
  </resultMap>
  <sql id="Base_Column_List" >
    STASK_ID, SBI_ID, STASK_NUMBER, STASK_NAME, STASK_SHORT_NAME, STASK_ORDERBY, STASK_TYPE,
    STASK_CHANGE_DATE, STASK_ISCHANGE_STATE, PCCI_ID, STASK_PARENT_ID, IS_INVALID
  </sql>

  <select id="aa" resultMap="BaseResultMap" parameterType="com.ldrc.srm.jczx.dal.dataobject.construction.projectinfo.SmTask">
  select
          t1.*, t2.*, t3.spart_name
  from sm_s_task t1
    left join sm_s_task_plan t2
        on t1.STASK_ID = t2.STASK_ID
    left join SM_S_PARTICIPA t3
        on t3.SPART_ID = t2.SPART_ID
where t1.sbi_id = #{sbiId} AND t1.STASK_ISCHANGE_STATE = #{staskIschangeState}
  </select>

</mapper>

     @Test	public void aa(){		SmTask st = new SmTask();		st.setSbiId(1);st.setStaskIschangeState(2);		List<SmTask> list = this.sqlSession.selectList("SmTaskMapper.aa", st);		System.out.println(list);		System.out.println(list.size()+" 数量");		for (SmTask smTask : list) {			System.out.println(smTask.getSpartName()+ " "+smTask.getSmTaskPlan().getSstpEndDate());		}	}控制台输出00:39:16.571 [main] DEBUG SmTaskMapper.aa - ooo Using Connection [conn2: url=jdbc:h2:~/srmcydw_v01 user=SA]00:39:16.571 [main] DEBUG SmTaskMapper.aa - ==>  Preparing: select t1.*, t2.*, t3.spart_name from sm_s_task t1 left join sm_s_task_plan t2 on t1.STASK_ID = t2.STASK_ID left join SM_S_PARTICIPA t3 on t3.SPART_ID = t2.SPART_ID where t1.sbi_id = ? AND t1.STASK_ISCHANGE_STATE = ? 00:39:16.618 [main] DEBUG SmTaskMapper.aa - ==> Parameters: 1(Integer), 2(Integer)[SmTask [spartName=明明, staskId=1, sbiId=1, staskNumber=2014BH001, staskName=参与单位课题一的任务一, staskShortName=任务一, staskOrderby=1, staskType=1, staskChangeDate=Sat Oct 25 00:00:00 CST 2014, staskChangeDate1=null, staskIschangeState=2, pcciId=1, staskParentId=1, isInvalid=2, smTaskStatus=com.ld[email protected]5de5bb3c, smBaseInfo=com[email protected]1567904d, smTaskPlan=co[email protected]4232ba35], SmTask [spartName=丽丽, staskId=2, sbiId=1, staskNumber=2014BH020, staskName=参与单位课题一的自定义任务一, staskShortName=任务二, staskOrderby=2, staskType=2, staskChangeDate=Sat Oct 25 00:00:00 CST 2014, staskChangeDate1=null, staskIschangeState=2, pcciId=1, staskParentId=1, isInvalid=2, smTaskStatus=com.ld[email protected]105f0f87, smBaseInfo=com[email protected]50f47076, smTaskPlan=co[email protected]60037c7f], SmTask [spartName=null, staskId=3, sbiId=1, staskNumber=2014BH021, staskName=参与单位课题一的自定义任务二, staskShortName=任务三, staskOrderby=3, staskType=2, staskChangeDate=Sat Oct 25 00:00:00 CST 2014, staskChangeDate1=null, staskIschangeState=2, pcciId=1, staskParentId=1, isInvalid=1, smTaskStatus=com.ld[email protected]4e2a718, smBaseInfo=com[email protected]3c481b29, smTaskPlan=co[email protected]21ef3faa]]3 数量明明 Mon Oct 27 00:00:00 CST 2014丽丽 Tue Oct 21 00:00:00 CST 2014null null

<select id="aa" resultMap="BaseResultMap" parameterType="com.ldrc.srm.jczx.dal.dataobject.construction.projectinfo.SmTask">
  select
          t1.*, t2.*, t3.spart_name
  from sm_s_task t1
    left join sm_s_task_plan t2
        on t1.STASK_ID = t2.STASK_ID
    left join SM_S_PARTICIPA t3
        on t3.SPART_ID = t2.SPART_ID
where t1.sbi_id = #{sbiId} AND t1.STASK_ISCHANGE_STATE = #{staskIschangeState}
  </select>

时间: 2024-10-03 20:17:11

mybatis随意sql语句的相关文章

mybatis实战教程(mybatis in action)之八:mybatis 动态sql语句

mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类:1. if 语句 (简单的条件判断)2. choose (when,otherwize) ,相当于java 语言中的 switch ,与 jstl 中的choose 很类似.3. trim (对包含的内容加上 prefix,或者 suffix 等,前缀,后缀)4. where (主要是用来简化sql语句中where条件判断的,能智能的处理 a

mybatis 动态sql语句

mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类: 1. if 语句 (简单的条件判断) 2. choose (when,otherwize) ,相当于java 语言中的 switch ,与 jstl 中的choose 很类似. 3. trim (对包含的内容加上 prefix,或者 suffix 等,前缀,后缀) 4. where (主要是用来简化sql语句中where条件判断的,能智能的

log4j打印MyBatis的sql语句配置

log4j.rootLogger=DEBUG,stdout log4j.appender.stdout=org.apache.log4j.ConsoleAppender log4j.appender.stdout.layout=org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) -%m%n log4j.logger.com.ibatis=debug log4j

mybatis显示sql语句 log4j.properties配置文件

log4j.properties配置如下: 1 将ibatis log4j运行级别调到DEBUG可以在控制台打印出ibatis运行的sql语句,方便调试: 2 3 ### 设置Logger输出级别和输出目的地 ### 4 log4j.rootLogger=debug,stdout,logfile 5 6 7 ### 把日志信息输出到控制台 ### 8 log4j.appender.stdout=org.apache.log4j.ConsoleAppender 9 #log4j.appender.

基于SpringJDBC的类mybatis形式SQL语句管理的思考与实现

SpringJDBC为我们提供了一个非常方便的数据库访问接口,我们都知道使用JdbcTemplate对数据库进行操作时需要传入执行的SQL语句.在小型系统中,SQL语句可能并不会太多,这个时候我们无论采取什么方式进行管理都没有关系.但是当系统逐渐庞大后,我们就要考虑以一种恰当的方式对这些SQL进行管理了.我们将首先介绍比较常见的几种SQL管理方式,然后再讨论类mybatis形式的SQL管理方式. 在方法中直接构造并传入 这种方式是在需要执行数据库操作的方法内直接硬编码SQL语句.这样做的好处在于

通过Log4j的DEBUG级别来显示mybatis的sql语句

    为了更加方便调试sql语句,需要显示mybatis的sql语句.     网络上的一般方式都是通过log4j来实现,但是很多都有问题.      经过实验,以下代码能够保持正常:(只显示mybatis的sql语句的debug语句,其他的debug不显示)     log4j.rootLogger = DEBUG,CONSOLE,LogFile,ErrorFile #注意这里需要改成DEBUG # 应用于控制台 log4j.appender.CONSOLE = org.apache.log

ssm环境下配置log4j打印mybatis的sql语句

首先附上官网的说明文档: mybatis Logging环境spring4.3.0+springmvc4.3.0+mybatis3.4.0 按官方文档的说明 1 SLF4J 2 Apache Commons Logging 3 Log4j 2 4 Log4j 5 JDK logging mybatis会使用最先找到的(按上文列举的顺序查找),不少应用服务器的classpath中已经包含Commons Logging,如Tomcat和WebShpere, 所以MyBatis会把它作为具体的日志实现

Mybatis动态sql语句(OGNL语法)

下面是Mybatis动态sql语句(即OGNL语法)的简单案例 1.创建表 create table test(id int primary key auto_increment,name varchar(20),job varchar(20),dept varchar(20),sal int) charset=utf8; insert into test values (null,'鲁班','java','甲',1456), (null,'后裔','java','甲',2440), (null

Java实战之路(1):SpringBoot项目中使用Mybatis打印Sql语句

SpringBoot项目中使用Mybatis打印Sql语句 如题,实际项目中使用很多都会用到SpringBoot+Mybatis的经典搭配进行开发,数据库里明明有数据,可是程序运行就是查不到,此时我们在本地Debug时,需要将Mybatis的实际Sql打印出来,看看Sql与我们期望的是否一致,或者将Sql拿到数据库中直接执行,看看结果.这里简单介绍几种实战中的用法. 方法一 properties:在application.properties配置文件中增加如下配置 logging.level.c