where子句设置了搜索条件它在insertupdatedelete语句中的应用方法也与在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比较运算符见下表
WordWRAP: breakword bgColor=#fff>以下是引用片段
符号 意义
= 等于
> 大于
< 小于
>= 大于等于
<= 小于等于
!= 不等于
<> 不等于
在比较charvarchar型数据时<的意思是更接近字母表头部>代表更接近字母表尾部一般来说小写字母大于大写字母大写字母大于数字但是这可能依赖于服务器上操作系统的比较顺序
在比较时末尾的空格是被忽略的例如Dirk等于Dirk
在比较日期时<表示早于>表示晚于
在使用比较运算符比较character和datetime数据时需用引号将所有数据引起来
expression可能是列名常数函数或者是列名或常数的任意组合以及以算术运算符或逐位运算符连接的函数算术运算符如下表所示
以下是引用片段
符号 意义
+ 加号
减号
* 乘号
/ 除号
is null在搜索一个NULL值时使用
like关键词对charvarchar和datetime(不包括秒和毫秒)可以使用like在MySQL中like也可以用在数字的表达式上
当用户在搜索datetime型数据时最好是使用关键词like因为完整的datetime记录包含各种各样的日期组件例如用户在列arrival_time中加入一个值:而子句where arrival_time=:却没有发现它因为MySQL把录入的数据转换成了Jan :AM然而子句where arrival_time like%:%就能找到它
boolean_expression返回true或false值的表达式
match_string由字符和通配符组成的串用单引号或双引号引起来是匹配模式通配符如下表所示
WordWRAP: breakword bgColor=#fff>以下是引用片段
符号 意义
% 或多个字符的字符串
_ 任何一单个字符
not 否定任何逻辑表达式或是关键词
如likenullbetween等
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中可以使用avgcountmaxmin和sum等集合函数表可以被任意列的组合分组
all在结果中包含所有组群的TransactSQL扩展这里的所有组群甚至包括那些被where子句所排除的组群如果同时使用having子句将对all的意义进行否定
aggregate_free_expression不包含集合函数的表达式TransactSQL扩展允许在用列名称分组的同时用无集合函数的表达式分组
having为group by子句设置条件类似于where为select语句设置条件的方法having的查找条件可以包括集合函数表达式除此之外它的查找条件与where查找条件相同
order by按列排列结果对select输出的列可以用列名列别名或列位置来引用例如select id as myidname as myname from mytable group by idselect id as myidname as myname from mytable group by myidselect id as myidname as myname from mytable group by 这三句是完全等价的当然我们不赞成用第三种用法这将给程序的可读性带来不好的影响 为了以降序排列把DESC关键词加到order by子句中你要排序的列名前缺省是升序你也可以用ASC关键词明确指定
limit 子句用来限制select语句返回的行数limit取个或个数字参数如果给定个参数第一个指定要返回的第一行的偏移量第二个指定返回行的最大数目初始行的偏移量是(不是)如果给定一个参数它指出偏移量为的返回行的最大数目也就是说limit 和limit 完全等价
至于procedure关键词的含义我也没搞得太清楚好象是对存储过程的支持而MySQL本身不支持存储过程看来是为了将来扩充的需要而保留的吧
[] []