mybatis学习笔记之基础框架(2)

简介: mybatis学习笔记之基础框架(2) mybatis是一个持久层的框架,是apache下的顶级项目。 mybatis让程序将主要精力放在sql上,通过mybatis提供的映射方式,自由灵活生成满足sql语句 mybatis可将向prparedStatement中的输入参数自动进行输入映射,将查询结果集灵活映射成java对象。(输出映射)

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代替。

  1. 动态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` 传入多个参数。
目录
相关文章
|
SQL Java 数据库连接
MyBatis 优秀的持久层框架(一)
MyBatis 优秀的持久层框架
64 0
|
1月前
|
SQL 关系型数据库 Java
Mybatis-Flex框架初体验
Mybatis-Flex框架初体验
|
2月前
|
SQL Java 数据库连接
|
11天前
|
SQL Java 数据库连接
什么是MyBatis持久层框架?
MyBatis 是一个优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs (Plain Old Java Objects, 普通的 Java 对象) 映射成数据库中的记录。
24 5
|
27天前
|
SQL XML Java
这样使用MyBatis框架,被攻击了
这样使用MyBatis框架,被攻击了
13 0
|
28天前
|
Java fastjson Apache
Spring Boot+Gradle+ MyBatisPlus3.x搭建企业级的后台分离框架
Spring Boot+Gradle+ MyBatisPlus3.x搭建企业级的后台分离框架
30 1
|
1月前
|
SQL Java 关系型数据库
MyBatisPlus学习笔记(SpringBoot版)
MyBatisPlus学习笔记(SpringBoot版)
99 0
|
1月前
|
XML Java 数据库连接
【MyBatis】 框架原理
【MyBatis】 框架原理
17 0
|
2月前
|
前端开发 Java 数据库连接
认识Java中最常用的框架:Spring、Spring MVC、Spring Boot、MyBatis和Netty
Spring框架 Spring是一个轻量级的开源框架,用于构建企业级应用。它提供了广泛的功能,包括依赖注入、面向切面编程、事务管理、消息传递等。Spring的核心思想是控制反转(IoC)和面向切面编程(AOP)。
77 3
|
2月前
|
SQL Java 关系型数据库
【MyBatis-Plus】快速精通Mybatis-plus框架—核心功能
【MyBatis-Plus】快速精通Mybatis-plus框架—核心功能
48 0
【MyBatis-Plus】快速精通Mybatis-plus框架—核心功能