第一章 数据库、表的主要操作

参考:https://github.com/datawhalechina/wonderful-sql
数据库:DB
数据库管理系统:DBMS
![在这里插入图片描述](https://img-blog.csdnimg.cn/c13f2c1136b744ac91e9124b07d12fa9.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBASm95Y2UwMTA1,size_20,color_FFFFFF,t_70,g_se,x_16在这里插入图片描述

1 RDBMS

  • 行:记录;列:字段
  • 完全基于标准 SQL 的 RDBMS 很少,通常需要根据不同的 RDBMS 来编写特定的 SQL 语句,原则上,本课程介绍的是标准 SQL 的书写方式

1.1 SQL语言分类

在这里插入图片描述

1.2 SQL的基本书写规则

在这里插入图片描述

  • 并列的、一个括号里的要逗号

2 DDL

  • create
  • drop
  • alter
  • DML:select、insert、update、delete、DCL

2.1 数据库、表、列的命名规则

  • 只能使用半角英文字母、数字、下划线_
  • 名称必须以半角英文字母开头

2.2 部分数据类型

在这里插入图片描述

2.3 部分约束

在这里插入图片描述

  • default 0:默认列设置为0值

2.4 数据库:创建

create database <数据库名>

在这里插入图片描述

2.5 表:创建、删除、更新

2.5.1 创建表、删除表:create、drop

  • 创建表
CREATE TABLE < 表名 >
( < 列名 1> < 数据类型 > < 该列所需约束 > ,
  < 列名 2> < 数据类型 > < 该列所需约束 > ,
  < 列名 3> < 数据类型 > < 该列所需约束 > ,
  < 列名 4> < 数据类型 > < 该列所需约束 > ,
  .
  .
  .
  < 该表的约束 1> , < 该表的约束 2> ,……);

在这里插入图片描述
在这里插入图片描述

  • 删除表
DROP TABLE < 表名 > ;

2.5.2 向表中插入数据:insert

-- 包含列清单
INSERT INTO <表名> (1,2,3, ……) VALUES (1,2,3, ……); 
INSERT INTO <表名> (1,2,3, ……) VALUES (1,2,3, ……); 
-- 省略列清单
INSERT INTO <表名>  VALUES (1,2,3, ……);  
-- 多列添加
INSERT INTO <表名>  VALUES (1,2,3, ……),
                          (1,2,3, ……);
-- 值可填null
  • 单列添加
    在这里插入图片描述
  • 多列添加
    在这里插入图片描述

2.5.3 从其他表复制数据

INSERT INTO productcopy (product_id, product_name, product_type, sale_price, purchase_price, regist_date)
SELECT product_id, product_name, product_type, sale_price, purchase_price, regist_date
  FROM Product; 

2.5.4 添加列、删除列:alter+add/drop

  • 添加列
ALTER TABLE < 表名 > ADD COLUMN < 列的定义 >;

在这里插入图片描述

  • 删除列
ALTER TABLE < 表名 > DROP COLUMN < 列名 >;

在这里插入图片描述

2.5.5 列数据更新:update+set

UPDATE <表名>
   SET <列名> = <表达式> [, <列名2>=<表达式2>...]
 WHERE <条件>  -- 可选,非常重要。
 ORDER BY 子句  --可选
 LIMIT 子句 --可选
  • 单列更新
-- 修改所有的注册时间
UPDATE product
   SET regist_date = '2009-10-10';  
-- 仅修改部分商品的单价
UPDATE product
   SET sale_price = sale_price * 10
 WHERE product_type = '厨房用具';  
 -- 将商品编号为0008的数据(圆珠笔)的登记日期更新为NULL 
 -- 只有未设置 NOT NULL 约束和主键约束的列才可以清空为NULL 
UPDATE product
   SET regist_date = NULL
 WHERE product_id = '0008'; 
  • 多列更新
-- 合并后的写法
UPDATE product
   SET sale_price = sale_price * 10,
       purchase_price = purchase_price / 2
 WHERE product_type = '厨房用具';  

2.5.6 清空表内容:truncate

TRUNCATE TABLE TABLE_NAME;
-- 小写
truncate table <表名>;

3 练习

  • 3.1
    在这里插入图片描述
    在这里插入图片描述
  • 3.2
    在这里插入图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值