mybatis框架的注意点
1.在mapper.xml文件中
resultType:返回结果类型,只能用于单表
paramsType:接收参数类型,基本数据类型可省略
2.给实体类起别名
在mybatisConfig.xml配置
<configuratoin>
<typeAliases>
1.<typeAlias type="类的完整路径",alias="别名"/>
2.<package name="扫描实体类所在的包"/>,别名为类名小写
</typeAliases>
<configuratoin>
3.获得新增数据的id
在Mapper.xml中的新增代码中加入
<insert userGenerateKeys="true" keyProperty="id的列名" .....
4.mybatis的in查询
- 参数类型为list集合
<select id="findall" resultType="bean.Emp">
select * from emp where empno in
<foreach collection="list" item="a" open="("
separator="," close=")" >
#{a}
</foreach>
</select>注意:parameterType 的值可以省略
- 参数为数组
<select id="findall" resultType="bean.Emp">
select * from emp where empno in
<foreach collection="array" index="b" item="a" open="("
separator="," close=")" >
#{a}
</foreach>
</select>
注意:parameterType 的值可以省略 - 参数为map
<select id="findall" resultType="bean.Emp">
select * from emp where empno in
<foreach collection="keya" index="b" item="a" open="("
separator="," close=")" >
#{a}
</foreach>
</select>
注意:parameterType 的值可以省略
传的值:
Map map=new HashMap();
map.put("keya", list1);
5.模糊查
<if test="ename!=null and ename!=''">
and ename like '%${属性名}%'
</if>
注意:test属性中读取属性值时直接写属性名
模糊查询读取属性时使el 表达式,${属性名}
除以上位置外,都使用#{属性名}
多个条件时使用and,or 拼接
6.resultMap
- 单表的resultMap
resultType="指定返回值的类型"//当列名和属性名一致时使用
resultMap="aaa" //1.当列名和属性名不一致 2.做多表查询时
mybatis 能实现的是单标的自动操作 <resultMap id="aaa" type="bean.Dept">
<!-- 可以手动指定列名和属性名的关系 ,非主键列使用result 标签,主键
列使用id 标签-->
<id property="dept_no" column="deptno"></id>
<result property="d_name" column="dname"/>
<result property="d_loc" column="loc"/>
</resultMap> - 两表关系(一对一)
<select id="方法名" resultMap="随便取">
sql语句
</select>
<resultMap="对应随便取" type="实体类">
<id column="主键名称" property="对应实体类主键”>
<result column="非主键名称" property="对应实体类非主键”>
存的是一方的话使用association 子标签
<association property="实体类中对应属性名" javaType="实体类名称">
<id column="主键名称" property="对应实体类主键”>
<result column="非主键名称" property="对应实体类非主键”>
</ association>
</resultMap> - 两表关系(多对多)
<select id="方法名" resultMap="随便取">
sql语句
</select>
<resultMap="对应随便取" type="实体类">
<id column="主键名称" property="对应实体类主键”>
<result column="非主键名称" property="对应实体类非主键”>
存的是集合的话使用Collection 子标签
<collection property="属性名" ofType="java 类型">
<id column="主键名称" property="对应实体类主键”>
<result column="非主键名称" property="对应实体类非主键”>
</ collection>
</resultMap> - 两表关系(一对多,多对一)
mybatis框架的注意点的更多相关文章
- Mybatis框架的多对一关联关系(六)
一.一对多的关联映射 一对多关联查询多表数据 1接口 public interface IDeptDAO { //根据部门编号查询该部门单个查询 public Emp getEmpById(Integ ...
- Spring+SpringMvc+Mybatis框架集成搭建教程
一.背景 最近有很多同学由于没有过SSM(Spring+SpringMvc+Mybatis , 以下简称SSM)框架的搭建的经历,所以在自己搭建SSM框架集成的时候,出现了这样或者那样的问题,很是苦恼 ...
- Mybatis框架中实现双向一对多关系映射
学习过Hibernate框架的伙伴们很容易就能简单的配置各种映射关系(Hibernate框架的映射关系在我的blogs中也有详细的讲解),但是在Mybatis框架中我们又如何去实现 一对多的关系映射呢 ...
- Hibernate框架与Mybatis框架的对比
学习了Hibernate和Mybatis,但是一直不太清楚他们两者的区别的联系,今天在网上翻了翻,就做了一下总结,希望对大家有帮助! 原文:http://blog.csdn.net/firejuly/ ...
- 初识Mybatis框架,实现增删改查等操作(动态拼接和动态修改)
此第一次接触Mybatis框架确实是有点不适应,特别是刚从Hibernate框架转转型过来,那么为什么要使用Mybatis框架,Mybatis框架和Hibernate框架又有什么异同呢? 这个问题在我 ...
- Spring+MyBatis框架中sql语句的书写,数据集的传递以及多表关联查询
在很多Java EE项目中,Spring+MyBatis框架经常被用到,项目搭建在这里不再赘述,现在要将的是如何在项目中书写,增删改查的语句,如何操作数据库,以及后台如何获取数据,如何进行关联查询,以 ...
- SSM框架-----------SpringMVC+Spring+Mybatis框架整合详细教程
1.基本概念 1.1.Spring Spring是一个开源框架,Spring是于2003 年兴起的一个轻量级的Java 开发框架,由Rod Johnson 在其著作Expert One-On-One ...
- Spring3.0 与 MyBatis框架 整合小实例
本文将在Eclipse开发环境下,采用Spring MVC + Spring + MyBatis + Maven + Log4J 框架搭建一个Java web 项目. 1. 环境准备: 1.1 创建数 ...
- 手把手Maven搭建SpringMVC+Spring+MyBatis框架(超级详细版)
手把手Maven搭建SpringMVC+Spring+MyBatis框架(超级详细版) SSM(Spring+SpringMVC+Mybatis),目前较为主流的企业级架构方案.标准的MVC设计模式, ...
- 详解Java的MyBatis框架中SQL语句映射部分的编写
这篇文章主要介绍了Java的MyBatis框架中SQL语句映射部分的编写,文中分为resultMap和增删查改实现两个部分来讲解,需要的朋友可以参考下 1.resultMap SQL 映射XML 文件 ...
随机推荐
- 跑步“无核心,不PB”
核心力量不管是在跑步中,还是在生活中都有着重要的作用,核心能让你的身体机能更加强劲. 1.什么是核心肌群? 核心肌群就是指我们所说的躯干,包括脊柱.骨盆.及周围肌群. 核心肌群由腹直肌.腹横肌.腹斜肌 ...
- 利用gitbush从git上下载代码到本地
1. 在本地新建一个存放代码的文件夹: 2.进入文件夹,右击Git bush here3 3. 出现以下面板: 4. 输入: git init 5.输入:git clone 文件地址链接 成功,在文件 ...
- @ControllerAdvice详解
@ControllerAdvice,是Spring3.2提供的新注解,从名字上可以看出大体意思是控制器增强.让我们先看看@ControllerAdvice的实现: package org.spri ...
- windows搭建zabbix agent
1.下载和解压zabbix agent 地址: http://www.zabbix.com/downloads/2.4.4/zabbix_agents_2.4.4.win.zip解压:conf目录存放 ...
- concurrentHashMap求size
在 JDK1.7 中,首先会使用不加锁的模式去尝试多次计算 ConcurrentHashMap 的 size,最多三次,比较前后计算的结果,结果一致就认为当前没有元素加入,计算的结果是准确的.如果不符 ...
- scrapy爬取58同城二手房问题与对策
测试环境: win10,单机爬取,scrapy1.5.0,python3.6.4,mongodb,Robo 3T 其他准备: 代理池:测试环境就没有用搭建的flask抓代理,因为我找到的几个免费网站有 ...
- paloalto防火墙的优势
1.所有 Palo Alto Networks 防火墙提供一个可用于执行防火墙管理功能的带外管理端口 (MGT).通过使用该 MGT 端口,可以将防火墙的管理功能与数据处理功能分开,从而保护对防火墙的 ...
- ES查询-match VS match_phrase
我们以一个查询的示例开始,我们在student这个type中存储了一些学生的基本信息,我们分别使用match和match_phrase进行查询. 首先,使用match进行检索,关键字是“He is”: ...
- 通过decorators = [,] 的形式给类中的所有方法添加装饰器
给类添加装饰器有多种方法: 1.可以在类中的某个方法上边直接@添加,这个粒度细.无需详细介绍 2.也可以在类中通过 decorators=[, ]的形式添加,这样的话,类中的所有方法都会被一次性加上装 ...
- tmux使用(程序员适用)
原文:http://jack-boy.iteye.com/blog/1586908 tmux基本使用 tmux是一个优秀的终端复用软件,即使非正常掉线,也能保证当前的任务运行,这一点对于远程S ...