SQL学习整理
SQL整理
SQL 对大小写不敏感!
一、对数据的操作
实现功能分类:
1. 增:
1.1 表存在,插入栏位:
//插入新的行(按栏位的顺序插入)
INSERT INTO Table_1 VALUES ('bly',23,'girl')
//指定栏位插入
INSERT INTO Table_1 (name,address) VALUES ('bbbb','cccc')
//将表2表中的数据都复制新增至表1中
INSERT INTO Table_1 SELECT * FROM Table_2
1.2 表不存在
//先建立表3,再将表1中的指定栏位插入新表
SELECT name,address INTO Table_3 FROM Table_1
2. 删
2.1 DELETE FROM Table_1 //删除表1表中所有数据(逐条删除,速度慢)
2.2 TRUNCATE TABLE Table_1 //清空表1表的数据(一次性删除所有,速度快)
注:delete、truncate、drop区别
删除XXX |
应用范围 |
格式 |
表和索引所占空间 |
|
delete |
数据 |
table&&view |
DELETE FROM table |
不会减少 |
truncate |
数据 |
table |
TRUNCATE TABLE table |
恢复初始大小 |
drop |
表 |
DROP TABLE table |
表占空间全部释放 |
3 改
3.1 UPDATE Table_1 SET gender='boy' WHERE name='bbbb'
4 查
4.1 SELECT * FROM Table_1 WHERE gender='boy'
4.2 SELECT * FROM Table_1
4.3 SELECT TOP 50 PERCENT name,SUM(price) FROM Table_1
GROUP BY name
Having SUM(price)>100
ORDER BY SUM(price)执行顺序:
- FROM
- WHERE
- GROUP BY 分组。一般和聚合函数一起用。
- HAVING 查询条件。WHERE 关键字无法与合计函数一起使用
- SELECT 查询
- DISTINCT 去重
- ORDER 排序
- TOP 10 (PERCENT) 前10(%)
4.4 模糊查询
‘%’多字符模糊匹配。如:’周%’,’%超’
‘_’一个字符模糊匹配。如:’周_’,’_超’
SELECT * FROM Table_1 WHERE name LIKE '%小%'
SELECT * FROM Table_1 WHERE name NOT LIKE '_超'
其他操作符
1 AND
SELECT * FROM Table_1 WHERE (name='bly' AND gender='girl')
2 OR
SELECT * FROM Table_1 WHERE (name='bly' OR name='zxl')
3 IN
IN 操作符允许我们在 WHERE 子句中规定多个值。
SELECT * FROM Table_1 WHERE name IN ('bly','zxl') //结果同上OR的结果
4 BETWEEN…AND…
包括前,不包括后
SELECT * FROM Table_1 WHERE price BETWEEN 50 AND 100 (50<=X<100)
5 JOIN
表A 和表B 为例
A: B:
5.1 内连接 INNER JOIN 则为交集A∩B
SELECT * FROM Table_1
INNER JOIN Table_2
ON Table_1.name = Table_2.name
5.2 外连接 FULL OUTER JOIN则为并集A∪B
SELECT * FROM Table_1
FULL OUTER JOIN Table_2
ON Table_1.name = Table_2.name
5.3 左连 LEFT JOIN则为A表全显示,B表没数据的NULL显示
SELECT * FROM Table_1
LEFT OUTER JOIN Table_2
ON Table_1.name = Table_2.name
5.4 右连 RIGHT JOIN 则为 B表全显示,A表没数据的NULL显示
SELECT * FROM Table_1
RIGHT JOIN Table_2
ON Table_1.name = Table_2.name
5.5 CROSS JOIN 为A表和B表的数据N*M
SELECT * FROM Table_1
CROSS JOIN Table_2
添:
A. A表有,B表没有
SELECT * FROM Table_1
FULL OUTER JOIN Table_2
ON Table_1.name = Table_2.name
WHERE Table_2.name IS NULL
B. A表、B表共有以外的
SELECT * FROM Table_1
FULL OUTER JOIN Table_2
ON Table_1.name = Table_2.name
WHERE Table_1.name IS NULL OR Table_2.name IS NULL
6 UNION
合并两个或多个 SELECT 语句的结果集。
UNION 内部的 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每条 SELECT 语句中的列的顺序必须相同。
SELECT * FROM Table_3 WHERE name='123'
UNION
SELECT * FROM Table_1 WHERE name='paulinka'
6.1 选取不同的值
SELECT name FROM Table_3
UNION
SELECT name FROM Table_1
6.2 允许重复的值
SELECT name FROM Table_3
UNION ALL
SELECT name FROM Table_1
函数:
- AVG()平均值
- SUM()和
- COUNT()总数
- LEN()长度
- UCASE()大写
- LCASE()小写
- ROUND(A,X)显示A栏位数据小数点后X位
- GETDATE()获取时间
- MIN()最小值
- MAX()最大值
二、对表的操作
1 新建表
1.1 插入数据同时创建表
SELECT * INTO Table_3 FROM Table_1
1.2 新建空表
CREATE TABLE Table_4 (
name nvarchar(30),
age int
)
2 删除表
DROP TABLE Table_3
3 修改表
3.1 添加栏位
ALTER TABLE Table_1 ADD price int
3.2 删除栏位
ALTER TABLE Table_2 DROP COLUMN name
SQL学习整理的更多相关文章
- SQL学习整理_1
数据库是保存表和其他相关SQL结构的容器. 列是存储在表中的一块同类型数据. 行是一组能够描述某个事物的列的集合. SQL不区分大小写,但建议命令采用大写,表名采用小写,便于读写. 建立数据库 CRE ...
- SQL学习整理_2
字符串处理,字符串函数不会改变存储在表中的数据内容,他们只是把函数结果当成查询结果返回. 1. SELECT right(name,2) FROM my_list --从my_list列表中取出n ...
- 一个项目涉及到的50个Sql语句(整理版)
/* 标题:一个项目涉及到的50个Sql语句(整理版) 说明:以下五十个语句都按照测试数据进行过测试,最好每次只单独运行一个语句. */ --1.学生表Student(S,Sname,Sage,Sse ...
- 基于实际项目的SQL学习总结
青云 随笔 - 2, 文章 - 0, 评论 - 1, 引用 - 0 一个项目涉及到的50个Sql语句(整理版) /* 标题:一个项目涉及到的50个Sql语句(整理版) 说明:以下五十个语句都按照测 ...
- js数组学习整理
原文地址:js数组学习整理 常用的js数组操作方法及原理 1.声明数组的方式 var colors = new Array();//空的数组 var colors = new Array(3); // ...
- TweenMax学习整理--特有属性
TweenMax学习整理--特有属性 构造函数:TweenMax(target:Object, duration:Number, vars:Object) target:Object -- 需要缓 ...
- HttpClient学习整理
HttpClient简介HttpClient 功能介绍 1. 读取网页(HTTP/HTTPS)内容 2.使用POST方式提交数据(httpClient3) 3. 处理页面重定向 ...
- !!对python列表学习整理列表及数组详细介绍
1.Python的数组分三种类型:(详细见 http://blog.sina.com.cn/s/blog_6b783cbd0100q2ba.html) (1) list 普通的链表,初始化后可以通过特 ...
- Java设计模式(学习整理)---命令模式
设计模式之Command(学习整理) 1.Command定义 不少Command模式的代码都是针对图形界面的,它实际就是菜单命令,我们在一个下拉菜单选择一个命令时,然后会执行一些动作. 将这些命令封装 ...
随机推荐
- console.log、toString方法与js判断变量类型
Java调用system.print.out()是会调用toString方法打印js里的console.log也是控制台打印,很多时候,我们以为也是调用toString方法,其实并不是.我们在chro ...
- mysql主主同步
Mysql 主主同步方案 第一台机器主 [root@master ~]# vim /etc/my.cnf [mysqld] server-id=1 log-bin=mysql-binlog log-s ...
- jmeter3.1 压测
压测目标:error 为0,线程起到250,服务器配置达到最大 一.Jmeter3.1 压测 JMeter3.1提供一个用于生成HTML页面格式图形化报告的扩展模块.该模块支持通过两种方式生成多维度图 ...
- js 中this到底指向哪里?
其实js的this指向很简单.我们记住下面3种情况. this 指向的是浏览器中的window.代码如下: function fn(){ this.name='yangkun'; this.age=2 ...
- 【Leetcode】【简单】【682棒球比赛】【JavaScript】
题目 682. 棒球比赛 你现在是棒球比赛记录员.给定一个字符串列表,每个字符串可以是以下四种类型之一:1.整数(一轮的得分):直接表示您在本轮中获得的积分数.2. "+"(一轮的 ...
- __int128的实现
#include<bitset> #include<algorithm> #include<iostream> #include<string> #in ...
- 函数(day08)
C语言里可以采用分组的方式管理语句 每个语句分组叫做一个函数 多函数程序执行的时候时间分配情况必须 遵守以下规则 .整个程序的执行时间被划分成几段,每段 时间都被分配给一个函数使用 .不同时间段不能互 ...
- 挑战程序设计第二版PDF高清完整版免费下载
挑战程序设计pdf 网上有些地方的资源获取比较麻烦,本着共享的原则将此书pdf发出来,希望有条件的同学支持正版. 链接:https://pan.baidu.com/s/16S-5QOjoNxSGQx- ...
- 07.网络编程-2.UDP
1.udp介绍 UDP --- 用户数据报协议, 是一个无连接的简单的面向数据报的传输层协议. UDP不提供可靠性, 它只是把应用程序传给IP层的数据报发送出去, 但是并不能保证它们能到达目的地. 由 ...
- PHP 页面刷新与跳转的方法汇总
HTML meta标签 <meta http-equiv='content-type' content="text/html;charset=utf-8"/> 实现页面 ...