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

400-689-2779

Linux shell脚本编程全解析:从基础语法到实战应用的系统指南

Linux shell脚本编程全解析:从基础语法到实战应用的系统指南

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

上课地点: 校区地址

成交/评价:

联系电话: 400-689-2779

Linux shell脚本编程全解析:从基础语法到实战应用的系统指南课程详情

Linux shell脚本编程全解析:从基础语法到实战应用的系统指南

一、shell基础认知与环境搭建

作为Linux系统与用户交互的关键桥梁,shell的重要性在自动化运维、批量任务处理中尤为突出。要深入掌握脚本编程,首先需要理解其发展脉络与技术分类。从早期的Bourne Shell(sh)到当前主流的Bash(Bourne-Again Shell),shell经历了多代演进,衍生出C Shell、Korn Shell等不同分支,其中Bash凭借强大的兼容性和扩展能力,成为大多数Linux发行版的默认选择。

Bash的核心优势体现在命令补全、历史记录追踪、别名定义等实用功能上。搭建Bash开发环境时,需注意配置.profile或.bashrc文件,通过设置PS1变量定制命令行提示符,调整HISTSIZE参数优化历史命令存储策略。对于脚本文件,其基本结构通常包含Shebang声明(#!/bin/bash)、注释说明及具体执行逻辑,常见的执行方式包括直接调用解释器(bash script.sh)、赋予执行权限后直接运行(./script.sh)等。

在调试环节,可通过sh -x script.sh开启追踪模式,结合echo命令输出变量状态,快速定位逻辑错误。此外,理解父shell与子shell的进程关系至关重要——子shell运行脚本时会继承父shell的环境变量,但对变量的修改不会影响父进程,这一特性在多脚本协作场景中需特别注意。

二、变量操作与字符串处理进阶

变量是shell脚本的数据基石,其分类可从作用域(全局/局部)、类型(标量/数组)两个维度划分。内置变量如$?(上条命令退出状态)、$$(当前进程PID)是脚本调试的重要工具,预定义变量$0(脚本名)、$1(个参数)则广泛应用于参数传递场景。自定义变量需遵循“变量名=值”的赋值规则,注意等号两侧不可有空格,通过unset命令可实现变量销毁。

数组操作在批量数据处理中不可或缺,Bash支持索引数组(如arr=(a b c))和关联数组(需启用declare -A声明),通过${arr[index]}获取元素,${#arr[@]}统计元素个数。特殊字符处理需掌握转义规则,例如用反斜杠\转义$、!等符号,或通过双引号保持空格完整性。Here Document(<<)则是多行输入的高效解决方案,常见于生成配置文件或日志输出。

字符串操作的核心在于变量扩展机制:${var:-default}实现空值默认替换,${var:start:length}完成子串截取,${var#pattern}执行前缀删除。结合${#var}获取字符串长度,可构建复杂的文本处理逻辑。命令替换($(command))则允许将命令输出赋值给变量,例如dir=$(ls)获取当前目录文件列表。

三、流程控制与函数设计

脚本的逻辑分支依赖if和case结构实现。if语句通过[条件表达式]或test命令判断,支持文件测试(-f检查文件存在)、数值比较(-gt大于)、字符串匹配(=等于)等场景。case语句适用于多条件匹配,语法结构为case $var in pattern1) ... ;; pattern2) ... ;; esac,特别适合处理用户输入的菜单选择场景。

循环结构包含for、while、until三种类型。for循环常用于遍历列表(for i in list; do ... done),while通过条件判断持续执行(while condition; do ... done),until则在条件不满足时循环(until ! condition; do ... done)。select命令结合了循环与菜单功能,可快速生成交互式选项。break和continue分别用于终止当前循环和跳过本次迭代,配合嵌套循环时需注意作用范围。

函数是代码复用的关键,定义格式为function_name() { ... }。通过$1-$9传递参数,$#统计参数数量,return命令设置返回值(0表示成功)。函数作用域默认全局,可通过local关键字声明局部变量避免冲突。递归函数在目录遍历、数学计算中应用广泛,例如计算阶乘时可定义fact() { if [ $1 -eq 0 ]; then echo 1; else echo $(( $1 * $(fact $(( $1 - 1 )) )) ); fi; }。

四、高级工具与实战应用

正则表达式是文本处理的核心工具,元字符如.(任意字符)、*(零次或多次)、+(一次或多次)构建匹配规则。字符类[abc]匹配任意字符,^取反形成[^abc],分组()用于捕获子模式,后向引用\1引用个分组内容。零宽断言如(?=pattern)正向预查,可实现位置匹配而不消耗字符。实际应用中,grep -E或egrep命令支持扩展正则,配合-v反向匹配、-n显示行号,能高效完成日志分析、数据筛选等任务。

sed(流编辑器)和awk(文本处理语言)是shell环境下的两大神器。sed通过地址范围(如1,5)和命令(s替换、d删除)实现行级操作,例如sed 's/old/new/g' file替换所有old为new。awk按字段处理文本,默认以空格分隔,通过$1访问个字段,配合BEGIN/END块处理头尾部逻辑,例如awk 'BEGIN{sum=0} {sum+=$3} END{print sum}' file统计第三列总和。两者结合可完成从日志解析到数据报表生成的全流程任务。

网络编程场景中,Bash通过/dev/tcp/host/port实现TCP连接,例如echo "GET /" > /dev/tcp/www.example.com/80获取网页内容。expect工具则能自动处理交互式登录,通过spawn启动会话,expect匹配提示信息,send发送响应,实现SSH自动登录、FTP批量上传等操作。脚本加密可通过shc工具生成二进制可执行文件,或使用openssl进行AES加密,保护核心业务逻辑。

五、常用命令与效率提升

掌握核心命令是提升脚本效率的关键。grep配合正则表达式实现内容搜索,find结合xargs处理批量文件操作(如find . -name "*.log" -print0 | xargs -0 rm删除所有日志文件)。sort按字段排序,uniq去除重复行,cut按列提取数据,curl/wget实现网络资源下载。tr用于字符转换(tr 'a-z' 'A-Z'转大写),paste合并文件列,join按公共字段连接文件,这些命令的灵活组合能解决90%以上的日常运维需求。

快捷键的使用习惯直接影响开发效率,Ctrl+A跳转到行首,Ctrl+E到行尾,Ctrl+U删除至行首,Ctrl+K删除至行尾,Alt+B/Alt+F单词级回退/前进,这些操作能显著减少鼠标依赖。此外,通过alias命令定义常用指令别名(如alias ll='ls -l'),可进一步提升操作流畅度。

南京柯普瑞IT学校

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

成立: 2006年

认证 地址认证 教学保障 在线预约 到店体验 售后支持
基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-04-04 15:00:59 HTTP/1.1 GET : http://www.aabqy.com/s/1037/c/43786.html
  2. 运行时间 : 0.061247s [ 吞吐率:16.33req/s ] 内存消耗:393.84kb 文件加载: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.000861s ]
  3. SELECT * FROM `fqi_school` WHERE `school_id` = '1037' AND `site_id` = 23 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000243s ]
  4. SHOW FULL COLUMNS FROM `fqi_school_class` [ RunTime:0.000595s ]
  5. SELECT * FROM `fqi_school_class` WHERE `school_id` = 1037 [ RunTime:0.000206s ]
  6. SHOW FULL COLUMNS FROM `fqi_school_campus` [ RunTime:0.000615s ]
  7. SELECT * FROM `fqi_school_campus` WHERE `school_id` = 1037 [ RunTime:0.000197s ]
  8. SHOW FULL COLUMNS FROM `fqi_school_course` [ RunTime:0.000650s ]
  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` = '43786' AND `course_status` = 1 AND `school_status` = 1 LIMIT 1 [ RunTime:0.000781s ]
  10. (select content_id,course_name from fqi_school_course where school_id = '1037' and content_id < '43786' 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 > '43786' and site_id <= '23' order by content_id asc limit 1) [ RunTime:0.001485s ]
  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.000439s ]
  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.000863s ]
  13. SELECT COUNT(*) AS think_count FROM `fqi_school_course` WHERE `school_id` = 1037 AND `course_status` = 1 [ RunTime:0.000255s ]
  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.000196s ]
  16. SHOW FULL COLUMNS FROM `fqi_school_comments` [ RunTime:0.000609s ]
  17. SELECT COUNT(*) AS think_count FROM `fqi_school_comments` WHERE `school_id` = '1037' [ RunTime:0.000225s ]
  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` < '43786' ORDER BY `content_id` DESC LIMIT 20 [ RunTime:0.048322s ]
0.061572s