`
cream
  • 浏览: 13554 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

MySQL数据库中的SELECT语句快速精细掌握

阅读更多
MySQL中SELECT语句的基本语法是:

  SELECT [STRAIGHT_JOIN] [SQL_SMALL_RESULT]

  [SQL_BIG_RESULT] [HIGH_PRIORITY]

  [DISTINCT|DISTINCTROW|ALL]

  select_list

  [INTO {OUTFILE|DUMPFILE} 'file_name' eXPort_options]

  [FROM table_references [WHERE where_definition]

  [GROUP BY col_name,...] [HAVING where_definition]

  [ORDER BY {unsighed_integer|col_name|formura} [ASC|DESC],...]

  [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 {OUTFILE|DUMPFILE} 'file_name' export_options,将结果集写入一个文件。文件在服务器主机上被创建,并且不能是已经存在的。语句中的eXPort_options部分的语法与用在LOAD DATAINFILE语句中的FieLDS和LINES子句中的相同,我们将在MySQL进阶_LOAD DATA篇中详细讨论它。而OUTFILE与DUMPFILE的关键字的区别是:后前只写一行到文件,并没有任何列或行结束。

  select list:其中可以包含一项或多项下列内容:

  1、“*”,表示按照create table的顺序排列的所有列。

  2、按照用户所需顺序排列的列名的清单。

  3、可以使用别名取代列名,形式如下:column name as column_heading。

  4、表达式(列名、常量、函数,或以算术或逐位运算符连接的列名、常量和函数的任何组合)。

  5、内部函数或集合函数。

  6、上述各项的任何一种组合。

  FROM:决定SELECT命令中使用哪些表。一般都要求有此项,除非select_list中不含列名(例如

,只有常量、算术表达式等)。如果表项中有多个表,用逗号将之分开。在关键词FROM后面的表的顺序不影响结果。

  表名可以给出相关别名,以便使表达清晰。这里的语法是tbl_name [AS] alias_name。例如:

  select t1.name,t2.salary from employee as t1,info as t2 where t1.name=t2.name与select t1.name,t2.salary from employee t1,info t2 where t1.name=t2.name是完全等价的。

  所有对该表的其他引用,例如在where子句和having子句中,都要用别名,别名不能以数字开头。

  where子句设置了搜索条件,它在insert,update,delete语句中的应用方法也与在select语句中的应用方法完全相同。搜索条件紧跟在关键词where的后面。如果用户要在语句中使用多个搜索条件,则可用and或 or连接。搜索条件的基本语法是[not] expression comparison_operator expression;[not] expression [not] like “match_string”;[not] expression is [not] null;[not] expression [not] between expression and expression;[not] column_name join_operator column_name;[not] boolean_eXPression。

  and:用来联结两个条件,并在两个条件都是TRUE的时候返回结果。当在同一语句中使用多个逻辑运算符时,and运算符总是最优先,除非用户用括号改变了运算顺序。

  or:用来联结两个条件,当两个条件中有任一条件是TRUE的时候返回结果。当在同一语句中使用多个逻辑运算符时,运算符or通常在运算符and之后进行运算。当然用户可以使用括号改变运算的顺序。

  between:用来标识范围下限的关键词,and后面跟范围上限的值。范围where @val between x and y包含首尾值。如果between后面指定的第一个值大于第二个值,则该查询不返回任何行。

  column_name:在比较中使用的列名。在会产生歧义时,一定要指明列所在的表名。

  comparison_operator:比较运算符。见下表:

  符号 意义

  = 等于

  > 大于

  < 小于

  >= 大于等于

  <= 小于等于

  != 不等于

  <> 不等于

  在比较char,varchar型数据时,“<”的意思是更接近字母表头部,“>”代表更接近字母表尾部。一般来说,小写字母大于大写字母,大写字母大于数字,但是这可能依赖于服务器上操作系统的比较顺序。

  在比较时,末尾的空格是被忽略的。例如,“Dirk”等于“Dirk ”。

  在比较日期时,“<”表示早于,“>”表示晚于。

  在使用比较运算符比较character和datetime数据时,需用引号将所有数据引起来。

  eXPression:可能是列名、常数、函数或者是列名或常数的任意组合,以及以算术运算符或逐位运算符连接的函数。算术运算符如下表所示:

  符号 意义

  + 加号

  - 减号

  * 乘号

  / 除号

  is null:在搜索一个NULL值时使用。

  like:关键词,对char、varchar和datetime(不包括秒和毫秒)可以使用like,在MySQL中like也可以用在数字的表达式上。

  当用户在搜索datetime型数据时,最好是使用关键词like,因为完整的 datetime记录包含各种各样的日期组件。例如用户在列arrival_time中加入一个值“9:20”,而子句where arrival_time=“9:20”却没有发现它,因为MySQL把录入的数据转换成了“Jan 1,1900 9:20AM”。然而子句where arrival_time like“%9:20%”就能找到它。

  boolean_eXPression:返回“true”或“false”值的表达式。

  match_string:由字符和通配符组成的串,用单引号或双引号引起来,是匹配模式。通配符如下表所示:

  符号 意义

  % 0或多个字符的字符串

  _ 任何一单个字符

  not: 否定任何逻辑表达式,或是关键词,

  如like,null,between等。

  group by和having子句在select语句中使用,

  可以将表划分成组并返回匹配having子句条件的组。

  语法:select语句开头

  group by [all] aggregate_free_expression [,aggregate_free_eXPression]*

  [having search_conditions]

  select语句结尾

  group by:指定表将划分的组群,如果在select表项中包含集合函数,则为各组计算一个总计值。这些总计值的结果以新的列显示,而不是新的行。在 having子句中用户可以引用这些新的总计列。在group by之前的select_list中可以使用avg、count、max、min和sum等集合函数。表可以被任意列的组合分组。

  all:在结果中包含所有组群的Transact-SQL扩展,这里的所有组群甚至包括那些被where子句所排除的组群。如果同时使用having子句,将对all的意义进行否定。

  ag

gregate_free_eXPression:不包含集合函数的表达式,Transact-SQL扩展允许在用列名称分组的同时,用无集合函数的表达式分组。

  having:为group by子句设置条件,类似于where为select语句设置条件的方法。having的查找条件可以包括集合函数表达式。除此之外,它的查找条件与where查找条件相同。

  order by:按列排列结果。对select输出的列可以用列名、列别名或列位置来引用。例如:select id as myid,name as myname from mytable group by id、select id as myid,name as myname from mytable group by myid、select id as myid,name as myname from mytable group by 1这三句是完全等价的。当然,我们不赞成用第三种用法,这将给程序的可读性带来不好的影响。为了以降序排列,把DESC关键词加到order by子句中你要排序的列名前。缺省是升序,你也可以用ASC关键词明确指定。

  limit 子句:用来限制select语句返回的行数。limit取1个或2个数字参数,如果给定2个参数,第一个指定要返回的第一行的偏移量,第二个指定返回行的最大数目。初始行的偏移量是0(不是1)。如果给定一个参数,它指出偏移量为0的返回行的最大数目。也就是说limit 5和limit 0,5完全等价。
分享到:
评论

相关推荐

    MySQL数据库中SELECT语句快速精细掌握

    MySQL中的SELECT语句是SQL语言的核心部分,用于从数据库中检索数据。它的基本语法结构复杂,但通过理解和熟练...记住,实践是掌握这些知识的关键,不断尝试和理解各种组合,你将能快速而精细地掌握MySQL的SELECT语句。

    PHPmyadmin操作MYSQL数据库基础教程

    在IT行业中,数据库管理是至关重要的技能之一,而PHPMyAdmin作为一款强大的开源工具,使得MySQL数据库的管理和操作变得更为简单。本教程将深入讲解如何使用PHPMyAdmin进行基础的MySQL数据库操作。 首先,理解...

    mysql数据库管理软件

    2. **数据插入与查询**:INSERT语句用于向表中插入数据,而SELECT语句用于从表中检索数据。学会使用WHERE子句进行条件筛选,以及GROUP BY和HAVING子句进行数据分组和过滤,是日常操作的关键。 3. **数据更新与删除*...

    MySql数据库.rar

    MySQL是一种广泛使用的开源关系型数据库管理系统(RDBMS),它基于结构化查询语言(SQL)进行数据操作。MySQL因其高效、稳定和易于管理的...理解并熟练掌握上述知识点,将有助于你有效地设计、管理及优化MySQL数据库。

    MySQL数据库安装包资源下载

    1. **下载MySQL安装包**:在"MySQL数据库安装包资源下载"的标题中,我们可以理解为提供了获取MySQL安装程序的途径。用户应前往MySQL官方网站或第三方可信源下载适合其操作系统的安装文件。对于Windows用户,可以选择...

    【如果积分自动变为不为0请留言联系我修改】sql数据库训练mysql数据库

    在MySQL中,可以使用SELECT语句来查询数据,INSERT来添加记录,UPDATE进行修改,而DELETE用于删除记录。 4. **数据库设计** 数据库设计包括创建数据库和表,定义字段类型、长度、默认值等属性。在MySQL中,可以...

    MySQL数据库:用户的权限管理.pptx

    MySQL数据库的权限管理系统是确保数据安全性和访问控制的关键部分。在MySQL中,权限分为四个层次:列权限、表权限、数据库权限和用户权限。新创建的SQL用户默认只能执行有限的操作,不能直接访问其他用户的表或立即...

    MySQL数据库.pdf

    MySQL是一种广泛使用的开源关系型数据库管理系统(RDBMS),由Oracle公司维护。...以上只是MySQL数据库系统的一些基本知识点,实际应用中还需要深入学习和实践,以应对各种复杂的数据库管理和开发需求。

    mySQL数据库

    综上所述,MySQL数据库系统因其丰富的功能、良好的性能以及易于使用而备受青睐。无论是初学者还是经验丰富的开发者,都能在MySQL中找到适合自己的解决方案。通过理解并掌握上述知识点,你将能更好地运用MySQL进行...

    Mysql数据库索引(2)- 为select设计索引- 自学笔记

    ### MySQL数据库索引设计原理与实践 #### 一、理论基础 ##### 1.1、一个例子 ...通过上述理论基础、评估方法和创建建议等内容的学习,我们可以更加科学地设计和优化MySQL数据库中的索引,从而有效提升查询性能。

    MySql数据库软件

    MySQL数据库软件是全球广泛使用的开源关系型数据库管理系统(RDBMS),由Oracle公司维护和提供支持。它以其高效性、可扩展性和易用性而备受赞誉,尤其在中小型企业和Web应用中占据了重要的地位。 首先,MySQL的核心...

    MySQL必知必会数据库脚本文件

    4. **查询操作**: SELECT语句是SQL中最常用的命令,用于从数据库中检索数据。通过使用WHERE子句、GROUP BY、HAVING、ORDER BY和JOIN等,你可以根据特定条件进行复杂的查询。 5. **事务处理**: MySQL支持ACID(原子...

    MysQL数据库

    MySQL数据库是一种广泛使用的开源关系型数据库管理系统(RDBMS),由瑞典MySQL AB公司开发,后被Oracle公司收购。它的名称是“My”(创始人Monty Widenius的女儿的名字)和SQL(Structured Query Language)的组合。...

    我是MySql数据库学习笔记以及相关项目练习.zip

    MySQL数据库是世界上最受欢迎的开源关系型数据库管理系统之一,广泛应用于Web应用程序、数据分析、企业系统等多个领域。本学习笔记和项目练习旨在帮助初学者和进阶者深入理解和掌握MySQL的核心概念和技术。 1. ...

    MySQL数据库应用案例视频教程下载第13讲 用户管理.zip

    在本节MySQL数据库应用案例视频教程中,我们将深入探讨用户管理这一关键主题。用户管理是数据库系统中的核心组成部分,因为它确保了数据的安全性和访问控制。MySQL作为广泛应用的关系型数据库管理系统,提供了强大的...

    mysql数据库的同步问题(双机热备)文.pdf

    MySQL数据库的同步问题,尤其是双机热备,是确保数据高可用性和连续性的关键策略。在MySQL中,这种同步被称为复制(Replication),而非同步(Sync),这是因为复制涉及到主服务器(Master)上的所有更改被重新执行...

    MySQL5.1中文手册

    例如,`SELECT`语句用于从表中检索数据,`INSERT`用于添加新记录,`UPDATE`用于修改现有记录,而`DELETE`则用于删除记录。此外,还有`CREATE DATABASE`、`CREATE TABLE`等用于构建数据库架构的命令。 在存储引擎...

Global site tag (gtag.js) - Google Analytics