• 实用、有效的课程体系研发
  • 良好的互动学习体验
  • 真实的服务

400-888-9073

白盒测试与黑盒测试全解析:方法对比、策略应用及测试人员进阶指南

来源:长沙博为峰 时间:08-23

白盒测试与黑盒测试全解析:方法对比、策略应用及测试人员进阶指南

黑盒测试核心方法与实践要点

软件测试领域中,黑盒测试作为基础且常用的测试手段,其方法体系直接影响测试覆盖度与效率。从实际应用看,黑盒测试主要围绕功能验证展开,通过输入输出关系分析设计测试用例,常见方法包括边界值、等价类、错误推测法等,每种方法均有独特的适用场景与注意事项。

边界值测试:关注极值的验证逻辑

边界值测试是黑盒测试中最基础的方法之一,其核心逻辑是针对输入域的边界点设计测试用例。例如,当系统要求输入年龄范围为18-60岁时,除了验证18和60这两个临界点,还需检查17、19、59、61等邻近值。这种方法虽能有效覆盖多数边界异常,但存在明显局限性:对于布尔型输入(如"是否同意协议"),因不存在数值边界,边界值测试无法发挥作用;同时,当输入域包含多个维度时,测试用例数量可能呈指数级增长,导致冗余问题。

等价类测试:简化测试用例的关键工具

针对边界值测试的冗余问题,等价类测试提供了优化思路。该方法将输入域划分为若干等价类,每个类中的测试用例对系统的影响具有一致性,只需选取部分代表性用例即可覆盖整个类。等价类又分为弱等价类与强等价类:弱等价类仅考虑单维度输入的有效性(如合法/非法输入),而强等价类需同时考虑多维度输入的组合情况(如年龄、性别、职业的交叉验证)。实际操作中,建议为每个等价类分配唯一编号,例如"EC01-合法年龄""EC02-非法负数年龄",这种标准化处理能显著提升测试文档的可追溯性。

因果图与决策表:复杂逻辑的可视化分析

当系统存在多个输入条件且输出依赖条件组合时,因果图法是更有效的选择。该方法通过"恒等、或、非"等逻辑关系描述输入与输出的因果联系,并引入E(异或)、I(包含)、O(唯一)等约束条件规范输入组合。例如,某系统要求用户至少选择"短信通知"或"邮件通知"中的一种(I约束),但不能同时选择两种(E约束),因果图可清晰呈现这种逻辑关系。不过,因果图的绘制过程较为繁琐,实际应用中更推荐直接生成决策表——将输入条件、约束规则与预期输出整理为表格形式,既能保持逻辑清晰,又便于测试用例的直接转化。

其他黑盒测试方法的特点与局限

错误推测法依赖测试人员的经验积累,通过预判常见错误(如空值输入、特殊符号注入)设计针对性用例,其优势在于快速定位高频问题,但覆盖率难以量化;场景法以用户实际操作流程为核心,模拟真实使用场景(如电商下单流程),适合验证系统的端到端功能,但需投入大量时间设计完整场景链。值得注意的是,黑盒测试用例可能存在覆盖漏洞或冗余,此时可借助白盒测试的覆盖指标(如语句覆盖、分支覆盖)进行评估,形成互补验证。

白盒测试的分类与技术要点

与黑盒测试关注外部功能不同,白盒测试聚焦程序内部逻辑,通过分析代码结构、执行路径等实现深度验证。其方法体系主要分为静态测试与动态测试两大类,分别从代码检查与运行验证两个维度保障软件质量。

静态测试:代码质量的前置保障

静态测试无需运行程序,主要通过人工评审或工具分析实现。常见方法包括:

  • 同行评审:由开发、测试、架构师组成评审小组,对代码的逻辑正确性、注释完整性、命名规范等进行交叉检查,能有效发现潜在设计缺陷;
  • 静态结构分析:利用工具(如SonarQube)扫描代码,检测循环复杂度、耦合度等指标,识别高风险代码段;
  • 数据流测试:追踪变量的定义-使用路径,检查是否存在未初始化变量、死代码等问题,确保数据流动的准确性。

静态测试的核心价值在于早期发现问题,降低后期修复成本。例如,在模块开发完成后立即进行代码评审,可避免因逻辑错误导致的大规模返工。

动态测试:运行时的逻辑验证

