MyBatis入门

MyBatis是一款优秀的持久层框架,用于简化JDBC开发

持久层:

负责将数据保存到数据库的那一层代码

我们会将操作数据库的Java代码作为持久层,而MyBatis就是对jdbc代码进行了封装。

JavaEE三层架构:表现层、业务层、持久层

框架:

是一个半成品软件。

MyBatis通过xml或注解的方式将要执行的各种statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的sql语句,最后由MyBatis框架执行sql并将结果映射为java对象并返回。

采用**"ORM"思想**解决了实体和数据库映射的问题,对JDBC进行了封装,屏蔽了JDBC、API底层访问细节,使我们不用与JDBC、API打交道就可以完成对数据库的持久化操作。

ORM:

Object Relational Mapping:对象关系映射

指的是持久化数据和实体对象的映射模式,为了解决面向对象与关系型数据库存在的互不匹配的现象的技术。

表------>类

记录(record,行数据)------>对象

字段------>对象属性

JDBC缺点:

1.硬编码、系统不易维护:

注册驱动,获取连接,如果要将Mysql数据库换成其他关系型数据库的话,四个地方都要修改

2.操作繁琐:

要手动设置参数、封装结果集;图标4的代码就是对查询到的数据进行封装,这部分代码无技术含量且耗费时间。

MyBatis优化:

硬编码可以配置到配置文件

操作繁琐的地方MyBatis都自动完成

java 复制代码
public class UserInfoDaoImpl implements UserInfoDao {
    @Override
    public List<UserInfo> selectAll(){
        try {
            InputStream in=Resources.getResourceAsStream("mybatis-config.xml");
            SqlSessionFactoryBuilder builder=new SqlSessionFactoryBuilder();
            SqlSessionFactory sqlSessionFactory=builder.build(in);
            SqlSession sqlSession = sqlSessionFactory.openSession();
            //有实现类对象的情况:
            List<UserInfo> userInfos = sqlSession.selectList("org.example.dao.UserInfoDao.selectAll");
            return userInfos;
            //没有实现类对象的情况:
            /**UserInfoDao mapper = sqlSession.getMapper(UserInfoDao.class);
            List<UserInfo> userInfos1 = mapper.selectAll();
            userInfos1.forEach(o-> System.out.println(o));*/
        } catch (IOException e) {
            e.printStackTrace();
            return null;
        }
    }
}
相关推荐
学地理的小胖砸1 小时前
【Python 操作 MySQL 数据库】
数据库·python·mysql
dddaidai1231 小时前
Redis解析
数据库·redis·缓存
数据库幼崽1 小时前
MySQL 8.0 OCP 1Z0-908 121-130题
数据库·mysql·ocp
Amctwd2 小时前
【SQL】如何在 SQL 中统计结构化字符串的特征频率
数据库·sql
betazhou2 小时前
基于Linux环境实现Oracle goldengate远程抽取MySQL同步数据到MySQL
linux·数据库·mysql·oracle·ogg
lyrhhhhhhhh3 小时前
Spring 框架 JDBC 模板技术详解
java·数据库·spring
喝醉的小喵4 小时前
【mysql】并发 Insert 的死锁问题 第二弹
数据库·后端·mysql·死锁
付出不多5 小时前
Linux——mysql主从复制与读写分离
数据库·mysql
初次见面我叫泰隆5 小时前
MySQL——1、数据库基础
数据库·adb
Chasing__Dreams5 小时前
Redis--基础知识点--26--过期删除策略 与 淘汰策略
数据库·redis·缓存