• 零基础入门IT行业
  • 专注每一位学员的成长
  • 职业道路走得坚实而长远

400-666-4820

Struts2框架系统化学习指南:从基础搭建到高级应用的完整课程解析

Struts2框架系统化学习指南:从基础搭建到高级应用的完整课程解析

授课机构: 沈阳叩丁狼教育

上课地点: 校区地址

成交/评价:

联系电话: 400-666-4820

Struts2框架系统化学习指南:从基础搭建到高级应用的完整课程解析课程详情

哪些开发者需要系统学习Struts2?

在JavaWeb开发领域,MVC框架是构建高效应用的核心工具。Struts2作为经典的MVC框架之一,其学习价值不仅体现在技术本身,更在于对开发思维的系统化训练。这门课程主要面向三类开发者:

类是已有JavaWeb开发经验的同学。这类开发者通常掌握了基础的Servlet、JSP技术,但在复杂业务场景中,直接使用原生技术会面临代码冗余、维护困难等问题。Struts2的MVC模式能帮助他们建立更清晰的分层架构,提升代码可维护性。

第二类是对MVC框架原理感兴趣的学习者。MVC作为软件设计的经典模式,理解其在具体框架中的实现逻辑,能为后续学习SpringMVC、Spring Boot等主流框架打下坚实基础。Struts2的体系结构清晰,是入门MVC模式的优质载体。

第三类是使用过其他MVC框架(如Struts1或SpringMVC)的开发者。Struts2与Struts1的架构差异显著,与SpringMVC的设计思路也各有侧重。通过对比学习,能更深刻理解不同框架的适用场景,拓展技术视野。

为什么选择Struts2作为进阶学习方向?

要理解Struts2的学习价值,需先明确其在Web开发框架中的定位。Struts2本质上是一个基于MVC设计模式的Web应用框架,核心功能是作为控制器(Controller)协调模型(Model)与视图(View)的数据交互。与Struts1相比,Struts2进行了全面重构:它不再依赖Servlet API,而是通过FilterDispatcher拦截请求,采用更灵活的拦截器机制处理请求,这种设计大幅提升了框架的可扩展性和灵活性。

在实际开发中,Struts2的优势体现在三个方面:其一,高度模块化的拦截器机制,开发者可通过配置实现参数校验、日志记录、权限控制等通用功能,减少重复编码;其二,强大的标签库支持,JSP页面中使用Struts2标签能简化数据展示与表单处理逻辑;其三,完善的国际化解决方案,通过资源文件配置即可实现多语言支持,满足全球化应用需求。

尽管当前Spring生态占据主流,但Struts2在传统企业级应用中仍有广泛应用。掌握这一框架,不仅能提升开发者的竞争力,更能通过对比学习加深对MVC模式的理解,为后续技术进阶提供扎实基础。

课程内容全解析:从入门到精通的系统化学习路径

阶段:Struts2基础入门

入门阶段的核心目标是建立框架认知,掌握基础开发流程。课程从Struts2的起源与设计理念讲起,详细讲解环境搭建步骤——包括依赖库引入、配置文件编写、服务器集成等关键操作。通过“HelloWorld”程序的完整实现,学习者将直观感受Struts2的请求处理流程:从客户端发送请求,到Filter拦截、Action处理、结果视图渲染的全链路逻辑。

在配置相关章节,课程会深入解析struts.xml的核心配置项,包括package、action、result的作用与配置规范,帮助学习者掌握框架的“控制中枢”。Action类的定义与多方法访问部分,将重点讲解如何通过继承ActionSupport类简化开发,以及如何通过通配符配置实现一个Action处理多个请求的技巧,这对提升代码复用率至关重要。

值得关注的是“Action中访问ServletAPI”章节。尽管Struts2提倡解耦设计,但实际开发中仍可能需要直接访问HttpServletRequest、HttpSession等对象。课程将介绍三种主流访问方式(ServletActionContext、实现特定接口、依赖注入),并分析各自的适用场景与优缺点。

请求参数的接收与封装是Web开发的基础需求。课程会讲解基本类型参数、对象参数、集合参数的封装方法,特别强调“模型驱动”与“属性驱动”两种模式的差异,帮助学习者根据业务场景选择最优方案。

第二阶段:高级特性与实战应用

进阶阶段聚焦Struts2的核心特性,旨在培养学习者解决复杂问题的能力。拦截器作为框架的“神经中枢”,课程将首先解析其工作原理与执行流程,详细介绍内置拦截器(如params、validation、fileUpload)的功能与配置方法。在此基础上,重点讲解自定义拦截器的开发步骤——从接口实现、配置注册到参数传递,结合日志记录、权限校验等实际案例,演示如何通过拦截器实现功能扩展。

国际化(i18n)是企业级应用的常见需求。课程将系统讲解Struts2的国际化实现方案,包括资源文件的命名规范、页面标签的使用方法,以及如何根据客户端语言自动切换资源。通过实际案例,学习者将掌握多语言表单提示、错误信息、界面文本的动态展示技术。

