数据库基础篇(三)—— SQL之数据操纵、定义

写在前面:今天我们来学习DML数据操纵语言和DDL数据定义语言。DML包括插入、修改、删除;DDL包括表和库的管理。一般从事数据分析工作,只有查的权限,没有增删改及建库建表的权限。通常我们需要将业务数据从数仓或者正式库,迁移到测试库或本地库。具体迁移方法上一节有介绍。迁移到测试库后,就可以增删改操作。

DML语言的学习

1、 插入 insert

1)语法

# 方式一
insert into 表名(字段名,...)
values(值1,...);
# 方式二
insert into 表名
set 字段名1=值2,字段名2=值2 ...

2)两种方式区别

方式一使用最多。它支持插入多行;支持嵌入子查询。方式二不支持。

insert into info(id,name,age)
values(1,'cherich',18),(2,'cherich2',NULL),
(3,'cherich3',20);

insert into info(id,name,age)
select id,name,age from info;

3)特点

①字段类型和值类型一致或兼容,而且一一对应

②可以为空的字段,可以不用插入值,或用null填充

③不可以为空的字段,必须插入值

④字段个数和值的个数必须一致

⑤字段可以省略,但默认所有字段,并且顺序和表中的存储顺序一致

2、修改 update

1)语法

# 修改单表语法
update 表名 
set 字段=新值,字段=新值
【where 条件】
# 修改多表语法:
update 表1 别名1,表2 别名2
set 字段=新值,字段=新值
where 连接条件
and 筛选条件

2)栗子

# 更新单个表
update info 
set name='Cherich',age=24
where id = 1;

3、删除 delete

1)语法

#方式一:delete语句 
# 单表的删除:★
delete from 表名 【where 筛选条件】

# 多表的删除:
delete 别名1,别名2
from 表1 别名1,表2 别名2
where 连接条件
and 筛选条件;
#方式二:
truncate table 表名

2)栗子

# 单表删除
delete from info where age = 18;
# 多表删除
delete from info a inner join order b on a.id=b.id
where a.name='cherich';
# 清空整个表
truncate table info;

3)两种方式区别

① truncate不能加where条件,而delete可以加where条件

② truncate的效率高一点

③truncate 删除带自增长的列的表后,如果再插入数据,数据从1开;delete 删除带自增长列的表后,如果再插入数据,数据从上一次的断点处开始

④truncate删除不能回滚,delete删除可以回滚

DDL语言的学习

1、库和表的管理

1)库的管理:

# 创建库
create database 库名
# 删除库
drop database 库名

2)表的管理:

#1.创建表
CREATE TABLE IF NOT EXISTS info(
  stuId INT,
  stuName VARCHAR(20),
  gender CHAR,
  bornDate DATETIME
 
 # 查看info表结构 
 DESC info;

#2.修改表 alter
语法:ALTER TABLE 表名 ADD|MODIFY|DROP|CHANGE COLUMN 字段名 【字段类型】;
#①修改字段名
ALTER TABLE info CHANGE  COLUMN sex gender CHAR;
#②修改表名
ALTER TABLE info RENAME [TO]  studentinfo;
#③修改字段类型和列级约束
ALTER TABLE info MODIFY COLUMN borndate DATE ;
#④添加字段
ALTER TABLE info ADD COLUMN email VARCHAR(20) first;
#⑤删除字段
ALTER TABLE info DROP COLUMN email;

#3.删除表
DROP TABLE [IF EXISTS] info;

# 4.表的复制
# ①仅仅复制表的结构
CREATE TABLE copy LIKE info;
# ②复制表结构和数据
CREATE TABLE copy1
SELEC * FROM info; 
# ③复制部分数据
CREATE TABLE copy2
SELEC stuId ,stuName FROM info
WHERE gender ='女'; 
# ④仅仅复制部分结构
CREATE TABLE copy3
SELEC stuId ,stuName FROM info
WHERE 0;
#(或者WHERE 1=2)

注意:对于表和库的管理,语句理解就好。工作中最方便的是直接在Navicat中直接操作。那么,这里重要的是复制表,它的需求通常是直接复制表的结构或数据,或者部分数据及部分结构。不需要重新再创建表结构,导数据。直接用SQL,效率会很高,且不容易出错。

2、常见类型

上面在创建表时,涉及到数据类型。它和Python程序语言类似,也有自己的数据类型。都是在存储数据时,要对数据类型进行限制,保证插入数据时的准确性。分类分别是数值型、字符型、日期型。图中标记部分为常用。

3、常见约束

上面在创建表时涉及到约束,它是工作中非常重要的。我们从一个问题场景来看,下面是一个真实的面试题。我们第一反应是"报错!",但是面试官想听的是背后报错原因及解决方案。下面,带着问题来学习约束。

约束是一种限制,用于限制表中的数据结构,为了保证表中的数据的准确和可靠性、一致性。比如:创建用户表时,为了保证每一个用户唯一性,就需要进行约束。添加约束的时机分别是创建表、修改表时。SQL中有五大常用约束。如下:

①NOT NULL 非空约束,保证该字段的值不为空。如:用户ID

②DEFAULT 默认约束,字段如果不插入数据也有默认值。如:性别

③UNIQUE 唯一约束,可以为空。如:商品类别

④PRIMARY KEY 主键,保证字段唯一性、非空。如:ID,员工编号

⑤FOREIGN KEY 外键,用于限制两个表之间的关系,用于保证该字段的值必须来自主表的关联列的值。如:用户表里有个外键是order_id, order_id是order的主键。下图是约束在Navicat中设置的对应位置。

最后回答下上面的问题:原因是int类型的id字段最大数据量支持到4294967295,如果超过则会报错。解决方案:①检查id字段是否是主键②将id的类型转换为 bigint。

好,今天学习到这里。本节内容相对上一节要简单些。虽然简单,但每个知识点都是工作中常用的。这篇文章主要是SQL的增删改和表和库的管理。明天继续学习SQL的事务及视图。一起加油!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,711评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,932评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,770评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,799评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,697评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,069评论 1 276
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,535评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,200评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,353评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,290评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,331评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,020评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,610评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,694评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,927评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,330评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,904评论 2 341

推荐阅读更多精彩内容

  • 今天感恩节哎,感谢一直在我身边的亲朋好友。感恩相遇!感恩不离不弃。 中午开了第一次的党会,身份的转变要...
    迷月闪星情阅读 10,543评论 0 11
  • 彩排完,天已黑
    刘凯书法阅读 4,175评论 1 3
  • 表情是什么,我认为表情就是表现出来的情绪。表情可以传达很多信息。高兴了当然就笑了,难过就哭了。两者是相互影响密不可...
    Persistenc_6aea阅读 123,665评论 2 7