一、类型别名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. MVC 中使用EF

    EF 1)简单查询 后台代码 using MvcApplication18.Models; using System; using System.Collections.Generic; using ...

  2. C#与C++(结构体内对象指定大小)

    C++结构体:struct DATAAREA { // 报警协议数据区结构 char szAlarmNo[20]; // 报警编号(必填) char szUserNo[10]; // 用户编号(必填) ...

  3. Android 获取存储空间

    package com.example.getMem; import java.io.File; import android.os.Build;import android.os.Bundle;im ...

  4. Android Volley 框架的使用(一)

    为什么要使用Volley框架 开发android应用很多时候都要涉及网络操作,Android SDK中提供了HttpClient 和 HttpUrlConnection两种方式用来处理网络操作,但当应 ...

  5. UVA 11404 五 Palindromic Subsequence

     Palindromic Subsequence Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu ...

  6. 字符串表达式String Expressions

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

  7. CUBRID学习笔记 18 sql语句的预处理(类似存储过程)

    定义预处理  类似sqlserver的存储过程 语法 PREPARE stmt_name FROM preparable_stmt 说明 PREPARE 关键字 stmt_name 预处理语句的名字 ...

  8. linux 命令行模式下,浏览网页

    Ubuntu自带最新版的Gnome桌面,拥有大量的服务和桌面应用程序,让您仅通过一张安装光盘就可以体验到无比舒适的操作环境.下文介绍的在ubuntu下使用终端命令行上网的方法. 第一步,需要安装一个名 ...

  9. FLASH CC 2015 CANVAS (四)制作响应式设计(自适应)的项目

    注意 此贴 为个人边“开荒”边写,所以不保证就是最佳做法,也难免有错误(如果发现我会更新文章)! 正式教程会在后续开始更新 相信你在看了(第二节)(第三节)之后已经能够满足绝大多数的互动需求了.那么也 ...

  10. elcipse 安装svn插件 转载

    1.下载最新的Eclipse,我的版本是3.7.2 indigo(Eclipse IDE for Java EE Developers)版    如果没有安装的请到这里下载安装:http://ecli ...