• 提供相应学习目标和学习内容;
  • 贴身打造专属于考生个人教学学习计划;
  • 帮助考生实现复习时间合理分配和高效利用。

400-018-6228

计算机考研操作系统核心考点:虚拟内存知识体系全解析

来源:贵阳中公考研 时间:05-18

计算机考研操作系统核心考点:虚拟内存知识体系全解析

计算机考研操作系统核心考点:虚拟内存知识体系全解析

操作系统模块的关键突破口:为什么虚拟内存是必考点?

在计算机考研的专业课复习中,操作系统向来是区分度较高的模块。而虚拟内存作为操作系统内存管理的核心机制,不仅是各类高校历年真题的高频考点,更是理解现代计算机系统运行逻辑的重要切入点。从基础概念到实现细节,从理论原理到实际应用,虚拟内存的知识体系贯穿了内存管理、进程调度、外存交互等多个子模块,掌握这一内容对构建完整的操作系统知识框架具有关键作用。

理解虚拟内存的理论基石:局部性原理详解

要深入掌握虚拟内存机制,首先需要理解其背后的理论支撑——局部性原理。这一原理揭示了程序运行时内存访问的基本规律,是虚拟内存得以高效运作的核心依据。

时间局部性:重复访问的内在逻辑

程序运行中,某些指令或数据会在短时间内被多次访问,这种现象即为时间局部性。最典型的例子是循环结构:例如一个计算数组总和的循环,循环体内的累加指令会被反复执行;或者一个频繁调用的函数,其对应的代码段会在短时间内被多次访问。这种特性使得操作系统可以将近期使用过的内容保留在内存中,避免频繁的外存调入操作,从而提升运行效率。

空间局部性:连续访问的底层规律

除了时间维度的重复访问,程序在空间维度上也表现出明显的连续性。当程序访问某个内存地址后,接下来访问其相邻地址的概率会显著增加。例如遍历一个一维数组时,程序会依次访问数组的每一个元素,这些元素在内存中是连续存放的;或者执行顺序代码时,CPU会按地址顺序读取指令。这种特性使得操作系统可以采用“预取”策略,将当前访问位置附近的内容一并加载到内存中,减少后续的缺页中断次数。

虚拟内存的运行机制:动态调入调出的底层逻辑

基于局部性原理,虚拟内存打破了“程序必须全量加载到内存才能运行”的传统限制,通过动态的调入调出机制,实现了内存资源的高效利用。其核心流程可概括为三个关键步骤:

1. 部分加载启动运行

程序启动时,操作系统仅将当前执行所需的部分代码和数据加载到内存中,其余内容仍保留在外存(如硬盘)。这种“按需加载”的方式显著减少了内存占用,使得更多程序可以同时运行。

2. 缺页触发调入操作

当程序执行到未加载到内存的指令或数据时(即发生“缺页中断”),操作系统会暂停当前程序,转而执行缺页中断处理程序。该程序会在外存中找到所需内容的存储位置,然后将其调入内存。

3. 内存不足时置换腾出空间

若调入新内容时内存已无空闲空间,操作系统会根据特定的置换算法(如LRU最近最少使用算法),选择内存中暂时不用的页面置换到外存,腾出空间后再完成新内容的调入。这一过程在程序运行中可能反复发生,确保内存始终存放最急需的内容。

虚拟内存的实现基础:软硬件协同的技术支撑

虚拟内存的高效运行依赖于硬件和软件的协同配合。缺少任何一方的支持,这一机制都无法正常工作。

硬件层面的必要条件

(1)足够容量的内存:用于存放当前运行所需的程序和数据,其大小直接影响系统能同时运行的程序数量。
(2)大容量外存支持:作为内存的扩展,外存(如硬盘、SSD)需要提供足够的空间存储程序的其余部分,其访问速度虽慢但容量远大于内存。
(3)地址变换机构:包括页表寄存器、快表(TLB)等组件,负责将程序使用的虚拟地址转换为实际的物理地址。快表的存在可以显著提升地址转换速度,减少访问延迟。
(4)缺页中断机构:当访问的页面不在内存时,硬件需要能够检测到这一情况并触发中断,通知操作系统进行处理。

软件层面的关键支持

(1)虚实转换数据结构:如页表、段表等,这些数据结构记录了虚拟地址与物理地址的映射关系,是地址变换的核心依据。页表通常存储在内存中,操作系统通过维护页表的状态(如有效位、修改位)来管理页面的调入调出。
(2)中断服务处理程序:当发生缺页中断时,操作系统需要执行特定的中断处理程序,完成页面的调入或置换操作。这一程序需要高效处理各种边界情况(如页面置换时的写回外存),确保系统的稳定性。
(3)操作系统整体支持:虚拟内存机制并非独立存在,而是与进程管理、文件系统等模块紧密配合。例如,当页面需要从外存调回时,需要文件系统提供外存空间的访问接口;进程切换时,需要保存和恢复页表寄存器等上下文信息。

