MySQL中SELECT语句的基本语法是: SELECT [STRAIGHT_JOIN] [SQL_SMALL_RESULT] [SQL_BIG_RESULT] [HIGH_PRIORITY] [DISTINCTDISTINCTROWALL] select_list [INTO {OUTFILEDUMPFILE} 'file_name' export_options] [FROM table_references [WHERE where_definition] [GROUP BY col_name,...] [HAVING where_definition] [ORDER BY {unsighed_integercol_nameformura} [ASCDESC],...] [LIMIT [offset,] rows] [PROCEDURE procedure_name]] 从这个基本语法可以看出,最简单的SELECT语句是SELECT select_list,实际上利用这个最简单的SELECT语句,你也可以完成许多你期待的功能,首先你能利用它进行MySQL所支持的任何运算,例如:SELECT 1+1,它将返回2;其次,你也能利用它给变量赋值,而在PHP中,运用SELECT语句的这种功能,你就可以自由地运用MySQL的函数为PHP程序进行各种运算,并赋值给变量。在很多的时候,你会发现MySQL拥有许多比PHP更为功能强大的函数。 STRAIGHT_JOIN、SQL_SMALL_RESULT、SQL_BIG_RESULT、HIGH_PRIORITY是MySQL对ANSI SQL92的扩展。如果优化器以非最佳次序联结表,使用STRAIGHT_JOIN可以加快查询。 SQL_SMALL_RESULT和SQL_BIG_RESULT是一组相对的关键词。它们必须与GROUP BY、DISTINCT或DISTINCTROW一起使用。SQL_SMALL_RESULT告知优化器结果会很小,要求MySQL使用临时表存储最终的表而不是使用排序;反之,SQL_BIG_RESULT告知优化器结果会很小,要求MySQL使用排序而不是做临时表。 HIGH_PRIORITY将赋予SELECT比一个更新表的语句更高的优先级,使之可以进行一次优先的快速的查询。 以上四个关键词的使用方法的确比较晦涩。幸运的是,在绝大多数情况下,在MySQL中我们完全可以选择不使用这四个关键词。 DISTINCT、DISTINCTROW对查询返回的结果集提供了一个最基本但是很有用的过滤。那就是结果集中只含非重复行。在这里要注意的是,对关键词DISTINCT、DISTINCTROW来说,空值都是相等的,无论有多少NULL值,只选择一个。而ALL的用法就有画蛇添足之嫌了。它对结果集的产生没有任何影响。 INTO {OUTFILEDUMPFILE} 'file_name' export_options,将结果集写入一个文件。文件在服务器主机上被创建,并且不能是已经存在的。语句中的export_options部分的语法与用在LOAD DATAINFILE语句中的FIELDS和LINES子句中的相同,我们将在MySQL进阶_LOAD DATA篇中详细讨论它。而OUTFILE与DUMPFILE的关键字的区别是:后前只写一行到文件,并没有任何列或行结束。

