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;
        }
    }
}
相关推荐
fen_fen39 分钟前
用户信息表建表及批量插入 100 条数据(MySQL/Oracle)
数据库·mysql·oracle
马克Markorg7 小时前
常见的向量数据库和具有向量数据库能力的数据库
数据库
Coder_Boy_9 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
helloworldandy9 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
数据知道11 小时前
PostgreSQL 故障排查:如何找出数据库中最耗时的 SQL 语句
数据库·sql·postgresql
qq_124987075311 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
枷锁—sha11 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
Coder_Boy_11 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Gain_chance11 小时前
35-学习笔记尚硅谷数仓搭建-DWS层最近n日汇总表及历史至今汇总表建表语句
数据库·数据仓库·hive·笔记·学习
此生只爱蛋12 小时前
【Redis】主从复制
数据库·redis