一、类型别名typeAlias

1、在mapper文件中:实体作为resultType,多次书写在配置文件中,每次需要书写权限名(com.baizhi.yanxj.entity.User),代码比较繁琐。

2、类型别名配置

在mybatis-config.xml中配置:

    <typeAliases>
      <typeAlias type="com.baizhi.yanxj.entity.User" alias="别名"></typeAlias>
    </typeAliases>

注意:

1、对于DAO接口的方法,书写完一个方法就必须测试,只要有一个方法书写错误,可能导致整个测试都失败

2、sql必须测试,在mapper文件中,sql语句没有";"

二、配置文件参数

1、在mybatis-config.xml文件中,关于数据库连接相关的参数可能会经常改变,对mybatis-cofig维护降低,把连接数据库相关的参数,书写在一个小的配置文件中(jdbc.properties),在mybatis-cofig中动态获取

2、开发步骤

1)书写小的配置文件jdbc.properties

2)在mybatis-conf.xml中引入小的配置文件(jdbc.properties)

3)动态获得值 ${键名}

三、补充Mybatis批量删除

1、在JDBC中

sql="delete from t_user where id=?"

for(int i=0;i<ids.length;i++){

pstmt.setInt(1,ids[i];

pstmt.addBatch();

}

pstmt.executeBatch();

等效sql:delete from t_user where id in(1,2,3)

2、mybatis批删

<delete id="批删的方法">

delete from t_user where id in

<foreach collection="list|array" item="ids" open="(" separator="," close=")">

#{ids}

</foreach>

</delete>

四、Mybatis+Struts2整合

1、MVC

M:entity

DAO  :Mybatis

Service :Mybatis  事务{

//1、通过工具类获得SQLSession

SqlSession session = MybatisUtil.getSqlSession();

//2、获得DAO

PersonDAO dap = session.getMapper(PersonDAO.class);

//3、调用DAO方法完成业务

dao.xxx();

//4、事务提交或者回滚

session.commit();/session.rollback();

finally{

//通过工具类关闭session

MybatisUtil.closeSession();

}

}

C: Struts2

V:jsp   struts2标签+OGNL

2、Struts2+Mybatis整合

1)搭建环境

a、导入jar包:strut2相关jar+mybatis核心jar+ojdbc5.jar

b、引入配置文件:

struts.xml

mybatis-config.xml

mapper.xml

log4j.properties

c、初始化配置

web.xml中配置struts2的核心过滤器

mybatis-config.xml配置

3、补充source folder

配置文件经常放置在source folder,项目部署后,自动部署在WEB-INF/classes/的根目录下,等效与放在src目录下

五、参数的绑定(pstmt.setXXX(index,value)).

1、参数只有一个

1)八种基本类型+String+java.util.Date:参数不需要绑定

public User selectById(int id);

<select id="selectById" resultType="User">

select id,username,password from t_user where id=#{id}

</select>

2)参数为一个实体:参数绑定为实体的属性名称

2、多参数的绑定(分页int begin ,int end)

1)通过下标进行参数的绑定:可读性差,不建议使用

2)采用注解的方式进行参数的绑定【重点】

3)通过map集合绑定参数(古老)

分页:

DAO接口方法中:

mapper文件:

业务层:

Mybatis学习(贰)的更多相关文章

  1. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作(转载)

    本文转载自:http://www.cnblogs.com/jpf-java/p/6013540.html 上一篇博文MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybati ...

  2. MyBatis学习总结(八)——Mybatis3.x与Spring4.x整合(转载)

      孤傲苍狼 只为成功找方法,不为失败找借口! MyBatis学习总结(八)--Mybatis3.x与Spring4.x整合 一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: m ...

  3. MyBatis学习总结(七)——Mybatis缓存(转载)

      孤傲苍狼 只为成功找方法,不为失败找借口! MyBatis学习总结(七)--Mybatis缓存 一.MyBatis缓存介绍 正如大多数持久层框架一样,MyBatis 同样提供了一级缓存和二级缓存的 ...

  4. (原创)mybatis学习二,spring和mybatis的融合

    mybatis学习一夯实基础 上文介绍了mybatis的相关知识,这一节主要来介绍mybaits和spring的融合 一,环境搭建 1,jar包下载,下载路径为jar包 2,将包导入到java工程中 ...

  5. (原创)mybatis学习一,夯实基础

    一,what?(是什么) MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可 ...

  6. MyBatis学习--简单的增删改查

    jdbc程序 在学习MyBatis的时候先简单了解下JDBC编程的方式,我们以一个简单的查询为例,使用JDBC编程,如下: Public static void main(String[] args) ...

  7. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对u ...

  8. 【Todo】Mybatis学习-偏理论

    之前写过好几篇Mybatis相关的文章: http://www.cnblogs.com/charlesblc/p/5906431.html  <SSM(SpringMVC+Spring+Myba ...

  9. MyBatis学习系列三——结合Spring

    目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring MyBatis在项目中应用一般都要结合Spring,这一章主要把MyBat ...

  10. MyBatis学习系列二——增删改查

    目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring 数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改, ...

随机推荐

  1. if else 语句练习

    一.if  else 语句.

  2. 怎样实现UIView的旋转

    首先创建界面,在viewDidLoad创建view以及button 相关代码如下 -(void)viewDidLoad { [super viewDidLoad]; viewDemo = [[UIVi ...

  3. #define用法集锦

    Definition: The #define Directive You can use the #define directive to give a meaningful name to a c ...

  4. crontab执行shell脚本

    */5 * * * * cd /data/**/ && ./*.sh * * * * * /bin/sh /home/*.sh

  5. UE4高级功能--初探超大无缝地图的实现LevelStream

    转自:http://blog.csdn.net/u011707076/article/details/44903223 LevelStream 实现超大无缝地图--官方文档学习 The Level S ...

  6. Writing On-Error Trigger In Oracle Forms

    Suppose you want to handle an error in oracle forms and want to display custom error message for tha ...

  7. Plotting means and error bars (ggplot2)

    library(ggplot2) ############################################# # summarySE ######################### ...

  8. django-crontab定时任务

    django-crontab实现定时任务 1 django-crontab安装 django-crontab安装: django-crontab加入:只需要将INSTALLED_APPS即可.如下代码 ...

  9. Java中静态和非静态的区别

    在网上看到的,感觉还不错,自己笔记下来,以后忘了方便看: 非静态方法是相对于静态方法来说的.静态方法使用static关键字来标示,非静态方法没有此关键字. 他们之间最大的区别在于它们生命周期的不同,静 ...

  10. LSMW应用

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...