码迷,mamicode.com
首页 > 其他好文 > 详细

select语句

时间:2016-08-16 01:47:06      阅读:162      评论:0      收藏:0      [点我收藏+]

标签:

一、检索--输出所有的列

SELECT * 
FROM my_friends WHERE
first_name = cake;

* 代表选择出所有的行-----(什么行呢?)就是first_name =‘cake’的行。整个语句的意思就是从my_friends的表中,检索出first_name = ‘cake‘ 的行,并全部显示!

注意:1.文本类的数据类型的值需要加上单引号,非文本类的数据类型的值不需加单引号(规则跟INSERT插入数值的时候一样)

爱用单引号:CHAR,VARCHAR,DATA,DATATIME,BLOG

拒绝用单引号:DEC,INT    

(如果文本数据类型的 数据需要用到单引号‘ 时,需要用 \‘来代替  ‘)

2.如果WHERE后面的列是非文本类的数据类型,可以使用 ‘<’ 和 ‘>’ 检索出 对应范围的值。

注意:a. 不等于 有两种表示方式  <> 和 !=  

b. 等号 可以结合 < 或者 >使用,如:<= 或者 >= 

c.可以使用关键字代替>= 、<= 表示数值区间,如:

SELECT * FROM my_friends
WHERE
age BETWEEN 15 AND 30; --注意:BETWEEN 规定,必须按顺序,从小到大!不可以是between 30 and 15

 

 

要是想要满足多个条件呢?可以更进一步(或多步,多步也是增加and条件而已...)检索满足多个条件下的序列

SELECT* FROM  my_friends       
WHERE 
last_name = ‘Lily’
AND last_name = Wang;

 

整理一下,就是当表 my_friends 中的列 last_name = ‘Lily‘而且 first_name = ‘Wang‘ 时,输出所有的列

 

存在“与” ,“与”用AND 表示 ,那也肯定存在着“或”,“或”用 OR 表示!

 

 当需要使用多个 ‘OR’ 的时候,程序会显得很累赘,所以聪明的SQL 衍生出了 关键字 ‘IN’ 来解决这个问题! 

SELECT *FROM  my_friends       
WHERE 
interest = ‘baskball’
OR
interest = running
OR
interest = swimming
OR
...;

--------->>

SELECT * FROM my_friends       
WHERE 
interest  IN ( ‘baskball’,running,swimming);  ---在这里  IN是包含的意思

而且,IN 意为 包含。 NOT IN意为 不包含SELECT * 

FROM * my_friends       
WHERE 
interest  NOT IN (‘baseball);

 

附加: 更多的NOT

1.NOT也可以和BETWEEN 或者 LIKE 一起使用,在使用时,NOT 一定要紧接在 WHERE 后面。但是NOT IN 是个例外,而且即使把NOT移到 WHERE 后一可以运作(以下程序等效上程序)

SELECT * FROM my_friends       
WHERE 
NOT interest  IN (‘baseball);

 

2.NOT和AND或OR一起使用时,要直接接在AND或者OR后面!记得哦!!!

SELECT * 
FROM my_friends       WHERE NOT age BETWEEN 1 AND 15; SELECT last_name FROM my_friends WHERE NOT first_name LIKE %W‘    -- AND NOT first_name LIKE %L;

 

 

 

有一个巨大的问题来了,如果我找的数据是 NULL 呢? 应该怎么去寻找,毕竟 NULL != NULL 呀

解决办法肯定是多于问题的!

SELECT phone    --选择列的名称
FROM my_friends       --从表中
WHERE e-mail IS NULL;

IS NULL是关键字!

 

二、检索--输出特定的序列(过滤数据)

SELECT status    --选择列的名称
FROM my_friends       --从表中
WHERE last_name = ‘Lily’;  --当last_name  = ‘Lily‘时

整理一下,就是当表 my_friends 中的列 last_name = ‘Lily‘时,输出列 status

 

三、检索--文本型相同的部分

SELECT * FROM my_friends       --从表中
WHERE last_name  LIKE = ‘L%;  --当last_name 以L开头时

上面程序表达的是,检索my_friend中的 last_name 的列,输出以‘L’开头的所有行

通配符  ---必须配合 文本型数据类型使用

%   ---百分号 是任意数量的未知字符的替身

_    ----下划线 是一个未知字符的替身

SELECT * FROM my_friends       --从表中
WHERE last_name  LIKE = ‘_L%;  --当last_name 以‘XL‘开头时,X 为任意字符

 

select语句

标签:

原文地址:http://www.cnblogs.com/simonLiang/p/5771475.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!