mybatis学习笔记之基础框架(2)
mybatis学习笔记之基础框架(2) mybatis是一个持久层的框架,是apache下的顶级项目。 mybatis让程序将主要精力放在sql上,通过mybatis提供的映射方式,自由灵活生成满足sql语句 mybatis可将向prparedStatement中的输入参数自动进行输入映射,将查询结果集灵活映射成java对象。(输出映射) SqlMapConfig.xml(是mybatis的全局配置文件,名称不固定) 配置了数据源/事务等mybatis运行环境 配置映射文件(配置sql语句) mapper.xml(映射文件)/mapper.xml/mapper.xml SqlSessionFactory(会话工厂) 作用:创建SqlSesion SqlSession(会话,是一个接口,面向用户程序员的接口) 作用:操作数据库(发出sql增删改查) Executor(执行器,是一个接口(基本执行器/缓存执行器)) 作用:SqlSes内部通过执行器操作数据库
mapped statement (底层封装对象)
作用:对操作数据库存储封装,包括sql语句。输入参数/输出结果类型
输入参数类型 java简单类型 hashmap pojo自定义
输出参数类型 java简单类型 hashmap pojo自定义
3.入门程序:
需求:根据用户id(key)查询用户信息 根据用户名称模糊查询用户信息 添加用户 删除用户 更新用户
mybatis运行环境(jar包) lib下的依赖包:核心包 mybatis-3.3.0.jar:操作指南 加入mysql的驱动包 3.0创建po类
3.1映射文件 映射文件命名: User.xml(原始ibatis命名),mapper代理开发映射文件名称叫xxxMapper.xml,比如:UserMapper.xml/ItemsMapper.xml 在映射文件中配置sql语句。
3.2在sqlMapConfig.xml映射文件 在sqlMapConfig.xml中加载user.xml
3.3添加用户
4.0程序的编写小结
3.3.1parameterType 在映射文件中通过parameterType指定输入参数类型。
3.3.2resultType 在映射文件中通过resultType指定输出结果的类型。
3.3.3 #{}和${} #{}表示一个占位符。${}表示一个拼接符号,但会引起sql注入,不建议使用。
3.3.4SelectOne和selectList
selectOne表示查询一条记录进行映射。如果使用selectOne可以实现那么也可以使用selectList实现。
selectList 表示查询出一个列表(多条记录)进行映射。如果使用selectList查询多条记录不可用selectOne代替。
- 动态sql mybatis核心对sql语句进行灵活操作,同伙表达式进行判断,对sql进行灵活拼接、组装。 5.1用户信息中和查询列表和用户信息查询列表总数这两个stat的定义使用动态sql。 对查询条件进行判断,如果输入条件不为空,才进行拼接。
<!-- where-->
<where>
<if test ="username"
5.2sql片段
5.3foreach
向sql传递数组或List,mybatis使用foreach解析。
5.3.1需求
SELECT * FROM USER WHERE id=1 OR id=2 OR id=3
或者
SELECT * FROM USER WHERE id IN(1,2,3)
5.3.2实现
在输入参数类型中添加`List<Integer>ids` 传入多个参数。
- [C#6] 0-概览
- 移植Windows自宿主WCF服务到Linux/Mono2.8
- IISWeb应用防火墙WAF
- WordPress 开发之让浏览器自动加载最新的CSS、JS文件(免刷新缓存)
- 在Windows 7无法通过UNC路径连接到共享文件夹的解决方法
- SQL Sever索引
- 使用SQL Server Management Studio 2008 将数据库里的数据导成脚本
- jquery mobile 移动web(5)
- [C#6] 1-using static
- WordPress 中的 Debug 模式(调试模式)
- Windows Server 2008 R2 Server Core 的 Microsoft .NET Framework 4安装程序
- [C#6] 4-string 插值
- 使用API Key验证WCF Data Service
- WordPress By Example:一个WordPress 主题搜索引擎
- java教程
- Java快速入门
- Java 开发环境配置
- Java基本语法
- Java 对象和类
- Java 基本数据类型
- Java 变量类型
- Java 修饰符
- Java 运算符
- Java 循环结构
- Java 分支结构
- Java Number类
- Java Character类
- Java String类
- Java StringBuffer和StringBuilder类
- Java 数组
- Java 日期时间
- Java 正则表达式
- Java 方法
- Java 流(Stream)、文件(File)和IO
- Java 异常处理
- Java 继承
- Java 重写(Override)与重载(Overload)
- Java 多态
- Java 抽象类
- Java 封装
- Java 接口
- Java 包(package)
- Java 数据结构
- Java 集合框架
- Java 泛型
- Java 序列化
- Java 网络编程
- Java 发送邮件
- Java 多线程编程
- Java Applet基础
- Java 文档注释