虚拟内存的三大核心特征:理解其本质的关键

通过前面的分析可以看出,虚拟内存机制具有区别于传统内存管理方式的显著特征,这些特征正是其高效性和灵活性的来源。

特征一:多次性——分阶段加载的运行模式

与早期“一次性加载所有内容”的内存管理方式不同,虚拟内存允许程序分多次加载到内存中。程序启动时仅加载必要部分,后续根据运行需要逐步加载剩余内容。这种模式大幅降低了内存的初始占用,使得内存资源可以被更高效地分配给多个程序。

特征二:对换性——内存外存的动态交互

虚拟内存机制下,内存与外存之间不再是单向的“加载”关系,而是双向的“对换”关系。暂时不用的内容会被置换到外存,需要时再调回内存。这种动态交互使得系统可以根据当前运行状态灵活调整内存使用,避免资源浪费。

特征三:虚拟性——突破物理限制的用户体验

虚拟内存革命性的特征在于其“虚拟性”。通过软硬件协同,用户感知到的内存空间(虚拟地址空间)远大于实际的物理内存大小。例如,一台物理内存为8GB的计算机,可能为每个程序提供4GB甚至更大的虚拟地址空间。这种“内存扩展”的效果,极大提升了程序的运行灵活性,使得大型应用的开发和运行成为可能。

备考建议:如何高效掌握虚拟内存知识点?

对于计算机考研学子而言,掌握虚拟内存知识点需注重“理论+实践”的结合:

(1)深入理解底层原理:重点把握局部性原理的具体表现、虚拟内存的运行流程、地址变换的具体过程,避免死记硬背,注重逻辑推导。
(2)结合经典例题训练:通过分析历年真题中的虚拟内存相关题目(如缺页率计算、页面置换算法应用),掌握知识点的实际应用场景。
(3)构建知识关联网络:将虚拟内存与进程管理(如上下文切换时的页表操作)、文件系统(如页面在外存的存储位置)等模块联系起来,理解操作系统各组件的协同工作机制。

校区导航
基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-04-04 12:41:36 HTTP/1.1 GET : http://www.aabqj.com/s/5668/n/32959.html
  2. 运行时间 : 0.021261s [ 吞吐率:47.03req/s ] 内存消耗:391.73kb 文件加载: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.000340s ] mysql:host=127.0.0.1;port=3306;dbname=baijiao_branch_collect;charset=utf8
  2. SHOW FULL COLUMNS FROM `fqi_school` [ RunTime:0.001169s ]
  3. SELECT * FROM `fqi_school` WHERE `school_id` = '5668' AND `site_id` = 17 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000304s ]
  4. SHOW FULL COLUMNS FROM `fqi_school_class` [ RunTime:0.000627s ]
  5. SELECT * FROM `fqi_school_class` WHERE `school_id` = 5668 [ RunTime:0.000255s ]
  6. SHOW FULL COLUMNS FROM `fqi_school_campus` [ RunTime:0.000647s ]
  7. SELECT * FROM `fqi_school_campus` WHERE `school_id` = 5668 [ RunTime:0.000278s ]
  8. SHOW FULL COLUMNS FROM `fqi_school_news` [ RunTime:0.000789s ]
  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` = 5668 AND `a`.`content_id` = '32959' AND `news_status` = 1 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000664s ]
  10. (select content_id,news_name,school_id from fqi_school_news where school_id = '5668' and content_id < '32959' and site_id <= '17' order by content_id desc limit 1) union all(select content_id,news_name,school_id from fqi_school_news where school_id = '5668' and content_id > '32959' and site_id <= '17' order by content_id asc limit 1) [ RunTime:0.000757s ]
  11. SHOW FULL COLUMNS FROM `fqi_school_course` [ RunTime:0.000744s ]
  12. SELECT * FROM `fqi_school_course` WHERE `school_id` = 5668 AND `site_id` = 17 AND `course_status` = 1 AND `school_status` = 1 ORDER BY `course_id` DESC LIMIT 4 [ RunTime:0.000534s ]
  13. SELECT * FROM `fqi_school_course` WHERE `school_id` = 5668 AND `school_status` = 1 AND `course_status` = 1 ORDER BY `course_id` DESC LIMIT 8 [ RunTime:0.000239s ]
  14. SELECT * FROM `fqi_school_news` WHERE `school_id` = 5668 ORDER BY `click` DESC,`news_id` DESC LIMIT 5 [ RunTime:0.000156s ]
  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` = '17' AND `b`.`school_status` = '1' AND `news_status` = 1 AND `content_id` < 32959 ORDER BY `content_id` DESC LIMIT 20 [ RunTime:0.008499s ]
0.021773s