• 为员工创造价值,为客户创造价值;
  • 为推动全社会进步而努力;
  • 成为中国的企业IT人才培养解决方案提供商.

400-689-2779

QTP自动化测试全流程实操指南:从基础入门到高阶技巧深度解析

QTP自动化测试全流程实操指南:从基础入门到高阶技巧深度解析

授课机构: 南京柯普瑞IT学校

上课地点: 校区地址

成交/评价:

联系电话: 400-689-2779

QTP自动化测试全流程实操指南:从基础入门到高阶技巧深度解析课程详情

QTP自动化测试全流程实操指南:从基础入门到高阶技巧深度解析

一、QTP自动化测试基础体系构建

QTP(QuickTest Professional)作为主流的自动化测试工具,在软件测试领域应用广泛。要熟练掌握其核心功能,需从基础体系搭建开始。这里将重点拆解自动化测试入门要点、工具基础操作及关键模块逻辑。

1. 自动化测试入门路径与工具认知

对于刚接触QTP的测试人员,首要任务是建立「自动化测试从零开始」的完整认知。这不仅包括工具的安装配置与界面熟悉,更需要理解自动化测试的核心价值——通过脚本化执行替代重复手工操作,提升测试效率与覆盖率。

QTP的帮助文档(Help)是重要的学习资源,其内置的操作指南、函数说明及示例代码,能快速解决工具使用中的常见问题。建议新手在操作过程中养成「遇到问题先查帮助文档」的习惯,逐步积累工具使用经验。

2. 录制与回放:QTP的基础功能逻辑

录制与回放是QTP最直观的功能,也是新手接触自动化测试的步。简单来说,录制功能通过捕获用户在被测系统上的操作生成脚本,回放则是按脚本重复执行这些操作。但需要明确:录制与回放并非万能,其核心作用是快速生成初始脚本框架,后续仍需大量优化工作。

值得注意的是,过度依赖录制模式会导致脚本维护成本激增。实际项目中,因页面元素变化、业务逻辑调整等因素,纯录制生成的脚本往往难以稳定运行。因此,「认清并远离QTP的脚本录制模式」是进阶学习的重要认知转变。

二、对象库:QTP自动化测试的核心引擎

对象库(Object Repository)被称为QTP的「精华模块」,其核心作用是管理被测应用中的界面元素(如按钮、输入框、列表等),通过定义对象属性实现元素的精准识别与操作。掌握对象库的使用,是编写稳定自动化脚本的关键。

1. 对象库基础操作与原理解析

以一个简单登录场景为例:用户输入用户名、点击登录按钮。QTP通过对象库记录「用户名输入框」的「name属性=username」、「登录按钮」的「id属性=loginBtn」等特征,在回放时依据这些特征定位元素并执行操作。这一过程涉及对象库的存储机制、对象属性匹配规则及Object Spy工具的使用。

Object Spy是对象库操作的核心辅助工具,它能实时获取界面元素的详细属性信息(如类名、坐标、文本内容等),帮助测试人员准确定义对象特征。而对象库管理器(Object Repository Manager)则负责对象库的集中管理,支持导入、导出、合并等操作,满足团队协作需求。

2. 对象库进阶编程与常见问题处理

进入Expert View模式后,测试人员可直接编写对象库相关代码,实现更灵活的对象管理。例如,通过编程方式动态修改对象属性,适应页面元素的动态变化。这里需要区分「测试对象(Test Objects)」与「运行时对象(Run-Time Objects)」的差异:测试对象是对象库中定义的静态描述,运行时对象是脚本执行时实际操作的界面元素,两者需通过属性匹配建立关联。

实际项目中,对象无法识别或识别错误是常见问题。可能原因包括:页面元素属性动态变化(如随机生成的id)、多个元素属性重复、对象库与实际页面版本不一致等。针对这些问题,可通过调整对象识别属性优先级(如优先使用「text」而非「id」)、启用「智能识别」功能或结合描述性编程(后文详述)解决。

三、描述性编程与数据池:提升脚本灵活性的关键

除对象库编程外,描述性编程(Descriptive Programming)是QTP的另一大核心技术。它通过动态描述对象属性定位元素,无需依赖对象库,极大提升了脚本的灵活性和可维护性。

1. 描述性编程的实现方式与应用场景

描述性编程有两种主要写法:一种是使用「Description」对象逐步构建属性集合,另一种是直接在操作语句中嵌入属性描述。例如,定位一个文本为「提交」的按钮,可写为:

Browser("title:=测试页面").Page("title:=表单页").WebButton("text:=提交").Click