OGNL(对象图导航语言)与ValueStack(值栈)是Struts2的数据处理核心。课程将深入解析OGNL的语法特性(如属性访问、方法调用、投影选择),以及ValueStack的双层结构(栈顶对象与上下文对象)。通过大量示例,演示如何在JSP页面中使用OGNL表达式访问值栈数据,如何通过Action向值栈压入对象,这对实现视图与模型的高效数据交互至关重要。

数据校验与文件上传下载是Web应用的高频需求。课程将介绍Struts2的两种校验方式(基于XML的声明式校验与基于注解的编程式校验),并结合业务场景讲解校验规则的配置技巧。文件上传部分,重点讲解内置拦截器的配置参数(如文件大小、允许的文件类型),以及如何在Action中获取上传文件的元数据(文件名、类型、字节流),实现文件存储与处理。

最后,课程将系统讲解Struts2常用标签的使用方法,包括控制标签(if/else、iterator)、数据展示标签(property、text)、表单标签(form、input、select)等。通过实际页面开发案例,演示如何利用标签简化JSP代码,提升视图层的可维护性。

学习Struts2能带来哪些能力提升?

完成本课程学习后,开发者将具备三方面核心能力:一是熟练使用Struts2完成Web应用的全流程开发,包括需求分析、框架搭建、功能实现与调试优化;二是深入理解MVC设计模式的本质,能根据业务需求选择合适的框架或自定义架构;三是掌握拦截器、OGNL、值栈等高级技术,具备扩展框架功能、解决复杂开发问题的能力。这些能力不仅能直接应用于实际项目,更能为后续学习SpringMVC、MyBatis等框架奠定坚实基础。

沈阳叩丁狼教育

沈阳叩丁狼教育
认证 7 年

成立: 2006年

认证 地址认证 教学保障 在线预约 到店体验 售后支持
基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-04-06 00:33:09 HTTP/1.1 GET : http://www.aabqn.com/s/3698/c/55213.html
  2. 运行时间 : 0.062236s [ 吞吐率:16.07req/s ] 内存消耗:387.54kb 文件加载: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.000362s ] mysql:host=127.0.0.1;port=3306;dbname=baijiao_branch_collect;charset=utf8
  2. SHOW FULL COLUMNS FROM `fqi_school` [ RunTime:0.001276s ]
  3. SELECT * FROM `fqi_school` WHERE `school_id` = '3698' AND `site_id` = 18 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000308s ]
  4. SHOW FULL COLUMNS FROM `fqi_school_class` [ RunTime:0.000676s ]
  5. SELECT * FROM `fqi_school_class` WHERE `school_id` = 3698 [ RunTime:0.000230s ]
  6. SHOW FULL COLUMNS FROM `fqi_school_campus` [ RunTime:0.000702s ]
  7. SELECT * FROM `fqi_school_campus` WHERE `school_id` = 3698 [ RunTime:0.000256s ]
  8. SHOW FULL COLUMNS FROM `fqi_school_course` [ RunTime:0.000716s ]
  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` = 3698 AND `a`.`content_id` = '55213' AND `course_status` = 1 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000694s ]
  10. (select content_id,course_name from fqi_school_course where school_id = '3698' and content_id < '55213' and site_id = '18' order by content_id desc limit 1) union all(select content_id,course_name from fqi_school_course where school_id = '3698' and content_id > '55213' and site_id <= '18' order by content_id asc limit 1) [ RunTime:0.001299s ]
  11. SELECT * FROM `fqi_school_course` WHERE `school_id` = 3698 AND `site_id` = 18 AND `course_status` = 1 AND `school_status` = 1 AND `school_class_id` = 13957 ORDER BY `course_id` DESC LIMIT 4 [ RunTime:0.000432s ]
  12. SELECT * FROM `fqi_school_course` WHERE `school_id` = 3698 AND `site_id` = 18 AND `course_status` = 1 AND `school_status` = 1 ORDER BY `course_id` DESC LIMIT 10 [ RunTime:0.000255s ]
  13. SELECT COUNT(*) AS think_count FROM `fqi_school_course` WHERE `school_id` = 3698 AND `course_status` = 1 [ RunTime:0.000203s ]
  14. SHOW FULL COLUMNS FROM `fqi_school_teacher` [ RunTime:0.000661s ]
  15. SELECT COUNT(*) AS think_count FROM `fqi_school_teacher` WHERE `school_id` = '3698' [ RunTime:0.000227s ]
  16. SHOW FULL COLUMNS FROM `fqi_school_comments` [ RunTime:0.000585s ]
  17. SELECT COUNT(*) AS think_count FROM `fqi_school_comments` WHERE `school_id` = '3698' [ RunTime:0.000224s ]
  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` = '18' AND `b`.`school_status` = '1' AND `course_status` = 1 AND `course_id` < '55213' ORDER BY `content_id` DESC LIMIT 20 [ RunTime:0.048413s ]
0.062576s