mysql select 进阶_MySQL进阶_SELECT篇(一)相关推荐

  1. mysql function select 赋值_MySql 进阶

    多表查询 修改表poetry_item,增加 user_id字段 mysql> ALTER table `poetry_item` ADD `user_id` varchar(30) COLLA ...

  2. mysql select语法_MySQL SELECT语法(一)SELECT语法详解

    SELECT的语法如下: SELECT[ALL | DISTINCT | DISTINCTROW ] [HIGH_PRIORITY] [STRAIGHT_JOIN] [SQL_SMALL_RESULT ...

  3. mysql select表达式_MySQL数据库SELECT查询表达式解析

    数据的管理在很大一部分是在进行查找工作,而SELECT占据了很大的一部分 SELECT select_expr [,select_expr...] [ FROM table_reference WHE ...

  4. mysql select 缓存_mysql select缓存机制使用详解

    mysql Query Cache 默认为打开.从某种程度可以提高查询的效果,但是未必是最优的解决方案,如果有的大量的修改和查询时,由于修改造成的cache失效,会给服务器造成很大的开销,可以通过qu ...

  5. mysql select 使用_mysql select简单用法

    mysql select简单用法 1.select语句可以用回车分隔 $sql=select * from article where id=1 和 $sql=select * from articl ...

  6. mysql select效率_Mysql优化之selectcount效率_MySQL

    bitsCN.com 1.任何情况下SELECT COUNT(*) FROM tablename是最优选择: 2.尽量减少SELECT COUNT(*) FROM tablename WHERE CO ...

  7. mysql 进阶_mysql进阶 - 随笔分类 - 云潇洒 - 博客园

    随笔分类 - mysql进阶 1 摘要:防御SQL注入的方法总结 这篇文章主要讲解了防御SQL注入的方法,介绍了什么是注入,注入的原因是什么,以及如何防御,需要的朋友可以参考下. SQL注入是一类危害 ...

  8. mysql revoke 用法_mysql进阶(二十八)MySQL GRANT REVOKE用法

    mysql进阶(二十八)MySQL GRANT REVOKE用法 MySQL的权限系统围绕着两个概念: 认证->确定用户是否允许连接数据库服务器: 授权->确定用户是否拥有足够的权限执行查 ...

  9. mysql游标进阶_mysql进阶(三)游标简易教程

    mysql游标简易教程 从mysql V5.5开始,进行了一次大的改变,就是将InnoDB作为默认的存储引擎.InnoDB支持事务,而且拥有相关的RDBMS特性:ACID事务支持,数据完整性(支持外键 ...

最新文章

  1. 2018中国AI英雄风云榜:投出你心目中的中国AI领军人!
  2. 学习编写用例是开发者走向项目经理的必经之路(《编写有效用例》书评) ——“Jolt大奖精选丛书”有奖征文...
  3. 关于核定区域电网2018—2019年输电价格的通知
  4. Selenium | 网上教程
  5. python输入input数组_Python学习——实现简单的交互raw_input的使用
  6. 6部BBC “教材级” 地理纪录片,有生之年必看系列!
  7. java 数据类型 string_java的基本数据类型和引用数据类型都有哪些,string属于什么类型...
  8. java自定义 filter,HBase自定义Filter
  9. vue中检测断网处理
  10. socket io 不使用redis_为什么Redis单线程能够达到数十万、百万级的QPS?
  11. java8获取路径_创建和读取目录
  12. excel进销存管理系统_美萍商业进销存软件—库存了如指掌
  13. load与DOMContentLoaded
  14. 计算器代码(C语言)
  15. window一键清理垃圾代码
  16. npstion实现通过手机扫描二维码向电脑录入信息
  17. Arcgis中修改属性字段名
  18. 腾讯TEG一面(电话面试)
  19. 计算机应用技术毕业后的简历,计算机应用技术毕业生个人简历模板
  20. rails相当于java中的什么_Rails中的ERB中的%,%=,%#和-%有什么区别?

热门文章

  1. OPPO 人像视频黑科技新鲜出炉,下月就换手机!
  2. 追新求快的时代,别让 Java Web 开发必备工具 Tomcat 变成“熟悉的陌生人”!
  3. 谷歌 AI 专家爆料:90% 的人都不知道,编程能力差,其实都是输在了这点上!...
  4. 原来 Kylin 的增量构建,大有学问! | 原力计划
  5. 天才程序员之陨落:业余项目创业 Cloudflare,公司上市前患病失去自理能力
  6. 如何用 Python 拆分表格并发送邮件?
  7. 软件欺诈的骗局揭露:“替罪羊”究竟是如何构建的?
  8. 稳定=死亡!废掉一个人的最好办法,就是让他瞎努力......
  9. 那位全心投入本地生活的首席科学家!
  10. 这些硬核公众号你知道几个?