sql基础语句

总结sql基本知识点,并结合实例,一步步复杂化

这里写图片描述

1.检索数据(SELECT)

查询所有员工的薪水(简单的检索语句)

SELECT salary FROM employees;

2.限制检索结果(LIMIT)

在1的基础上返回从行10开始的20行薪水数据(返回指定的行,不是返回所有行)

SELECT salary FROM employees LIMIT 10,20;

3. 对结果进行排序展示(ORDER BY)

在2的基础上,将薪水按照降序排序

SELECT salary FROM employees OEDER BY salary DESC;

4. 过滤检索数据(WHERE)

1).操作符过滤:操作符包括等于’=’、不等于’<>’、不等于’!=’、大于’>’、大于等于’>=’、小于’<’、小于等于’<=’、在**之间BETWEEN “AND、是否为空IS NULL、AND、OR、IN、NOT

例子:检索工号为1到100之间的员工的所有信息

SELECT * FROM employees WHERE job_id BETWEEN 1 AND 100;

例子:检索城市为北京、上海、杭州的地址信息

SELECT * FROM locations WHERE city IN('北京',‘上海’,‘杭州’);

2).通配符过滤:通配为LIKE搭配
与%搭配:%表示任意内容,数量的字符
与-搭配:-表示单个字符

例子:检索LAST_NAME中含有‘lucy’的员工信息

SELECT * FROM employees WHERE last_name LIKE '%lucy%';

例子:检索出以某一字符开头,以’lucy’结尾的员工信息

SELECT * FROM employees WHERE last_name LIKE '_lucy';

3).正则表达式:
单一字符匹配:REGEXP ‘.1000’

OR匹配:REGEXP ‘1000|2000’(串中包含1000或2000的记录)

匹配给定字符中的某一个字符:REGEXP ‘[123] Ton’(串中包含有1/2/3 Ton的记录)

匹配范围:REGEXP ‘[0-9] Ton’(匹配0-9中的任一数字)

匹配特殊字符:需要通过\进行转义 REGEXP ‘\.’

匹配字符类:[:alnum:]任意字母和数字(同[a-zA-Z0-9])
[:alpha:]任意字符(同[a-zA-Z])
[:blank:]空格和制表(同[\t])…

匹配多个实例:*0个或多个匹配
+1个或多个匹配
?0个或1个匹配
{n}指定数目匹配
{n,}不少于指定数目的匹配
{n,m}匹配数目的范围

定位符:
^文本的开始
$文本的结尾
[[:<:]]词的开始
[[:>:]]词的结尾

例子:检索employee表中所有符合规范的手机号码

SELECT employee_id,phone_number FROM employees WHERE phone_number REGEXP '^1[0-9]{10}';

5. 拼接字段

将俩个子串拼接成较长的串

例子:检索给出员工的姓名

SELECT Concat(first_name,last_name) AS name FROM employees;

6. 使用函数

1)文本处理函数:
Length():返回串的长度
Lower():将串转换为小写
Ltrim():去掉串左边的空白字符
Rtrim():去掉串右边的空白字符
Upper():将串转化为大写
SubString():返回子串的字符

2)日期和时间处理函数:
CurDate():返回当前日期
CurTime():返回当前时间
Now():返回当前日期和实践
Date():返回日期时间的日期部分
Time():返回日期时间的时间部分
Year():返回一个日期的年份部分
Mouth():返回一个日期的月部分
Day():返回一个日期的天数部分
Hour():返回一个时间的小时部分
Minute():返回一个时间的分钟部分
Second():返回一个时间的秒部分
AddDate():增加一个日期
AddTime():增加一个时间
DateDiff():计算两个日期之差
DateFormate():返回格式化的日期或时间

3)数值处理函数:
Abs():返回一个数的绝对值
Exp():返回一个数的指数值
Mod():返回除操作的余数
Rand():返回一个随机数
Sqrt():返回一个数的平方根
Cos():返回一个角度的余弦
Sin():返回一个角度的正弦
Tan():返回一个角度的正切
一般情况下,文本处理函数和日期处理函数用的较多

7. 聚集函数

AVG():计算平均值
COUNT():统计个数
MAX():统计最大值
MIN():统计最小值
SUM():计算和

8. 分组数据

通过GROUP BY分组,HAVING对分组数据进行过滤

9. 子查询

10. 联结

内联结
外联结:分为左外联结、右外联结

11. 组合查询

通过UNION将多个SELECT语句做并集

SELECT中子句顺序:

SELECT > FROM > WHERE > GROUP BY > HAVING > ORDER BY > LIMIT

后续:详细实例

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值