当前位置: 首页 > wzjs >正文

成都手机网站开发百度小说风云榜排名

成都手机网站开发,百度小说风云榜排名,建设股公司网站,企业微信商城1. 什么是 MyBatis? MyBatis 是一款优秀的 持久层框架,它通过 XML 或注解配置,将 Java 对象(POJO)与数据库操作(SQL)进行灵活映射,简化了 JDBC 的复杂操作。 核心思想:S…
1. 什么是 MyBatis?

MyBatis 是一款优秀的 持久层框架,它通过 XML 或注解配置,将 Java 对象(POJO)与数据库操作(SQL)进行灵活映射,简化了 JDBC 的复杂操作。

  • 核心思想SQL 与代码分离,开发者可专注 SQL 优化,同时享受 ORM(对象关系映射)的便捷。

  • 定位:介于 JDBC 和全自动 ORM(如 Hibernate)之间的半自动化框架,灵活控制 SQL,适合复杂查询和高性能场景。


2. 核心特性
特性说明
动态 SQL支持条件分支(<if><choose>)、循环(<foreach>)等动态生成 SQL。
参数映射自动将 Java 对象属性映射到 SQL 参数(#{property})。
结果集映射将查询结果自动封装为 Java 对象(<resultMap>)。
缓存机制提供一级缓存(SqlSession 级别)和二级缓存(Mapper 级别)。
插件扩展支持自定义插件(如分页、日志),通过拦截器修改 MyBatis 核心行为。

3. 核心组件

    1.SqlSessionFactory

  • 作用:创建 SqlSession 的工厂类,全局唯一,通常由 SqlSessionFactoryBuilder 解析配置文件生成。

  • 配置来源:XML 文件(如 mybatis-config.xml)或 Java 代码。

    2.SqlSession

  • 作用:执行 SQL 操作、获取 Mapper 接口实例。非线程安全,需确保每次请求单独创建。

  • 关键方法

    <T> T getMapper(Class<T> type);  // 获取 Mapper 接口实例
    int insert(String statement, Object parameter);  // 直接执行 SQL

    3.Mapper 接口与 XML 映射文件

  • Mapper 接口:定义数据库操作方法,方法名与 XML 中的 SQL ID 对应。

  • XML 映射文件:编写 SQL 语句,配置参数/结果映射。

    4.Executor

  • 作用:SQL 执行器,处理缓存、事务、语句调度等核心逻辑。

  • 类型SimpleExecutor(默认)、ReuseExecutor(重用预处理语句)、BatchExecutor(批处理)。


4. 工作原理
  1. 配置加载

    • 解析 mybatis-config.xml,初始化数据源、事务管理器、Mapper 扫描路径等。

    • 加载 Mapper XML 文件或扫描 Mapper 接口,构建 SQL 映射关系。

  2. SqlSession 创建

    • 通过 SqlSessionFactory.openSession() 创建 SqlSession,内部包含 Executor 和事务控制。

  3. SQL 执行流程

    • Mapper 代理:通过动态代理(如 MapperProxy)将接口方法调用转发给 SqlSession。

    • SQL 解析:根据方法名找到对应的 SQL 语句,处理动态标签(如 <if>)。

    • 参数处理:将 Java 对象转换为 SQL 参数(ParameterHandler)。

    • SQL 执行:通过 Executor 执行 JDBC 操作,返回结果。

    • 结果映射:将 ResultSet 转换为 Java 对象(ResultSetHandler)。


5. 缓存机制
缓存级别作用范围生命周期开启方式
一级缓存SqlSession 级别随 SqlSession 关闭或清空默认开启
二级缓存Mapper 级别应用生命周期,可跨 SqlSession 共享XML 中配置 <cache/> 标签开启

6. 常见问题
  1. MyBatis 与 Hibernate 的区别?

    • MyBatis:半自动化,需手动写 SQL,灵活控制细节。

    • Hibernate:全自动化,通过 HQL 操作对象,适合快速开发。

  2. #{} 和 ${} 的区别?

    • #{}:预编译参数(防 SQL 注入),如 WHERE id = ?

    • **∗∗:字符串替换(慎用),如动态表名‘ORDERBY∗∗:字符串替换(慎用),如动态表名‘ORDERBY{column}`。

  3. 如何实现分页?

    • 物理分页:使用插件(如 PageHelper)或数据库方言(LIMIT)。

    • 内存分页:查询全部数据后在代码中分页(不推荐)。


7. 总结
  • 优势:灵活控制 SQL、动态 SQL 强大、性能优化空间大。

  • 适用场景:复杂查询、需深度优化 SQL、对数据库访问有精细控制需求的项目。

  • 学习路径:掌握 XML/注解配置 → 理解动态 SQL → 熟悉缓存机制 → 整合 Spring/Spring Boot。


http://www.dtcms.com/wzjs/403645.html

相关文章:

  • 南通网站制作哪个好百度投诉电话人工服务总部
  • 珠海网站seo机构
  • 以前做弹幕现在的电影网站十大免费网站推广平台
  • 云网站开发网址大全网站
  • 公司做一个静态网站多少钱新媒体运营主要做什么
  • window主机用wordpress北京seo设计公司
  • 单页网站规划设计书东莞网站建设优化排名
  • 福州高端网站制作黄页网络的推广软件
  • 奥美广告公司简介seo怎么优化关键词排名
  • 大型门户网站建设需要哪些技术永久不收费免费的聊天软件
  • 网站开发工具是啥怎么注册网站 个人
  • 一个做问卷调查的网站好seowhy培训
  • 用ps做网站方法百度广告服务商
  • 湖南网站制作收费标准seo的内容有哪些
  • 网站qq一键登录搜索引擎有哪些?
  • 找人做网站靠谱吗代刷网站推广链接免费
  • 一个空间做两个网站的视频教程google搜索
  • 湖寮做网站网络公司品牌推广
  • 简单的网站开发流程站长之家查询
  • 做采集网站赚钱吗北京网站seo优化推广
  • 学做网站论坛插件杭州网络排名优化
  • 自己做网站如何挣钱网页推广怎么做的
  • 网站建设纠纷 网站检测百度上海推广优化公司
  • 莞城仿做网站适合seo的建站系统
  • 视频网站的服务器建设网站优化排名公司
  • 网站推广排名抖音推广方式有哪些
  • 西安高端网站建设公司每日军事新闻
  • 公司网站域名更改怎么做可以营销的十大产品
  • 常德做网站公司哪家好淘宝新店怎么快速做起来
  • 杭州微网站建设百度校招