SQL学习笔记:高级教程
SQL语法
- LIMIT
select col from table limit number
select * from table limit number - LIKE
select * from table where col LIKE '%in%'
select * from table where col NOT LIKE '%in%' - 通配符
- 通配符必须与LIKE一起使用
- % -- 替代一个或者多个字符
- _ -- 替代一个字符
- [charlist] -- 字符列中的任何单一字符
- [!charlist] -- 不在字符列中的任何单一字符
- select * from table where col LIKE '[abc]d_e%'
- IN 在where中选取多个值
select * from table where col IN ('zhi1', 'zhi2') - BETWEEN ... AND ...
select * from table where col BETWEEN 'a' AND 'c'
select * from table where col NOT BETWEEN 'a' AND 'c' - Alias
select A.col, B.col1 from table1 AS A, table2 AS B where A.col = 'zhi1' AND B.col = 'zhi2'
select col1 AS name1, col2 AS name2 from table - JOIN
select A.col1, B.col2 from tablea AS A, tableb AS B where A.col = B.col - INNER JOIN
select tablea.col1, tableb.col2 from tablea INNER JOIN tableb ON tablea.col = tableb.col - LEFT JOIN
结果会返回左表中所有的行,即使右表中没有匹配的行
select tablea.col1, tableb.col2 from tablea LEFT JOIN tableb ON tablea.col = tableb.col - RIGHT JOIN
结果返回右表中所有的行,即使右表中没有匹配的行
select tablea.col1, tableb.col2 from tablea RIGHT JOIN tabelb ON tablea.col = tableb.col - FULL JOIN
结果返回两表中所有的行,即使没有匹配
select tablea.col1, tableb.col2 from tablea FULL JOIN tableb ON tablea.col = tableb.col - UNION 与 UNION ALL
union 需要有相同数量的列同时数据类型相似,列的顺序也要一致
union 输出唯一的值; union all 输出所有的值
select col1, col2 from tablea
UNOIN ALL
select col1, col2 from tableb - SELECT INTO 创建备份
select * into tablea_backup from tablea - CREATE DATABASE 创建数据库
create database name - CREATE TABLE 创建表
cerete tbale name (id int, name varchar(255), adress varchar(255)) - 数据类型
数据类型 | 描述 |
---|---|
int(size) | 仅容纳整数 括号内为数字的最大位数 |
decimal(size,d) numeric(size, d) |
容纳带有小数的数字 size规定数字的最大位数 d规定小数点右侧的最大位数 |
char(size) | 容纳固定长度的字符串 size为规定字符串的长度 |
varchar(size) | 容纳可变长度的字符串 字符串的最大长度 |
data(yyyymmdd) | 容纳日期 |
- sql约束可以加在 create table 语句也可以用在alter table语句
- NOT NULL 不接受空值
crete table name (id int NOT NULL, name varchar(255) NOT NULL, city varchar(255)) - UNIQUE 约束唯一标识数据库表中的每条记录
- 每个表可以有多个unique,但只有一个primary key 约束
- 创建表时
crete table name (id int NOT NULL, name varchar(255) NOT NULL, city varchar(255), UNIQUE(id))
crete table name (id int NOT NULL, name varchar(255) NOT NULL, city varchar(255), CONSTRAINT uc_name UNIQUE (id, city)) - 更改表时
alter table name ADD UNIQUE(id)
alter table name ADD CONSTRAINT uc_name UNIQUE (id, city) - 撤销UNIQUE约束
alter table name DROP INDEX uc_name - primry key = unique + not null
- 每个表中都应该有一个主键,并且只有一个主键
- 创建表时
crete table name (id int NOT NULL, name varchar(255) NOT NULL, city varchar(255), PRIMARY KEY (id))
crete table name (id int NOT NULL, name varchar(255) NOT NULL, city varchar(255), CONSTRAINT pk_name PRIMARY KEY (id, city)) - 更改表时
alter table name ADD PRIMARY KEY (id)
alter table name ADD CONSTRAINT pk_name PRIMARY KEY (id, city) - 撤销表时(注意与撤销unique的不同)
alter table name DROP PRIMARY KEY - FOREIGN KEY
crete table tablename1(id1 int not null, things varchar(255), id2 int, primary key (id1), FOREIGN KEY (id2) REFERENCES tablename2 (id))
crete table tablename1(id1 int not null, things varchar(255), id2 int, primary key (id1), CONSTRAINT fk_name FOREIGN KEY (id2) REFERENCES tablename2 (id)) - 更改表时
alter table name ADD CONSTRAIN fk_name FOREIGN KEY (id) REFERENCES tablename2 (id1) - 撤销foreign key
alter table name DROP FOREIGN KEY fk_name - CHECK
crete table tablename1(id1 int not null, things varchar(255), id2 int, primary key (id1), CONSTRAINT chk_name CHECK (id > 0 AND city = "abc"))
alter table name ADD CONSTRAINT chk_name CHECK (id > 0 and city = 'abc')
alter table name DROP CHECK chk_name - DEFAULT
crete table tablename1(id1 int not null, things varchar(255), id2 int, shijian date DEFAULT GETDATE())
alter table name ALTER city SET DEFAULT 'abc'
alter table name ALTER city DROP default - INDEX
CREATE INDEX indexname ON tablename (city, id DESC) - DROP
DROP table tablename
TRUNCATE table tablename
truncate仅仅删除数据不删除表本身 - ALTER 添加列
alter table tablename ADD colname datatype - 修改列数据格式
alter table tablename ALTER COLUMN colname datatype - 删除列
alter table tablename DROP COLUMN colname - AUTO_INCREMENT
在每次加入新的数据后,会自动创建主键的值
crete table tablename1(id1 int not null AUTO_INCREMENT, things varchar(255), id2 int, primary key (id1)) - VIEW 视图
CREATE VIEW viewname AS
select * from tablename - 撤销视图
DROP VIEW viewname - NULL
select * from tablename where col1 IS NOT NULL - IFNULL
select IFNULL(COL1, 0) from table1 - DATE函数
函数 | 描述 |
---|---|
NOW() | 返回当前日期和时间 |
CURDATE() | 返回当前日期 |
CURTIME() | 返回当前时间 |
DATE() | 提取日期部分 |
EXTRACT() | 提取日期时间的单独部分 |
DATE_ADD() | 给日期加上指定的时间间隔 |
DATE_SUB() | 给日期减去指定的时间间隔 |
DATEDIFF() | 返回两日期之间的天数 |
DATE_FORMAT() | 指定时间日期格式 |
SQL学习笔记:高级教程的更多相关文章
- php学习笔记--高级教程--读取文件、创建文件、写入文件
打开文件:fopen:fopen(filename,mode);//fopen("test.txt","r"): 打开模式:r 仅仅读方式打开,将文件指针指向 ...
- 数据库MySQL学习笔记高级篇
数据库MySQL学习笔记高级篇 写在前面 学习链接:数据库 MySQL 视频教程全集 1. mysql的架构介绍 mysql简介 概述 高级Mysql 完整的mysql优化需要很深的功底,大公司甚至有 ...
- ORALCE PL/SQL学习笔记
ORALCE PL/SQL学习笔记 详情见自己电脑的备份数据资料
- 学习笔记|JSP教程|菜鸟教程
学习笔记|JSP教程|菜鸟教程 ------------------------------------------------------------------------------------ ...
- Oracle之PL/SQL学习笔记
自己在学习Oracle是做的笔记及实验代码记录,内容挺全的,也挺详细,发篇博文分享给需要的朋友,共有1w多字的学习笔记吧.是以前做的,一直在压箱底,今天拿出来整理了一下,给大家分享,有不足之处还望大家 ...
- SQL学习笔记
SQL(Structured Query Language)学习笔记 [TOC] Terminal登录数据库 1.登录mysql -u root -p ; 2.显示所有数据库show database ...
- AngularJs学习笔记--Guide教程系列文章索引
在很久很久以前,一位前辈向我推荐AngularJs.但当时我没有好好学习,仅仅是讲文档浏览了一次.后来觉醒了……于是下定决心好好理解这系列的文档,并意译出来(英文水平不足……不能说是翻译,有些实在是看 ...
- DP动态规划学习笔记——高级篇上
说了要肝的怎么能咕咕咕呢? 不了解DP或者想从基础开始学习DP的请移步上一篇博客:DP动态规划学习笔记 这一篇博客我们将分为上中下三篇(这样就不用咕咕咕了...),上篇是较难一些树形DP,中篇则是数位 ...
- SQL学习笔记:一些高级语句
现在以MySQL为模板.学习的方法和别的数据库写法上会有不同,但是思路基本一致. 用到的数据库表的格式: +----+--------------+-------------------------- ...
随机推荐
- 沉淀,再出发:sublime中快捷键和html标签的使用和生成以及使用markdown
沉淀,再出发:sublime中快捷键和html标签的使用和生成以及使用markdown 一.前言 工欲善其事,必先利其器.在软件代码的编写中,一定要知道IDE或者编辑器的快捷键的使用,这样可以提高很多 ...
- .NET Reflector注册问题
reflector工具不错, 终于8.x了,也可以注册了,但是不小心注册成standard版本了,但vs中无法使用,于是各种删注册表,后来找到何英涛的解决方案 下面介绍一个Reflector很坑的一个 ...
- TCP/IP 协议图--计算机网络体系结构分层
计算机网络体系结构分层 计算机网络体系结构分层 不难看出,TCP/IP 与 OSI 在分层模块上稍有区别.OSI 参考模型注重“通信协议必要的功能是什么”,而 TCP/IP 则更强调“在计算机上实 ...
- 自学PHP有哪些书籍和教程值得推荐?
知乎上看到一题主询问:"自学PHP有哪些书籍和教程值得推荐?",互联网深度屌丝秦风给出了不错的答案,希望能够帮助自学PHP的朋友们. 以下仅供参考: 尤其不认可W3school之类 ...
- 解决Could not commit JPA transaction RollbackException: Transaction marked as rollbackOnly
项目测试发生问题,方法正常结束,但是报了 Could not commit JPA transaction; nested exception is javax.persistence.Rollbac ...
- JavaScript 数组遍历方法的对比
JavaScript 发展至今已经发展出多种数组的循环遍历的方法,不同的遍历方法运行起来那个比较快,不同循环方法使用在那些场景,下面将进行比较: 各种数组遍历的方法 for 语句 ,,,] , len ...
- 使用jenkins SonarQube gitlab 构建自动化发布系统
目前持续集成的生态越来越完善,工具也有很多,开源的或商业的.如: 最最流行的,也是使用最多的 Jenkins 有着持续集成DNA的ThoughtWorks GO.理念:"Deployment ...
- servlet的生命周期详解
一.servlet生命周期原理解析 1.Servlet生命周期分为三个阶段: (1)初始化阶段 调用init()方法 (2)响应客户请求阶段 调用service()方法 (3)终止阶段 调用dest ...
- Hadoop学习之路(二十五)MapReduce的API使用(二)
学生成绩---增强版 数据信息 computer,huangxiaoming,85,86,41,75,93,42,85 computer,xuzheng,54,52,86,91,42 computer ...
- 深入学习c++--重新审视auto
1. auto推断变量类型 2. auto遍历 3. 自定义类可使用auto