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

400-689-2779

Oracle数据库集群技术全栈学习指南:从架构原理到实战运维的深度解析

Oracle数据库集群技术全栈学习指南:从架构原理到实战运维的深度解析

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

上课地点: 校区地址

成交/评价:

联系电话: 400-689-2779

Oracle数据库集群技术全栈学习指南:从架构原理到实战运维的深度解析课程详情

Oracle数据库集群技术全栈学习指南

一、RAC基础体系:从架构认知到环境搭建

企业级数据库部署中,Oracle Real Application Clusters(RAC)是解决高并发、高可用需求的核心技术。要掌握这一体系,首先需建立对RAC架构的完整认知。RAC通过多节点共享存储的方式,实现数据库服务的横向扩展,其核心价值体现在业务连续性保障与资源利用率提升两大场景——前者适用于金融、电商等不能容忍中断的行业,后者则帮助企业降低硬件成本。

环境搭建阶段需重点关注三个维度:存储配置、主机规划与软件安装。存储层面,RAC依赖共享存储(如SAN、NAS或ASM)实现数据一致性,需明确磁盘组类型(外部冗余、正常冗余或高冗余)对数据安全的影响;主机配置需规划节点数量、网络拓扑(公共网络与私有网络分离)及IP地址分配;软件安装前需完成操作系统参数调优(如内核参数、用户限制),避免因基础配置问题导致集群不稳定。

以某电商企业的RAC部署案例为例,其初期因未正确规划私有网络带宽,导致节点间心跳通信延迟,最终影响业务交易响应速度。这一案例充分说明,环境搭建的每一步都需结合实际业务场景进行详细规划。

二、RAC运行机制:从原理到数据一致性保障

理解RAC的运行原理,关键在于把握Cluster Ready Services(CRS)与Cache Fusion两大核心机制。CRS作为集群管理的基础服务,负责节点状态监控、资源启动/停止及故障转移,其依赖的OCR(Oracle Cluster Registry)和Vote Disk文件是集群的“神经中枢”,任何损坏都可能导致集群瘫痪。

Cache Fusion技术则是RAC实现多节点数据共享的关键。当一个节点修改数据块时,通过私有网络将变更信息传递至其他节点,确保所有节点缓存的一致性。这一过程涉及数据块锁定、消息传递及版本管理,需重点关注Latch竞争、网络延迟对性能的影响。

在数据一致性保障方面,RAC通过Global Enqueue Service(GES)管理全局锁,避免多节点同时修改同一数据块引发的冲突。实际运维中,常见的问题包括全局锁等待超时、Cache Fusion消息积压,需结合AWR报告分析具体原因。

三、RAC高可用性:从故障切换到业务无感知

高可用性是RAC的核心卖点,其实现依赖节点VIP切换、TAF(Transparent Application Failover)及Service资源管理三大机制。节点VIP切换通过虚拟IP地址重绑定,确保客户端连接在节点故障时快速指向健康节点;TAF则在应用层实现故障转移,支持会话恢复(Session Failover)和事务恢复(Transaction Failover)两种模式,需根据业务类型选择合适策略。

Service资源管理允许将不同业务负载分配至特定节点组,结合动态注册功能实现负载均衡。例如,某银行核心交易系统通过配置Service,将查询类操作导向低负载节点,交易类操作导向高性能节点,有效提升了整体吞吐量。

实战中,需重点测试故障切换的时效性。根据Oracle官方建议,节点故障后VIP切换应在30秒内完成,TAF恢复时间需控制在2秒以内。若超时,需检查私有网络延迟、CRS监控参数(如gipc.timeout)设置是否合理。

【实战要点】LBA(Load Balancing Advisory)配置可通过srvctl工具实现,需结合业务高峰时段的负载数据调整权重;FAILOVER测试需模拟节点宕机(如关闭CRS服务),观察客户端连接是否自动重定向,日志是否记录完整的切换过程。

四、ASM存储管理:从原理到生产环境实践

Automatic Storage Management(ASM)是RAC的存储搭档,其通过将物理磁盘抽象为磁盘组,实现自动条带化、镜像及故障恢复,简化了存储管理复杂度。ASM实例独立于数据库实例运行,负责管理磁盘组元数据、分配扩展区(Extent)并监控磁盘健康状态。

理解ASM的逻辑结构需掌握三个概念:磁盘组(Disk Group)、故障组(Failure Group)和条带化(Stripe)。磁盘组是存储的逻辑容器,故障组用于定义磁盘的冗余边界(如同一存储阵列的不同控制器),条带化则通过将数据分散存储提升IO性能。实际部署中,建议为OCR/Vote Disk、数据文件、日志文件分别创建独立磁盘组,避免资源竞争。