动态测试需要实际运行程序,通过设计测试用例覆盖代码的关键路径。其方法可细分为:

  • 逻辑覆盖测试:以判定表达式为核心,设计用例实现语句覆盖(所有代码行至少执行一次)、判定覆盖(所有分支至少执行一次)、条件覆盖(所有条件取值至少满足一次)等不同层级的覆盖;
  • 路径覆盖测试:针对程序的独立执行路径设计用例,确保每条可执行路径至少被覆盖一次,适用于复杂逻辑模块(如状态机实现);
  • 循环测试:针对不同类型的循环(如简单循环、嵌套循环)设计用例,验证循环次数、终止条件、中间状态的正确性,避免因循环边界错误导致的性能问题或死循环。

动态测试的难点在于如何平衡覆盖深度与测试效率。例如,完全路径覆盖在理论上最严格,但实际中可能因路径数量爆炸(如嵌套循环)导致测试不可行,此时需结合风险优先级选择关键路径进行重点覆盖。

白盒测试的综合应用策略

在实际项目中,黑盒测试是功能验证的主力,而白盒测试更多作为补充手段,用于解决黑盒测试难以覆盖的深层问题。以下是可落地的综合策略,帮助提升测试效能:

策略一:优先开展静态白盒测试

对于核心功能模块(如支付接口、用户认证),需在代码开发阶段就启动静态测试。建议每周组织1-2次代码评审会议,结合历史缺陷数据制定《缺陷检查清单》(如"是否处理空指针异常""是否存在未关闭的资源"),并定期更新清单内容,逐步形成标准化的评审流程。

策略二:边界值与逻辑边界的双重验证

设计动态测试用例时,需同时考虑业务边界(如订单金额的最小/值)与代码逻辑边界(如循环的终止条件、判定表达式的临界值)。例如,某系统要求"用户连续3次输入错误密码则锁定账户",测试用例不仅要覆盖2次错误、3次错误、4次错误的业务场景,还需检查代码中计数器变量是否在3次时触发锁定逻辑,避免因变量溢出或逻辑判断错误导致功能失效。

策略三:针对性补充白盒测试

黑盒测试难以发现内存泄漏、资源未释放等底层问题,此时需引入白盒测试工具(如Valgrind用于内存检测、JProfiler用于Java内存分析)。例如,对长期运行的后台服务,可通过工具监控内存使用情况,定位因对象未正确释放导致的内存泄漏问题。

策略四:数据流分析指导路径测试

针对关键变量(如用户ID、交易金额),通过数据流测试追踪其定义-使用路径,识别可能存在的未初始化使用、无效赋值等问题。例如,某函数中变量"totalAmount"在分支A中被赋值,在分支B中未赋值但被使用,数据流分析可快速定位此类问题,指导测试人员补充分支B的覆盖用例。

策略五:工具辅助提升效率

合理利用测试工具可显著提升白盒测试效率。例如,使用JaCoCo统计Java代码的覆盖率,快速定位未覆盖的代码段;通过CodeClimate分析代码质量,自动检测代码异味(如过长函数、重复代码)。工具的输出结果可直接用于指导测试用例设计与代码优化,形成"测试-分析-优化"的闭环。

测试人员的技能进阶路径

无论是刚入门的测试新手,还是有多年经验的测试工程师,深入掌握白盒与黑盒测试技术都是职业发展的基石。对于新手,建议从黑盒测试入手,熟悉常见功能测试方法后,逐步学习白盒测试的基础概念(如代码结构分析、覆盖率指标);对于有经验的测试人员,可重点突破白盒测试的高阶应用(如复杂路径覆盖、工具集成自动化),同时关注测试左移(在需求阶段介入测试)与测试右移(生产环境监控),拓展测试的全生命周期影响力。

总之,白盒与黑盒测试并非对立关系,而是互补共存。只有将两者有机结合,根据项目需求灵活选择测试方法,才能构建更全面的质量保障体系,为个人职业发展与企业软件质量提升创造更大价值。