这种方式无需提前将按钮信息存储到对象库,适用于页面元素频繁变化或需要动态定位的场景(如多语言环境下的按钮文本切换)。实际应用中,描述性编程常与Object Spy结合使用:通过Spy获取元素属性,再用描述性语法编写定位语句,确保准确性。

需要注意的是,对象库编程(OP)与描述性编程(DP)各有优劣。OP适合稳定的界面元素管理,DP适合动态场景,两者混搭使用可兼顾脚本的稳定性与灵活性。

2. 数据池(Data Table)的深度应用

数据池是QTP实现参数化测试的核心工具,通过外部数据驱动脚本执行,支持同一脚本测试多组数据。例如,测试登录功能时,可在Data Table中填写多组用户名和密码,脚本读取数据后循环执行登录操作,验证不同输入的响应结果。

QTP的Data Table分为「测试数据池(Test DataTable)」和「运行时数据池(Run-Time DataTable)」。测试数据池存储测试所需的原始数据,运行时数据池是测试执行过程中数据的副本,支持动态修改。熟练使用DataTable对象的方法(如「GetSheet」获取工作表、「GetRowCount」获取行数),能高效实现数据的读取、写入与管理。

四、业务流控制与测试结果验证

自动化测试的最终目标是验证系统功能的正确性,这涉及业务流程的有效控制与测试结果的准确验证。QTP的操作模块(Actions)和验证点功能,正是实现这一目标的关键工具。

1. 操作模块(Actions)的业务流管理

复杂业务通常由多个子流程组成,QTP的Actions功能可将这些子流程封装为独立模块,通过调用(Call Action)实现业务流的灵活控制。例如,将「登录」「搜索」「下单」分别封装为Action,测试「完整购物流程」时依次调用这三个Action即可。

调用Action有三种方式:顺序调用(按脚本顺序执行)、参数化调用(传递输入输出参数)、迭代调用(指定执行次数)。合理切分Action(如按功能模块或业务步骤),能显著提升脚本的可维护性和复用性。

2. 验证点与测试报告:确保测试有效性

自动化测试的有效性,很大程度上取决于验证点的设计质量。QTP提供了多种验证点函数(如「CheckProperty」检查对象属性、「Verify」验证文本内容),支持验证界面元素状态、数据正确性、系统响应等。例如,登录后验证页面是否跳转到「用户中心」,可通过验证目标页面的标题或特定元素是否存在实现。

除内置验证点外,还可通过自定义函数实现复杂验证逻辑(如数据库数据比对、接口返回值校验)。测试报告(TestReport)会记录每个验证点的执行结果,支持HTML、文本等多种格式导出,方便测试人员快速定位问题。

五、QTP高阶技能:从工具使用到项目实战

掌握基础功能后,要成为QTP自动化测试专家,需进一步学习VBScript编程、函数资源库管理、环境变量配置等高阶技能,以适应复杂项目需求。

1. VBScript在自动化测试中的深度应用

QTP的脚本基于VBScript语言编写,熟练掌握其语法与常用函数是进阶关键。需重点关注代码规范(如变量命名、注释习惯)、基础语法(条件判断、循环结构)、常用函数(如「Split」分割字符串、「Date」获取当前日期)及自定义函数/类的封装。

例如,通过「SendKeys」函数模拟键盘输入(如快捷键操作),或使用「GetRef」方法获取函数引用实现动态调用,能解决许多特殊场景下的测试需求。

2. 10类常用Web控件的识别与操作

Web应用测试中,常见控件(如链接、输入框、复选框、表格等)的操作是基础。QTP针对不同控件提供了专属对象类型(如「WebEdit」对应输入框、「WebTable」对应表格),需掌握其特有属性和方法。例如:

  • 操作链接(Link):通过「href」属性或文本内容定位,调用「Click」方法触发跳转;
  • 操作表格(WebTable):使用「GetRowCount」获取行数,「GetCellData」读取单元格内容;
  • 操作下拉列表(WebList):通过「Set」方法选择指定选项,或「GetItem」获取所有选项值。

3. 函数资源库与环境变量的项目级应用

函数资源库(Library Files)用于存储可复用的函数和过程,支持静态调用(通过「Insert」菜单添加)和动态调用(使用「ExecuteFile」方法加载),能避免重复编码,提升团队协作效率。QTP 10.0及以上版本增强了函数库功能,支持更灵活的作用域管理和错误处理。

环境变量(Environment Variables)用于存储测试环境相关配置(如测试服务器地址、数据库连接信息),分为内置变量(如「ProjectName」获取项目名称)和自定义变量(可通过外部XML文件配置)。合理使用环境变量,能快速切换测试环境(如从「测试环境」切换到「预发布环境」),减少脚本修改量。

