一、select语法
1、 简单查询语句
select 字段 from 表名|视图 where 条件 order by 字段 desc|asc (|表示或,desc降序,asc升序,不写默认升序)
例如 :
select * from user where name='张三' order by id; (*表示所有字段)
另:select id, name,sex,phone from user where name='张三' order by id;
2、 查询不重复的数据
select distinct 字段[,字段,字段…] from 表名; 一个字段就判断一个字段的重复值,多个就会组合判断,多个都重复才会认为重复;
例如:
select distinct name from user; 查出所有用户的名字;
3、 显示指定条数的数据
sql最后加 limit 起始偏移量,行数。第一个表示从第多少条开始,第二个表示取出来多少条,如取根据用户的创建时间,取最新的10条数据
select * from user order by createTime desc limit 1,10;
二、select 常见示例
1、控制流程
我们经常会遇见需要对字段的显示进行处理的情况,如性别字段值1显示男,值2显示女。
(1)case;
语法为 case 字段 when 值 then ” when 值 then ” …… else ” end as 别名 (else 可不用)
例如:
select name ,case sex when 1 then '男' when 2 then '女' end as s from user ;
还有另一种情况,简单的值判断无法满足需求,如年龄18以下显示未成年,18-50显示青年,50以上显示老年,这时候需要表达式来进行判断;
语法为case when 表达式 then ” when 表达式 then ”…… else ” end as 别名
例如:
select name ,
case when age<18 then '未成年'
when age between 18 and 50 then '青年'
when age>50 then '老年' end a
from user;
表达式可以是一个也可以是多个,如未满18的女性显示美少女,就是when age<18 and sex=2 then ‘美少女’。
(2)IF;
IF (expr1,expr2,expr3) 如果 expr1 是TRUE (expr1 <> 0 and expr1 <> NULL),则 IF()的返回值为expr2; 否则返回值则为 expr3。IF() 的返回值为数字值或字符串值,具体情况视其所在语境而定
SELECT IF(1>2,2,3);返回3
SELECT IF(1<2,'yes ','no');返回yes
SELECT IF(STRCMP('test','test1'),'no','yes');返回no
(3)STRCMP;
Strcmp(str1,str2):如果str1>str2返回1,str1=str2反回0,str1<str2返回-1
如果字符串相同,STRCMP()返回0,如果第一参数根据当前的排序次序小于第二个,返回-1,否则返回1。
select STRCMP('text', 'text2'); 返回-1
select STRCMP('text2', 'text'); 返回1
select STRCMP('text', 'text');返回0
2、函数
这里只说明一下常用的函数,如下:
(1)IFNULL
判断是否为空,如果有值返回该字段的值,为空则返回指定值,语法为IFNULL(字段,”)
例如:
select name,ifnull(age,'该用户未填写年龄') from user
(2)CONCAT
字符串连接,数据库中不能用+号连接字符串,语法为CONCAT(str1,str2,…)
例如:
select CONCAT(name,'是一个',age,'的',case sex when 1 then '男' when 2 then '女' end ,'生')
from user;
但是有一点需要特别说明,如果其中一个字段为Null,则返回为null,因此,假如有某列数据可能会空的,字段用ifnull(age,”)
(3)FORMAT
对字段进行格式化,FORMAT(x,n)函数可以将数字x进行格式化,将x保留到小数点后n位。这个过程需要进行四舍五入。例如FORMAT(2.356,2)返回的结果将会是2.36;FORMAT(2.353,2)返回的结果将会是2.35。
(4) INET_ATON
INET_ATON(IP)函数可以将IP地址转换为数字表示,数字比字符串存储空间少,查询效率高,这算是一种mysql的优化;INET_NTOA(n)函数可以将数字n转换成IP的形式。其中,INET_ATON(IP)函数中IP值需要加上引号。这两个函数互为反函数。