原理分析之二:框架整体设计

1.引言

本文主要讲解Mybatis的整体程序设计,理清楚框架的主要脉络。后面文章我们再详细讲解各个组件。

 

2.整体设计

2.1 总体流程

(1)加载配置并初始化

      触发条件:加载配置文件

      配置来源于两个地方,一处是配置文件,一处是Java代码的注解,将SQL的配置信息加载成为一个个MappedStatement对象(包括了传入参数映射配置、执行的SQL语句、结果映射配置),存储在内存中。

      

(2)接收调用请求

      触发条件:调用Mybatis提供的API

      传入参数:为SQL的ID和传入参数对象

      处理过程:将请求传递给下层的请求处理层进行处理。

          

(3)处理操作请求

       触发条件:API接口层传递请求过来

       传入参数:为SQL的ID和传入参数对象

       处理过程:

        (A)根据SQL的ID查找对应的MappedStatement对象。

        (B)根据传入参数对象解析MappedStatement对象,得到最终要执行的SQL和执行传入参数。

        (C)获取数据库连接,根据得到的最终SQL语句和执行传入参数到数据库执行,并得到执行结果。

        (D)根据MappedStatement对象中的结果映射配置对得到的执行结果进行转换处理,并得到最终的处理结果。

        (E)释放连接资源。

       

(4)返回处理结果

将最终的处理结果返回。

 

2.2 功能架构设计

功能架构讲解:

我们把Mybatis的功能架构分为三层:

(1)API接口层:提供给外部使用的接口API,开发人员通过这些本地API来操纵数据库。接口层一接收到调用请求就会调用数据处理层来完成具体的数据处理。

(2)数据处理层:负责具体的SQL查找、SQL解析、SQL执行和执行结果映射处理等。它主要的目的是根据调用的请求完成一次数据库操作。

(3)基础支撑层:负责最基础的功能支撑,包括连接管理、事务管理、配置加载和缓存处理,这些都是共用的东西,将他们抽取出来作为最基础的组件。为上层的数据处理层提供最基础的支撑。

 

2.3 框架架构设计


 

框架架构讲解:

(1)加载配置:配置来源于两个地方,一处是配置文件,一处是Java代码的注解,将SQL的配置信息加载成为一个个MappedStatement对象(包括了传入参数映射配置、执行的SQL语句、结果映射配置),存储在内存中。

(2)SQL解析:当API接口层接收到调用请求时,会接收到传入SQL的ID和传入对象(可以是Map、JavaBean或者基本数据类型),Mybatis会根据SQL的ID找到对应的MappedStatement,然后根据传入参数对象对MappedStatement进行解析,解析后可以得到最终要执行的SQL语句和参数。

(3) SQL执行:将最终得到的SQL和参数拿到数据库进行执行,得到操作数据库的结果。

(4)结果映射:将操作数据库的结果按照映射的配置进行转换,可以转换成HashMap、JavaBean或者基本数据类型,并将最终结果返回

转载地址:http://chenjc-it.iteye.com/blog/1460990

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
"送你一朵小红花"系统是一个低代码构建的应用程序,旨在帮助部门员工之间通过送花来表达赞赏和鼓励。该系统可以根据每个员工收到的小红花数量来评估其绩效,并为绩效考核提供参考。 以下是该系统的原理分析和技术要点: 1. 用户身份管理:系统需要支持用户注册和登录功能,以确保只有授权的员工才能使用系统。可以使用现有的身份验证解决方案,如LDAP或单点登录。 2. 花朵赠送:系统应提供一个简单易用的界面,让员工能够选择要赠送的花朵类型,并选择目标员工。可以通过拖放或选择列表等方式实现。此外,还可以为花朵添加一些个性化的文字或表达方式。 3. 小红花计数:每当员工收到一朵花,系统应自动更新他们的小红花数量。这可以通过在数据库中为每个员工维护一个计数器来实现。当员工收到花朵时,计数器会自动增加。 4. 绩效考核:系统应提供一个绩效考核模块,用于根据每个员工收到的小红花数量进行评估。可以设置不同的绩效等级,例如:青铜、白银、黄金等,根据小红花数量来决定员工所属的等级。 5. 数据分析和报表:系统应提供数据分析和报表功能,以便管理层可以查看整个部门或公司的小红花赠送情况。这些报表可以显示每个员工的小红花数量、绩效等级以及整体赠送趋势等信息。 技术要点: - 前端开发:使用低代码开发平台或前端框架(如React、Vue.js)来构建用户界面,实现花朵赠送和数据展示功能。 - 后端开发:选择适合的后端技术栈(如Node.js、Python)来处理用户身份验证、数据库操作和绩效计算等功能。 - 数据库管理:使用关系型数据库(如MySQL、PostgreSQL)来存储员工信息、小红花数量和绩效等级。 - 安全性考虑:确保系统具有适当的安全机制,如访问控制、数据加密和防止恶意行为的防护措施。 通过以上原理分析和技术要点,可以设计一个低代码构建的“送你一朵小红花”系统,以帮助部门员工之间进行赞赏和鼓励,并提供绩效考核的参考。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值