学习mybatis的第三天

1、Mybatis的连接池技术

mybatis 的连接池的分类:

POOLED                       使用连接池技术  

UNPOOLED                  不使用连接池技术

JNDI                               使用JNDI实现数据源连接(不经常使用)

 设置这些连接池只需要在主配置文件SqlMapConfig.xml的dataSource标签设置type属性即可    如图一所示:

(图1)SqlMapConfog.xml 

1.1连接池技术原理:


连接池技术原理

1.2POOLED作用的过程:


mybatis_pooled的过程

2.Mybatis的事务控制:

    在mybatis中是通过SqlSession对象的commit方法和rollback方法实现事务的提交和回滚,若手动提交,只需要调用SqlSession对象的commit( )方法即可,若需要自动提交,则在生产SqlSession对象时,在openSession()中传递参数True即可完成自动提交功能,但是不建议自动提交。(底层为调用了JDBC中的setAutoCommit( )方法,默认为false,所以设置为true时即为自动提交

3.Mybatis中的动态SQL语句:

主要的三个标签<if>、<where>、<foreach>标签

3.1<if>标签:


<if>标签

    test的属性值为判断条件,test 属性中写的是对象的属性名,如果是包装类的对象要使用 OGNL 表达式的写法。

另外要注意 where 1=1 的作用(在查询条件数量不确定的条件情况下,使用 where 1=1可以很方便的规范语句,如果不写1=1,那么在每一个不为空的查询条件面前,都必须判断有没有where字句,哪里该加where,哪里该加and/or,用上 where 1=1 之后,就不存在这样的问题, 条件是 and 就直接and ,是or就直接接 or)

3.2<where>标签:

    为了简化上面 where 1=1 的条件拼装,我们可以采用<where>标签来简化开发。


<where>标签

3.3<foreach>标签:

<foreach>标签用于遍历集合

例如:传入多个 id 查询用户信息,用下边两个 sql 实现:

SELECT * FROM USERS WHERE username LIKE '%张%' AND (id =10 OR id =89 OR id=16)

SELECT * FROM USERS WHERE username LIKE '%张%' AND id IN (10,89,16)

这样我们在进行范围查询时,就要将一个集合中的值,作为参数动态添加进来。

这时可以先在 QueryVo 中加入一个 List 集合用于封装参数id,然后定义方法:


根据id集合查询用户们

于是:


<foreach>标签的使用

属性:

collection:代表要遍历的集合元素,注意编写时不要写#{}

open:代表语句的开始部分

close:代表结束部分

item:代表遍历集合的每个元素,生成的变量名

sperator:代表分隔符

其中   <include refid="defaultSql"></include>  为引入重复抽取的sql语句,用到了<sql>标签,refid为<sql>标签的id值。

3.4  <sql>标签


<sql>标签

<sql>标签抽取重复的sql语句,语句后面不用写分号。

4.mybatis中的多表查询操作:

4.1 一对一查询(多对一查询):

需求:

查询所有账户信息,关联查询下单用户信息。

注意:

因为一个账户信息只能供某个用户使用,所以从查询账户信息出发关联查询用户信息为一对一查询。如

果从用户信息出发查询用户下的账户信息则为一对多查询,因为一个用户可以有多个账户。

方式一:

在Account账户的实体类中,定义对象引用:


Account类

IAccountDao接口定义的方法:

IAccountDao接口

在IAccountDao的配置文件中定义对应关系:


IAccountDao.xml中的<resultMap>中定义映射关系

SQL语句:


SQL语句

方式二:

定义Account子类的方式实现查询:

如只需要查询账户信息的姓名和地址,那么只需要:

AccountUser类继承Account类进行封装账户信息

                                                                      接口中的方法:

返回AccountUser对象的集合

                                                                            SQL语句:

SQL语句,只查询账户的姓名和地址

4.2一对一查询(多对一查询):

需求:

查询所有用户信息及用户关联的账户信息。

分析:

用户信息和他的账户信息为一对多关系,并且查询过程中如果用户没有账户信息,此时也要将用户信息

查询出来,我们想到了左外连接查询比较合适

编写的SQL语句:

SELECT u.*,a.id aid,a.uid,a.money FROM user u LEFT JOIN account a ON a.uid = u.id;   

因为account表中的id与user表中的id重复,所以将account表的id取别名为aid

在Account账户的实体类中,定义引用:

因为为一对多的关系,一个人可能有多个账户,所以将定义一个List<Account>集合变量。

User类

IUser接口中的方法:


返回User对象的集合

在IUserDao的配置文件中定义对应关系:

IUserDao.xml中的resultMap配置对应关系

*注意:
collection

部分定义了用户关联的账户信息。表示关联查询结果集

property="accounts" :

关联查询的结果集存储在 User 对象的上哪个属性。

ofType="account" :

指定关联查询的结果集中的对象类型即List中的对象类型。此处可以使用别名,也可以使用全限定名。

SQL语句:

SQL查询所有用户信息并且其账户信息


5.Mybatis 多表查询之多对多:

5.1实现Role到User的多对多:

用户和角色的关系模型:

多对多关系模型
角色表
用户角色中间表,分别为两张表的外键

需求:

实现查询所有对象并且加载它所分配的用户信息。

分析:

查询角色我们需要用到Role表,但角色分配的用户的信息我们并不能直接找到用户信息,而是要通过中

间表(USER_ROLE 表)才能关联到用户信息。

编写的SQL语句:

SELECT u.*,role.id AS rid,role.`ROLE_DESC`,role.`ROLE_NAME` FROM user AS u LEFT OUTER JOIN user_role ON u.`id`=user_role.`UID` LEFT OUTER JOIN role ON role.`id` = user_role.`RID`;

在User的实体类中,定义多对多的映射:


User类

IUserDao接口中的方法:

IUserDao接口

在IUserDao的配置文件中定义对应关系:

映射关系

SQL语句:

SQL查询

5.1实现User到Role的多对多:

从 User 出发,我们也可以发现一个用户可以具有多个角色,这样用户到角色的关系也还是一对多关系。这样

我们就可以认为 User 与 Role 的多对多关系,可以被拆解成两个一对多关系来实现。其情况也是雷同与从Role到User的多对多。


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,588评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,456评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,146评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,387评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,481评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,510评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,522评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,296评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,745评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,039评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,202评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,901评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,538评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,165评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,415评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,081评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,085评论 2 352