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模式的代码都是针对图形界面的,它实际就是菜单命令,我们在一个下拉菜单选择一个命令时,然后会执行一些动作. 将这些命令封装 ...
随机推荐
- python jieba分词(添加停用词,用户字典 取词频
中文分词一般使用jieba分词 1.安装 pip install jieba 2.大致了解jieba分词 包括jieba分词的3种模式 全模式 import jieba seg_list = jieb ...
- 【剑指Offer】49、把字符串转换成整数
题目描述: 将一个字符串转换成一个整数(实现Integer.valueOf(string)的功能,但是string不符合数字要求时返回0),要求不能使用字符串转换整数的库函数. 数值为0或者字 ...
- 重置root管理员密码(RedHat、CentOS、Fedora)
重启Linux系统主机并出现引导画面时,按下键盘上的e键进入内核编辑界面. 在Linux16参数这行后面追加"rd.break"参数,然后按下Ctrl+x组合键来运行修改后的内核程 ...
- [CodeForces]908D New Year and Arbitrary Arrangement
设状态f[i][j]表示有i个a,j个ab的期望 发现如果i+j>=k的话就再来一个b就行了. #include <iostream> #include <cstdio> ...
- 继续聊WPF——Expander控件(1)
这个控件最实用的地方,就是做导航栏. <StackPanel Margin="20,20" Width="100" Height="460&qu ...
- Solr数据不同步
Solr配置了集群,本地有253和254,2个独立的Solr服务. 同一个页面的图片,刷新2次,图片地址不一样,最后查明,后台数据源Solr1和Solr2的数据不一致. 第1步推测:本地缓存, ...
- 洛谷 P2144 BZOJ 1003 [FJOI2007]轮状病毒
题目描述 轮状病毒有很多变种.许多轮状病毒都是由一个轮状基产生.一个n轮状基由圆环上n个不同的基原子和圆心的一个核原子构成.2个原子之间的边表示这2个原子之间的信息通道,如图1. n轮状病毒的产生规律 ...
- 0926mysql join的原理
转自 http://www.cnblogs.com/shengdimaya/p/7123069.html MySQL JOIN原理 先看一下实验的两张表: 表comments,总行数28856 表 ...
- codevs——T2894 Txx考试
http://codevs.cn/problem/2894/ 时间限制: 1 s 空间限制: 32000 KB 题目等级 : 黄金 Gold 题解 查看运行结果 题目描述 Descri ...
- A - 敌兵布阵(HDU 1166)
A - 敌兵布阵 HDU - 1166 思路:线段树单点修改+区间查询. #include<cstdio> #include<cstring> #include<iost ...