学习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语句:

主要的三个标签标签

3.1标签:


标签

    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 1=1 的条件拼装,我们可以采用标签来简化开发。


标签

3.3标签:

标签用于遍历集合

例如:传入多个 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集合查询用户们

于是:


标签的使用

属性:

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

open:代表语句的开始部分

close:代表结束部分

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

sperator:代表分隔符

其中     为引入重复抽取的sql语句,用到了标签,refid为标签的id值。

3.4  标签


标签

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

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

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

需求:

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

注意:

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

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

方式一:

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


Account类

IAccountDao接口定义的方法:

IAccountDao接口

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


IAccountDao.xml中的中定义映射关系

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集合变量。

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的多对多。


你可能感兴趣的:(学习mybatis的第三天)