mybatis 第一天 mybatis的基础知识
持久层的框架,对jdbc的封装
课程安排
第一天:基础知识(重点,内容量多)
最简单的jdbc程序
public class JdbcTest{ public static void main(String[] args){ //数据库连接 Connection connection = null; //预编译的Statement,使用预编译的statement提高数据库的性能 //通过preparedStatement向数据库发送一个sQL语句,数据库那边进行编译你写的SQL语句 //编译完后存在数据库端的缓存中,下次再发如果sql相同,它就不会编译了,提高性能 PreparedStatement preparedStatement = null; //结果集对象 ResultSet resultSet = null; try{ //加载数据库驱动 Class.forName("com.mysql.jdbc.Driver"); //通过驱动管理类获取数据连接 connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/mybatis?characterEncodeing=utr-8","root","mysql"); //定义sql语句?表示占位符 String sql = "select * from user where username = ?"; //获取预处理的statement preparedStatement = connection.preparedStatement(sql); //设置参数,第一个参数为sql语句中参数的序号(从1开始),第二个参数为设置的参数值 preparedStatement.setString(1,"王五");//1表示占位符的位置 //向数据库发出sql执行查询,查询出结果集 resultSet = preparedStatement.executeQuery(); //遍历查询结果集 while(resultSet.next){ System.out.println(resultSet.getString("id")+" "+resultSet.getString("username")); } }catch(Exception e){ e.printStackTrace(); }finally{ //释放资源 if(resultSet != null){ try{ resultSet.close(); }catch(SQLException e){ e.printStackTrace(); } } } if(preparedStatement != null){ try{ connection.close(); }catch(SQLException e){ e.printStackTrace(); } } if(Connection != null){ try{ connection.close(); }catch(SQLException e){ e.printStackTrace(); } } } }
对原生态jdbc程序(单独使用jdbc开发)问题总结
mybatis框架原理
mybatis入门程序
用户的增、删、改、查
mybatis开发dao两种方法:
原始dao开发方法(程序编写dao接口和dao实现类)(掌握)
mybatis和mapper接口(相当于dao接口)代理方法(掌握)
mybatis配置文件SqlMapCoinfig.xml
mybatis核心:
mybatis输入映射
mybatis输出映射
第二天:高级知识
高级结果集映射(一对一、一对多、多对多)
mybatis延迟加载
mybatis查询缓存(一级缓存、二级缓存)
mybatis和spring进行整合(掌握)
mybatis的逆向工程
1原生态的jdbc程序中问题总结
1.1、环境:
jdk环境:jdk 1.7
开发环境:Eclipse
数据库:mysql
1.2、创建mysql数据库
sql_table.sql 记录了表结构
sql_data.sql 记录了测试数据,在实际的企业开发中,最后提供一个初始化的数据脚本
1.3、jdbc程序
使用jdbc查询mysql数据库中用户表的记录。
1.4、问题总结
1、数据库连接,使用时就创建,不适用立即释放,对数据进行频繁的开启和关闭
造成资源浪费,影响了数据库的性能
解决方案:使用数据库连接池管理连接
2、将sql语句硬编码到Java代码中,如果sql语句修改,重新编译java代码,
不利于系统维护。
设想:将sql语句配置在xml配置文件中,即使sql变化,不需要对java
代码进行重新编译。
3、向preparedStatement中设置参数,对占位符和位置和设置参数值,
硬编码在java代码中,不利于系统维护。
设想:将sql语句及占位符和参数全部配置在xml中。
4、从resultSet中遍历结果集数据时存在硬编码,将获取表的字段进行硬编码,
不利于系统维护。
设想:将查询的结果自动的映射成java对象。
2 mybatis 框架
2.1 mybatis是什么?
mybatis是一个持久层框架,是Apache下的*项目
mybatis托管到googlecode下,再后来托管到github下
mybatis让程序员将主要精力放在sql上,通过mybatis提供的映射方式
,*灵活生成(半自动化,大部分需要程序员编写sql)满足需求的sql语句。
mybatis可以将向preparedStatement中输入参数自动进行输入映射,将查询结果集
灵活的映射成java对象。
2.2 mybatis框架
3 入门程序
3.1需求
根据用户id(主键) 查询用户信息
根据用户名称模糊用户信息
添加用户
修改用户
删除用户
环境:
jdk环境:jdk 1.7
开发环境:Eclipse
数据库:mysql
Mybatis的运行环境(jar包)
从Github下3.2.7版本
lib下:
mybatis-3.2.7.jar:核心包
log4j.jar:
cglib:动态代理(mapper代理)
mybatis.pdf操作指南
加入mysql数据库的驱动包
3.2 log4j.properties
3.3 工程目录结构
3.4 SqlMapConfig.xml
配置mybatis的运行环境、数据源、事务等。
3.5 根据用户id查询用户的信息
3.5.1 映射文件
映射文件命名:
User.xml(原始的ibatis的命名方式),mapper代理开发映射文件名称叫XXXMapper.xml,比如UserMapper.xml、ItemsMapper.xml
在映射文件中配置sql语句