4. 场景恢复与自动化模型(AOM)的实战价值

场景恢复(Recovery Scenarios)用于处理测试执行过程中出现的意外中断(如弹出警告框、页面崩溃),通过预设的恢复步骤(如关闭警告框、刷新页面)使测试继续执行。需注意避免常见误区:过度依赖默认恢复场景(可能导致错误被掩盖)、未针对具体项目定制恢复逻辑等。

QTP自动化模型对象(AOM)提供了编程接口,允许通过代码控制QTP的运行(如启动测试、停止测试、获取测试结果)。这一功能在持续集成(CI)环境中尤为重要,可实现自动化测试与Jenkins、TeamCity等工具的集成,推动测试流程的全面自动化。

南京柯普瑞IT学校

南京柯普瑞IT学校
认证 7 年

成立: 2006年

认证 地址认证 教学保障 在线预约 到店体验 售后支持
基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-04-04 15:02:41 HTTP/1.1 GET : http://www.aabqy.com/s/1037/c/43810.html
  2. 运行时间 : 0.071582s [ 吞吐率:13.97req/s ] 内存消耗:405.40kb 文件加载:136
  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_course_details.php ( 6.12 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_bottom.php ( 1.16 KB )
  136. /data/web/baijiao_branch_collect/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.000309s ] mysql:host=127.0.0.1;port=3306;dbname=baijiao_branch_collect;charset=utf8
  2. SHOW FULL COLUMNS FROM `fqi_school` [ RunTime:0.000957s ]
  3. SELECT * FROM `fqi_school` WHERE `school_id` = '1037' AND `site_id` = 23 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000268s ]
  4. SHOW FULL COLUMNS FROM `fqi_school_class` [ RunTime:0.000744s ]
  5. SELECT * FROM `fqi_school_class` WHERE `school_id` = 1037 [ RunTime:0.000270s ]
  6. SHOW FULL COLUMNS FROM `fqi_school_campus` [ RunTime:0.000654s ]
  7. SELECT * FROM `fqi_school_campus` WHERE `school_id` = 1037 [ RunTime:0.000266s ]
  8. SHOW FULL COLUMNS FROM `fqi_school_course` [ RunTime:0.000774s ]
  9. SELECT `a`.*,`content` FROM `fqi_school_course` `a` LEFT JOIN `fqi_school_course_content` `b` ON `b`.`content_id`=`a`.`content_id` WHERE `school_id` = 1037 AND `a`.`content_id` = '43810' AND `course_status` = 1 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000723s ]
  10. (select content_id,course_name from fqi_school_course where school_id = '1037' and content_id < '43810' and site_id = '23' order by content_id desc limit 1) union all(select content_id,course_name from fqi_school_course where school_id = '1037' and content_id > '43810' and site_id <= '23' order by content_id asc limit 1) [ RunTime:0.001401s ]
  11. SELECT * FROM `fqi_school_course` WHERE `school_id` = 1037 AND `site_id` = 23 AND `course_status` = 1 AND `school_status` = 1 AND `school_class_id` = 4196 ORDER BY `course_id` DESC LIMIT 4 [ RunTime:0.000477s ]
  12. SELECT * FROM `fqi_school_course` WHERE `school_id` = 1037 AND `site_id` = 23 AND `course_status` = 1 AND `school_status` = 1 ORDER BY `course_id` DESC LIMIT 10 [ RunTime:0.000946s ]
  13. SELECT COUNT(*) AS think_count FROM `fqi_school_course` WHERE `school_id` = 1037 AND `course_status` = 1 [ RunTime:0.000283s ]
  14. SHOW FULL COLUMNS FROM `fqi_school_teacher` [ RunTime:0.000683s ]
  15. SELECT COUNT(*) AS think_count FROM `fqi_school_teacher` WHERE `school_id` = '1037' [ RunTime:0.000197s ]
  16. SHOW FULL COLUMNS FROM `fqi_school_comments` [ RunTime:0.000604s ]
  17. SELECT COUNT(*) AS think_count FROM `fqi_school_comments` WHERE `school_id` = '1037' [ RunTime:0.000192s ]
  18. SELECT `content_id`,`course_name`,`a`.`school_id`,`b`.`school_name` FROM `fqi_school_course` `a` LEFT JOIN `fqi_school` `b` ON `b`.`school_id`=`a`.`school_id` WHERE `a`.`site_id` = '23' AND `b`.`school_status` = '1' AND `course_status` = 1 AND `course_id` < '43810' ORDER BY `content_id` DESC LIMIT 20 [ RunTime:0.057551s ]
0.071902s