校区导航
基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-04-04 20:52:16 HTTP/1.1 GET : http://www.aabrh.com/s/4772/n/28840.html
  2. 运行时间 : 0.020356s [ 吞吐率:49.13req/s ] 内存消耗:387.56kb 文件加载:137
  3. 缓存信息 : 0 reads,0 writes
  1. /data/web/baijiao_branch_collect/public/index.php ( 0.79 KB )
  2. /data/web/baijiao_branch_collect/vendor/autoload.php ( 0.75 KB )
  3. /data/web/baijiao_branch_collect/vendor/composer/autoload_real.php ( 1.63 KB )
  4. /data/web/baijiao_branch_collect/vendor/composer/platform_check.php ( 0.90 KB )
  5. /data/web/baijiao_branch_collect/vendor/composer/ClassLoader.php ( 15.99 KB )
  6. /data/web/baijiao_branch_collect/vendor/composer/autoload_static.php ( 4.26 KB )
  7. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/helper.php ( 8.34 KB )
  8. /data/web/baijiao_branch_collect/vendor/topthink/think-validate/src/helper.php ( 2.19 KB )
  9. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/helper.php ( 1.47 KB )
  10. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/stubs/load_stubs.php ( 0.16 KB )
  11. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Exception.php ( 1.69 KB )
  12. /data/web/baijiao_branch_collect/vendor/topthink/think-container/src/Facade.php ( 2.71 KB )
  13. /data/web/baijiao_branch_collect/vendor/symfony/deprecation-contracts/function.php ( 0.99 KB )
  14. /data/web/baijiao_branch_collect/vendor/symfony/polyfill-mbstring/bootstrap.php ( 8.26 KB )
  15. /data/web/baijiao_branch_collect/vendor/symfony/polyfill-mbstring/bootstrap80.php ( 9.78 KB )
  16. /data/web/baijiao_branch_collect/vendor/symfony/var-dumper/Resources/functions/dump.php ( 1.49 KB )
  17. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/App.php ( 15.30 KB )
  18. /data/web/baijiao_branch_collect/vendor/topthink/think-container/src/Container.php ( 15.76 KB )
  19. /data/web/baijiao_branch_collect/vendor/psr/container/src/ContainerInterface.php ( 1.02 KB )
  20. /data/web/baijiao_branch_collect/app/provider.php ( 0.19 KB )
  21. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Http.php ( 6.04 KB )
  22. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/helper/Str.php ( 7.29 KB )
  23. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Env.php ( 4.68 KB )
  24. /data/web/baijiao_branch_collect/app/common.php ( 10.83 KB )
  25. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/helper.php ( 18.78 KB )
  26. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Config.php ( 5.54 KB )
  27. /data/web/baijiao_branch_collect/config/app.php ( 1.29 KB )
  28. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/facade/Env.php ( 1.67 KB )
  29. /data/web/baijiao_branch_collect/config/cache.php ( 1.22 KB )
  30. /data/web/baijiao_branch_collect/config/config.php ( 0.26 KB )
  31. /data/web/baijiao_branch_collect/config/console.php ( 0.29 KB )
  32. /data/web/baijiao_branch_collect/config/cookie.php ( 0.56 KB )
  33. /data/web/baijiao_branch_collect/config/database.php ( 2.29 KB )
  34. /data/web/baijiao_branch_collect/config/filesystem.php ( 0.63 KB )
  35. /data/web/baijiao_branch_collect/config/lang.php ( 0.81 KB )
  36. /data/web/baijiao_branch_collect/config/log.php ( 1.37 KB )
  37. /data/web/baijiao_branch_collect/config/middleware.php ( 0.19 KB )
  38. /data/web/baijiao_branch_collect/config/route.php ( 1.54 KB )
  39. /data/web/baijiao_branch_collect/config/session.php ( 0.57 KB )
  40. /data/web/baijiao_branch_collect/config/trace.php ( 0.34 KB )
  41. /data/web/baijiao_branch_collect/config/view.php ( 0.81 KB )
  42. /data/web/baijiao_branch_collect/app/event.php ( 0.25 KB )
  43. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Event.php ( 7.67 KB )
  44. /data/web/baijiao_branch_collect/app/service.php ( 0.13 KB )
  45. /data/web/baijiao_branch_collect/app/AppService.php ( 0.26 KB )
  46. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Service.php ( 1.64 KB )
  47. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Lang.php ( 7.35 KB )
  48. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/lang/zh-cn.php ( 13.70 KB )
  49. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/initializer/Error.php ( 3.31 KB )
  50. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/initializer/RegisterService.php ( 1.33 KB )
  51. /data/web/baijiao_branch_collect/vendor/services.php ( 0.14 KB )
  52. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/service/PaginatorService.php ( 1.52 KB )
  53. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/service/ValidateService.php ( 0.99 KB )
  54. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/service/ModelService.php ( 2.04 KB )
  55. /data/web/baijiao_branch_collect/vendor/topthink/think-trace/src/Service.php ( 0.77 KB )
  56. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Middleware.php ( 6.72 KB )
  57. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/initializer/BootService.php ( 0.77 KB )
  58. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/Paginator.php ( 11.86 KB )
  59. /data/web/baijiao_branch_collect/vendor/topthink/think-validate/src/Validate.php ( 63.20 KB )
  60. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/Model.php ( 23.55 KB )
  61. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/Attribute.php ( 21.05 KB )
  62. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/AutoWriteData.php ( 4.20 KB )
  63. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/Conversion.php ( 6.75 KB )
  64. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/DbConnect.php ( 5.16 KB )
  65. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/ModelEvent.php ( 2.33 KB )
  66. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/concern/RelationShip.php ( 28.30 KB )
  67. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/contract/Arrayable.php ( 0.09 KB )
  68. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/contract/Jsonable.php ( 0.13 KB )
  69. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/model/contract/Modelable.php ( 0.09 KB )
  70. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Db.php ( 2.88 KB )
  71. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/DbManager.php ( 8.52 KB )
  72. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Log.php ( 6.28 KB )
  73. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Manager.php ( 3.92 KB )
  74. /data/web/baijiao_branch_collect/vendor/psr/log/src/LoggerTrait.php ( 2.69 KB )
  75. /data/web/baijiao_branch_collect/vendor/psr/log/src/LoggerInterface.php ( 2.71 KB )
  76. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Cache.php ( 4.92 KB )
  77. /data/web/baijiao_branch_collect/vendor/psr/simple-cache/src/CacheInterface.php ( 4.71 KB )
  78. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/helper/Arr.php ( 17.45 KB )
  79. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/cache/driver/Redis.php ( 6.94 KB )
  80. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/cache/Driver.php ( 9.03 KB )
  81. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php ( 1.99 KB )
  82. /data/web/baijiao_branch_collect/app/Request.php ( 0.09 KB )
  83. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Request.php ( 55.78 KB )
  84. /data/web/baijiao_branch_collect/app/middleware.php ( 0.26 KB )
  85. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Pipeline.php ( 2.61 KB )
  86. /data/web/baijiao_branch_collect/vendor/topthink/think-trace/src/TraceDebug.php ( 3.40 KB )
  87. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Route.php ( 23.73 KB )
  88. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/RuleName.php ( 5.75 KB )
  89. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/Domain.php ( 2.53 KB )
  90. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/RuleGroup.php ( 22.43 KB )
  91. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/Rule.php ( 26.95 KB )
  92. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/RuleItem.php ( 9.78 KB )
  93. /data/web/baijiao_branch_collect/route/app.php ( 3.05 KB )
  94. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/facade/Route.php ( 4.70 KB )
  95. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/dispatch/Controller.php ( 4.74 KB )
  96. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/Dispatch.php ( 10.44 KB )
  97. /data/web/baijiao_branch_collect/app/controller/Index.php ( 33.26 KB )
  98. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/facade/Request.php ( 9.20 KB )
  99. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/route/Url.php ( 14.07 KB )
  100. /data/web/baijiao_branch_collect/app/model/IndexModel.php ( 19.95 KB )
  101. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/facade/Config.php ( 1.37 KB )
  102. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/facade/Cache.php ( 2.06 KB )
  103. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/facade/Db.php ( 0.93 KB )
  104. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/connector/Mysql.php ( 5.73 KB )
  105. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/PDOConnection.php ( 53.74 KB )
  106. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/Connection.php ( 8.39 KB )
  107. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/ConnectionInterface.php ( 4.57 KB )
  108. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/builder/Mysql.php ( 16.58 KB )
  109. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/Builder.php ( 24.07 KB )
  110. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/BaseBuilder.php ( 27.50 KB )
  111. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/Query.php ( 15.97 KB )
  112. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/BaseQuery.php ( 45.13 KB )
  113. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php ( 7.43 KB )
  114. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php ( 3.26 KB )
  115. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php ( 20.07 KB )
  116. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/ParamsBind.php ( 3.66 KB )
  117. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/ResultOperation.php ( 7.01 KB )
  118. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/WhereQuery.php ( 19.37 KB )
  119. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php ( 7.11 KB )
  120. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php ( 2.63 KB )
  121. /data/web/baijiao_branch_collect/vendor/topthink/think-orm/src/db/concern/Transaction.php ( 2.77 KB )
  122. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/log/driver/File.php ( 5.96 KB )
  123. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php ( 0.86 KB )
  124. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/log/Channel.php ( 3.89 KB )
  125. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/event/LogRecord.php ( 1.02 KB )
  126. /data/web/baijiao_branch_collect/vendor/topthink/think-helper/src/Collection.php ( 16.47 KB )
  127. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Response.php ( 8.81 KB )
  128. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/response/View.php ( 3.29 KB )
  129. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/Cookie.php ( 6.06 KB )
  130. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/View.php ( 4.39 KB )
  131. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/view/driver/Php.php ( 6.44 KB )
  132. /data/web/baijiao_branch_collect/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php ( 1.60 KB )
  133. /data/web/baijiao_branch_collect/view/index/pc/school_news_details.php ( 2.39 KB )
  134. /data/web/baijiao_branch_collect/view/index/pc/school_top.php ( 5.76 KB )
  135. /data/web/baijiao_branch_collect/view/index/pc/school_right.php ( 2.17 KB )
  136. /data/web/baijiao_branch_collect/view/index/pc/school_bottom.php ( 1.16 KB )
  137. /data/web/baijiao_branch_collect/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.000351s ] mysql:host=127.0.0.1;port=3306;dbname=baijiao_branch_collect;charset=utf8
  2. SHOW FULL COLUMNS FROM `fqi_school` [ RunTime:0.001042s ]
  3. SELECT * FROM `fqi_school` WHERE `school_id` = '4772' AND `site_id` = 20 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000309s ]
  4. SHOW FULL COLUMNS FROM `fqi_school_class` [ RunTime:0.000601s ]
  5. SELECT * FROM `fqi_school_class` WHERE `school_id` = 4772 [ RunTime:0.000251s ]
  6. SHOW FULL COLUMNS FROM `fqi_school_campus` [ RunTime:0.000608s ]
  7. SELECT * FROM `fqi_school_campus` WHERE `school_id` = 4772 [ RunTime:0.000286s ]
  8. SHOW FULL COLUMNS FROM `fqi_school_news` [ RunTime:0.000669s ]
  9. SELECT `a`.*,`content` FROM `fqi_school_news` `a` LEFT JOIN `fqi_school_news_content` `b` ON `b`.`content_id`=`a`.`content_id` WHERE `school_id` = 4772 AND `a`.`content_id` = '28840' AND `news_status` = 1 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000621s ]
  10. (select content_id,news_name,school_id from fqi_school_news where school_id = '4772' and content_id < '28840' and site_id <= '20' order by content_id desc limit 1) union all(select content_id,news_name,school_id from fqi_school_news where school_id = '4772' and content_id > '28840' and site_id <= '20' order by content_id asc limit 1) [ RunTime:0.000582s ]
  11. SHOW FULL COLUMNS FROM `fqi_school_course` [ RunTime:0.000731s ]
  12. SELECT * FROM `fqi_school_course` WHERE `school_id` = 4772 AND `site_id` = 20 AND `course_status` = 1 AND `school_status` = 1 ORDER BY `course_id` DESC LIMIT 4 [ RunTime:0.000362s ]
  13. SELECT * FROM `fqi_school_course` WHERE `school_id` = 4772 AND `school_status` = 1 AND `course_status` = 1 ORDER BY `course_id` DESC LIMIT 8 [ RunTime:0.000172s ]
  14. SELECT * FROM `fqi_school_news` WHERE `school_id` = 4772 ORDER BY `click` DESC,`news_id` DESC LIMIT 5 [ RunTime:0.000158s ]
  15. SELECT `content_id`,`news_name`,`a`.`school_id`,`b`.`school_name` FROM `fqi_school_news` `a` LEFT JOIN `fqi_school` `b` ON `b`.`school_id`=`a`.`school_id` WHERE `a`.`site_id` = '20' AND `b`.`school_status` = '1' AND `news_status` = 1 AND `content_id` < 28840 ORDER BY `content_id` DESC LIMIT 20 [ RunTime:0.006427s ]
0.020855s