生产环境中,ASM的常见运维场景包括磁盘组扩容、故障磁盘替换及同步恢复。当某块磁盘出现坏道时,ASM会自动将数据从镜像副本恢复至新磁盘,这一过程需监控ASM实例的alert日志,确认恢复进度及是否存在性能波动。此外,ASMCMD工具(如asmcmd lsdg、asmcmd lsdisk)是日常管理的核心工具,需熟练掌握其操作命令。

五、RAC运维优化:从日常巡检到性能调优

RAC集群的稳定运行依赖规范化的运维流程。日常巡检需重点关注CRS服务状态(通过crsctl check cluster命令)、OCR/Vote Disk健康度(ocrcheck、votedisk命令)及ASM磁盘组冗余状态(asmcmd lsdg -l)。此外,数据库层面需监控AWR报告中的关键指标,如Cache Fusion消息量、Global Enqueue等待时间、主机CPU/内存使用率。

性能优化需结合具体场景。对于OLTP系统,需减少Global Enqueue竞争(如优化索引设计、避免大事务);对于OLAP系统,可调整Cache Fusion参数(如_gcs_server_processes)提升数据共享效率。某制造企业通过调整ASM条带化策略(将条带大小从1MB改为4MB),将报表查询性能提升了30%,这一案例验证了存储配置对整体性能的关键影响。

【实战操作】节点扩缩容是RAC运维的高阶技能。增加节点时,需先准备新主机环境(安装Oracle软件、配置共享存储),再通过srvctl add node命令加入集群;删除节点前需迁移该节点的Service资源,避免业务中断。操作过程中需严格遵循Oracle官方文档的步骤,确保元数据(如OCR)同步更新。

总结:构建RAC技术能力的关键路径

掌握Oracle数据库集群技术,需从“架构认知-原理理解-实战操作-运维优化”四个维度逐步深入。建议学习者先通过实验环境搭建2节点RAC集群,熟悉基础操作;再结合企业实际场景,针对高可用配置、性能瓶颈分析等难点进行专项突破;最终通过持续的生产环境实践,形成系统的技术能力体系。

无论您是数据库管理员、运维工程师,还是开发人员,掌握RAC与ASM核心技术都将为职业发展带来显著优势。本文覆盖的技术要点与实战案例,将为您的学习提供清晰的路径指引。

南京柯普瑞IT学校

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

成立: 2006年

认证 地址认证 教学保障 在线预约 到店体验 售后支持
基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-04-04 18:00:27 HTTP/1.1 GET : http://www.aabqy.com/s/1037/c/43853.html
  2. 运行时间 : 0.058525s [ 吞吐率:17.09req/s ] 内存消耗:397.68kb 文件加载: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.000330s ] mysql:host=127.0.0.1;port=3306;dbname=baijiao_branch_collect;charset=utf8
  2. SHOW FULL COLUMNS FROM `fqi_school` [ RunTime:0.001029s ]
  3. SELECT * FROM `fqi_school` WHERE `school_id` = '1037' AND `site_id` = 23 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000285s ]
  4. SHOW FULL COLUMNS FROM `fqi_school_class` [ RunTime:0.000639s ]
  5. SELECT * FROM `fqi_school_class` WHERE `school_id` = 1037 [ RunTime:0.000221s ]
  6. SHOW FULL COLUMNS FROM `fqi_school_campus` [ RunTime:0.000640s ]
  7. SELECT * FROM `fqi_school_campus` WHERE `school_id` = 1037 [ RunTime:0.000230s ]
  8. SHOW FULL COLUMNS FROM `fqi_school_course` [ RunTime:0.000696s ]
  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` = '43853' AND `course_status` = 1 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000701s ]
  10. (select content_id,course_name from fqi_school_course where school_id = '1037' and content_id < '43853' 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 > '43853' and site_id <= '23' order by content_id asc limit 1) [ RunTime:0.001246s ]
  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` = 4197 ORDER BY `course_id` DESC LIMIT 4 [ RunTime:0.000393s ]
  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.000875s ]
  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.000653s ]
  15. SELECT COUNT(*) AS think_count FROM `fqi_school_teacher` WHERE `school_id` = '1037' [ RunTime:0.000194s ]
  16. SHOW FULL COLUMNS FROM `fqi_school_comments` [ RunTime:0.000605s ]
  17. SELECT COUNT(*) AS think_count FROM `fqi_school_comments` WHERE `school_id` = '1037' [ RunTime:0.000196s ]
  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` < '43853' ORDER BY `content_id` DESC LIMIT 20 [ RunTime:0.044812s ]
0.058844s