当前位置:首页>java>Spring 事务详解:声明式事务与编程式事务的对比

Spring 事务详解:声明式事务与编程式事务的对比

  • 2026-01-30 07:06:46
Spring 事务详解:声明式事务与编程式事务的对比

在Java企业级开发中,事务管理是保障数据一致性的核心机制,Spring框架为开发者提供了两种主流的事务管理方式——声明式事务与编程式事务。二者基于Spring的事务抽象层实现,却在使用方式、灵活性、侵入性等方面存在显著差异,适配不同的业务场景。本文将从概念、实现、优劣、适用场景等维度,深入对比二者特性,为Java开发中的事务选型提供参考。

一、核心概念与底层支撑

Spring事务的底层依赖PlatformTransactionManager接口,该接口定义了事务的提交、回滚等核心操作,不同的数据源(如JDBC、Hibernate、MyBatis)对应不同的实现类(如DataSourceTransactionManagerHibernateTransactionManager)。声明式事务与编程式事务的本质区别,在于事务边界的定义方式与控制粒度,而非底层事务执行机制。

二、声明式事务:基于注解的无侵入式管理

1. 实现方式

声明式事务是Spring最常用的事务管理方式,核心依赖@Transactional注解(或XML配置,注解方式更主流),通过AOP(面向切面编程)机制实现事务的自动织入。开发者无需手动编写事务的开启、提交、回滚代码,仅需在目标方法或类上添加注解,Spring会通过动态代理机制,在方法执行前后自动完成事务的创建与管理。

基础使用示例:

@Servicepublic classUserServiceImplimplementsUserService{@Autowiredprivate UserMapper userMapper;// 声明式事务:通过注解定义事务属性@Transactional(rollbackFor = Exception.classpropagation= Propagation.REQUIRED)@OverridepublicvoidsaveUser(User user){        userMapper.insert(user);// 业务逻辑执行,若抛出Exception及其子类,事务自动回滚    }}

注解核心属性可配置事务传播行为、隔离级别、超时时间、只读属性、回滚规则等,满足多样化事务需求。

2. 核心优势

  • 低侵入性:无需修改业务逻辑代码,仅通过注解标记事务边界,符合“开闭原则”,业务代码与事务管理代码解耦,便于维护。
  • 开发效率高:省去手动开启、提交、回滚事务的重复代码,简化开发流程,尤其适用于常规业务场景。
  • 配置灵活:通过注解属性可快速配置事务传播行为(如REQUIRED、SUPPORTS)、隔离级别(如READ_COMMITTED)等,无需修改核心逻辑。
  • 统一管理:可通过全局配置统一设置事务默认属性,避免分散配置导致的不一致问题。

3. 主要劣势

  • 控制粒度较粗:事务边界只能精确到方法级别,无法在方法内部灵活控制事务的开启与结束(如方法中某段代码需要独立事务,另一段不需要)。
  • 隐藏事务细节:事务的开启、提交逻辑被AOP封装,排查事务问题时(如事务未生效、异常回滚失败)需追溯AOP代理流程,增加排查难度。
  • 注解失效场景多:存在多种注解失效情况,如非public方法、静态方法、final方法上的注解无效;自调用方法(同一类中方法调用)无法触发AOP代理,导致事务失效,需额外处理(如通过ApplicationContext获取代理对象)。
  • 不适用于复杂事务场景:对于多数据源事务、嵌套事务的复杂控制,注解配置灵活性不足,难以满足精细化需求。

三、编程式事务:手动编码的精细化控制

1. 实现方式

编程式事务需开发者手动编写事务的开启、提交、回滚代码,核心依赖TransactionTemplate(推荐方式)或PlatformTransactionManager直接操作。TransactionTemplate采用模板方法模式,封装了事务的核心流程,开发者仅需编写业务逻辑与异常处理逻辑。

基础使用示例(基于TransactionTemplate):

@Servicepublic classOrderServiceImplimplementsOrderService{@Autowiredprivate TransactionTemplate transactionTemplate;@Autowiredprivate OrderMapper orderMapper;@OverridepublicvoidcreateOrder(Order order){// 编程式事务:手动定义事务逻辑        transactionTemplate.execute(status -> {try {                orderMapper.insert(order);// 复杂业务逻辑,可灵活控制事务节点return true// 事务提交            } catch (Exception e) {                status.setRollbackOnly(); // 事务回滚throw new RuntimeException("创建订单失败", e);            }        });    }}

也可通过PlatformTransactionManager手动开启事务(传统方式,代码冗余度高),需手动管理事务状态,避免遗漏回滚导致资源泄漏。

2. 核心优势

  • 控制粒度极细:可在方法内部精确控制事务的开启、提交、回滚时机,支持多段逻辑独立控制事务(如方法中部分代码开启事务,部分代码不参与事务)。
  • 事务逻辑透明:事务控制代码与业务代码同层,事务流程清晰,排查问题时可直接追溯代码,定位问题更高效。
  • 无失效场景:不受方法修饰符、自调用等场景限制,只要手动编码控制,事务逻辑均能生效,稳定性更强。
  • 适配复杂场景:可灵活处理多数据源事务、嵌套事务、分布式事务的精细化控制,支持自定义事务提交/回滚条件,满足特殊业务需求。

3. 主要劣势

  • 高侵入性:事务控制代码与业务代码耦合紧密,违背“单一职责原则”,增加业务代码冗余度,维护成本高。
  • 开发效率低:每个事务场景都需重复编写开启、提交、回滚代码,尤其在多事务场景下,代码量大幅增加。
  • 易遗漏事务细节:手动编码需注意事务回滚的完整性,若异常捕获不全面或遗漏setRollbackOnly,可能导致事务未回滚,引发数据不一致问题。

四、核心维度对比表

对比维度声明式事务(@Transactional)编程式事务(TransactionTemplate)
实现方式
基于AOP自动织入,注解/XML配置
手动编码,模板方法/直接操作事务管理器
侵入性
低(无侵入,业务代码纯净)
高(事务代码与业务代码耦合)
控制粒度
粗(仅方法级)
细(方法内任意节点)
开发效率
高(无需编写重复事务代码)
低(重复编写事务控制逻辑)
问题排查难度
高(AOP封装,需追溯代理流程)
低(事务逻辑透明,直接定位代码)
适用场景
常规业务、简单事务、追求代码简洁性场景
复杂事务、精细化控制、多数据源/分布式事务场景
失效风险
高(存在多种注解失效场景)
低(手动控制,无隐式失效场景)
灵活性
中(注解属性配置,无法突破方法级控制)
高(可自定义任意事务流程)

五、选型建议与最佳实践

1. 声明式事务选型场景

适用于大多数常规业务场景,尤其是CRUD操作、简单业务逻辑的事务管理。例如:用户注册、订单支付(无复杂分支事务)、数据批量插入等场景,可通过@Transactional快速实现事务管理,兼顾开发效率与代码整洁性。

最佳实践:

  • 明确注解生效范围,避免在非public、静态、final方法上使用注解。
  • 指定rollbackFor属性(默认仅回滚RuntimeException及其子类),避免受检异常导致事务不回滚。
  • 避免自调用问题,若需同一类中方法调用触发事务,可通过@Autowired自身代理对象或使用AopContext获取代理对象。

2. 编程式事务选型场景

适用于复杂事务场景,需要精细化控制事务边界或处理特殊事务需求。例如:多数据源跨库事务、嵌套事务(部分逻辑提交,部分回滚)、事务中需动态判断是否提交/回滚、分布式事务(结合Seata等框架)等场景。

最佳实践:

  • 优先使用TransactionTemplate而非直接操作PlatformTransactionManager,减少冗余代码。
  • 统一捕获异常,明确设置回滚条件,避免遗漏事务回滚。
  • 复杂场景下可封装事务模板工具类,减少重复编码。

六、总结

声明式事务与编程式事务并非对立关系,而是Spring事务管理体系中互补的两种方式。声明式事务以“低侵入、高效率”为核心优势,适配80%的常规业务场景;编程式事务以“高灵活、细粒度”为特点,解决复杂事务场景的管控难题。

在实际Java开发中,建议优先采用声明式事务简化开发,针对特殊复杂场景引入编程式事务补充控制。同时,需深入理解二者的底层原理与边界场景,避免因事务配置不当导致数据一致性问题,确保系统稳定性。

    往期推荐

    Java Stream异常处理全解析:机制、方案与实践指南

    Java Stream 异常处理的最佳实践有哪些?

    JVM 调优参数配置指南:新手从避坑到实战,不同服务器即拿即用

    Java 空指针异常(NPE)的优雅处理方案

    Java开发中100个高频易出错/疑难问题(全梳理,附解决方案+避坑要点)

    150个核心Linux命令:运维与开发的效率利器

    最新文章

    随机文章

    基本 文件 流程 错误 SQL 调试
    1. 请求信息 : 2026-02-08 09:19:17 HTTP/2.0 GET : https://f.mffb.com.cn/a/464367.html
    2. 运行时间 : 0.124871s [ 吞吐率:8.01req/s ] 内存消耗:4,504.38kb 文件加载:140
    3. 缓存信息 : 0 reads,0 writes
    4. 会话信息 : SESSION_ID=c1d462fbbe42dddfa77595aa498b4fed
    1. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/public/index.php ( 0.79 KB )
    2. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/autoload.php ( 0.17 KB )
    3. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_real.php ( 2.49 KB )
    4. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/platform_check.php ( 0.90 KB )
    5. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/ClassLoader.php ( 14.03 KB )
    6. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_static.php ( 4.90 KB )
    7. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper.php ( 8.34 KB )
    8. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/helper.php ( 2.19 KB )
    9. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/helper.php ( 1.47 KB )
    10. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/stubs/load_stubs.php ( 0.16 KB )
    11. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Exception.php ( 1.69 KB )
    12. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Facade.php ( 2.71 KB )
    13. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/deprecation-contracts/function.php ( 0.99 KB )
    14. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap.php ( 8.26 KB )
    15. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap80.php ( 9.78 KB )
    16. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/Resources/functions/dump.php ( 1.49 KB )
    17. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-dumper/src/helper.php ( 0.18 KB )
    18. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/VarDumper.php ( 4.30 KB )
    19. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/App.php ( 15.30 KB )
    20. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Container.php ( 15.76 KB )
    21. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/container/src/ContainerInterface.php ( 1.02 KB )
    22. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/provider.php ( 0.19 KB )
    23. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Http.php ( 6.04 KB )
    24. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Str.php ( 7.29 KB )
    25. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Env.php ( 4.68 KB )
    26. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/common.php ( 0.03 KB )
    27. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/helper.php ( 18.78 KB )
    28. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Config.php ( 5.54 KB )
    29. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/app.php ( 0.95 KB )
    30. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cache.php ( 0.78 KB )
    31. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/console.php ( 0.23 KB )
    32. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cookie.php ( 0.56 KB )
    33. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/database.php ( 2.48 KB )
    34. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Env.php ( 1.67 KB )
    35. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/filesystem.php ( 0.61 KB )
    36. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/lang.php ( 0.91 KB )
    37. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/log.php ( 1.35 KB )
    38. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/middleware.php ( 0.19 KB )
    39. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/route.php ( 1.89 KB )
    40. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/session.php ( 0.57 KB )
    41. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/trace.php ( 0.34 KB )
    42. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/view.php ( 0.82 KB )
    43. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/event.php ( 0.25 KB )
    44. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Event.php ( 7.67 KB )
    45. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/service.php ( 0.13 KB )
    46. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/AppService.php ( 0.26 KB )
    47. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Service.php ( 1.64 KB )
    48. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Lang.php ( 7.35 KB )
    49. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/lang/zh-cn.php ( 13.70 KB )
    50. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/Error.php ( 3.31 KB )
    51. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/RegisterService.php ( 1.33 KB )
    52. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/services.php ( 0.14 KB )
    53. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/PaginatorService.php ( 1.52 KB )
    54. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ValidateService.php ( 0.99 KB )
    55. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ModelService.php ( 2.04 KB )
    56. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Service.php ( 0.77 KB )
    57. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Middleware.php ( 6.72 KB )
    58. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/BootService.php ( 0.77 KB )
    59. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Paginator.php ( 11.86 KB )
    60. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/Validate.php ( 63.20 KB )
    61. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Model.php ( 23.55 KB )
    62. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Attribute.php ( 21.05 KB )
    63. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/AutoWriteData.php ( 4.21 KB )
    64. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Conversion.php ( 6.44 KB )
    65. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/DbConnect.php ( 5.16 KB )
    66. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/ModelEvent.php ( 2.33 KB )
    67. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/RelationShip.php ( 28.29 KB )
    68. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Arrayable.php ( 0.09 KB )
    69. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Jsonable.php ( 0.13 KB )
    70. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/contract/Modelable.php ( 0.09 KB )
    71. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Db.php ( 2.88 KB )
    72. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/DbManager.php ( 8.52 KB )
    73. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Log.php ( 6.28 KB )
    74. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Manager.php ( 3.92 KB )
    75. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerTrait.php ( 2.69 KB )
    76. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerInterface.php ( 2.71 KB )
    77. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cache.php ( 4.92 KB )
    78. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/simple-cache/src/CacheInterface.php ( 4.71 KB )
    79. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Arr.php ( 16.63 KB )
    80. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/driver/File.php ( 7.84 KB )
    81. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/Driver.php ( 9.03 KB )
    82. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php ( 1.99 KB )
    83. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/Request.php ( 0.09 KB )
    84. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Request.php ( 55.78 KB )
    85. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/middleware.php ( 0.25 KB )
    86. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Pipeline.php ( 2.61 KB )
    87. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/TraceDebug.php ( 3.40 KB )
    88. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/middleware/SessionInit.php ( 1.94 KB )
    89. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Session.php ( 1.80 KB )
    90. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/driver/File.php ( 6.27 KB )
    91. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/SessionHandlerInterface.php ( 0.87 KB )
    92. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/Store.php ( 7.12 KB )
    93. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Route.php ( 23.73 KB )
    94. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleName.php ( 5.75 KB )
    95. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Domain.php ( 2.53 KB )
    96. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleGroup.php ( 22.43 KB )
    97. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Rule.php ( 26.95 KB )
    98. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleItem.php ( 9.78 KB )
    99. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/route/app.php ( 1.72 KB )
    100. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Route.php ( 4.70 KB )
    101. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/dispatch/Controller.php ( 4.74 KB )
    102. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Dispatch.php ( 10.44 KB )
    103. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/controller/Index.php ( 4.81 KB )
    104. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/BaseController.php ( 2.05 KB )
    105. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/facade/Db.php ( 0.93 KB )
    106. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/connector/Mysql.php ( 5.44 KB )
    107. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/PDOConnection.php ( 52.47 KB )
    108. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Connection.php ( 8.39 KB )
    109. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/ConnectionInterface.php ( 4.57 KB )
    110. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/builder/Mysql.php ( 16.58 KB )
    111. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Builder.php ( 24.06 KB )
    112. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseBuilder.php ( 27.50 KB )
    113. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Query.php ( 15.71 KB )
    114. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseQuery.php ( 45.13 KB )
    115. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php ( 7.43 KB )
    116. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php ( 3.26 KB )
    117. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php ( 20.07 KB )
    118. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ParamsBind.php ( 3.66 KB )
    119. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ResultOperation.php ( 7.01 KB )
    120. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/WhereQuery.php ( 19.37 KB )
    121. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php ( 7.11 KB )
    122. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php ( 2.63 KB )
    123. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/Transaction.php ( 2.77 KB )
    124. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/driver/File.php ( 5.96 KB )
    125. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php ( 0.86 KB )
    126. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/Channel.php ( 3.89 KB )
    127. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/event/LogRecord.php ( 1.02 KB )
    128. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/Collection.php ( 16.47 KB )
    129. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/View.php ( 1.70 KB )
    130. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/View.php ( 4.39 KB )
    131. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Response.php ( 8.81 KB )
    132. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/response/View.php ( 3.29 KB )
    133. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cookie.php ( 6.06 KB )
    134. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-view/src/Think.php ( 8.38 KB )
    135. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php ( 1.60 KB )
    136. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/Template.php ( 46.61 KB )
    137. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/driver/File.php ( 2.41 KB )
    138. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/contract/DriverInterface.php ( 0.86 KB )
    139. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/runtime/temp/067d451b9a0c665040f3f1bdd3293d68.php ( 11.98 KB )
    140. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
    1. CONNECT:[ UseTime:0.000640s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
    2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000823s ]
    3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.009385s ]
    4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.014294s ]
    5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000652s ]
    6. SELECT * FROM `set` [ RunTime:0.000221s ]
    7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000609s ]
    8. SELECT * FROM `article` WHERE `id` = 464367 LIMIT 1 [ RunTime:0.000957s ]
    9. UPDATE `article` SET `lasttime` = 1770513557 WHERE `id` = 464367 [ RunTime:0.008036s ]
    10. SELECT * FROM `fenlei` WHERE `id` = 65 LIMIT 1 [ RunTime:0.000236s ]
    11. SELECT * FROM `article` WHERE `id` < 464367 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000635s ]
    12. SELECT * FROM `article` WHERE `id` > 464367 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.012269s ]
    13. SELECT * FROM `article` WHERE `id` < 464367 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.000968s ]
    14. SELECT * FROM `article` WHERE `id` < 464367 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.000735s ]
    15. SELECT * FROM `article` WHERE `id` < 464367 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.005808s ]
    0.126414s