sql学习笔记1

144 阅读8分钟

「这是我参与2022首次更文挑战的第12天,活动详情查看:2022首次更文挑战

1.环境搭建

在终端登陆(不设置环境变量):

/usr/local/mysql/bin/mysql -u root -p

password:17351735

在终端输入mysql,提示找不到命令,设置环境变量。

PATH="$PATH":/usr/local/mysql/bin

export PATH=$PATH:/usr/local/mysql/bin

source ~/.bash_profile

mysql -u root -p

之后输入密码:17351735,以后就可以通过 mysql -u root -p在终端登陆。

客户端登陆:

datatrip(付费)

dbeaver(免费)

2.认识数据库

数据库管理系统:Database Management System,DBMS

2.1DBMS类型

有本叫做《七周七数据库》的书,每周介绍1种数据库类型,总共介绍了5种类型,7个数据库。

2.1.1层次数据库(Hierarchical Database,HDB)

2.1.2关系数据库(Relational Database,RDB)

  • Oracle Database:甲骨文公司的RDBMS
  • SQL Server:微软公司的RDBMS
  • DB2:IBM公司的RDBMS
  • PostgreSQL:开源的RDBMS
  • MySQL:开源的RDBMS

如上是5种具有代表性的RDBMS,其特点是由行和列组成的二维表来管理数据,这种类型的 DBMS 称为关系数据库管理系统(Relational Database Management System,RDBMS)。

2.1.3面向对象数据库(Object Oriented Database,OODB)

2.1.4XML数据库(XML Database,XMLDB)

2.1.5键值存储系统(Key-Value Store,KVS)

举例:MongoDB

这个笔记仅讲述关系数据库,即RDBMS,重点讲mysql。

RDBMS常见系统结构为c/s类型。

数据库按照记录的形式存储数据。

用excel做类比:

一条记录相当于excel里的一行。

一个列相当于一个字段。

行和列交汇的地方,称之为单元格。

表头,也就是列名。

2.2SQL语句的3大类

使用SQL语句来操作数据库。

sql语句可分为3类。

2.2.1DDL:数据定义语言

DDL(Data Definition Language,数据定义语言) 用来创建或者删除存储数据用的数据库以及数据库中的表等对象。DDL 包含以下几种指令。

  • CREATE : 创建数据库和表等对象
  • DROP : 删除数据库和表等对象
  • ALTER : 修改数据库和表等对象的结构

2.2.2DML:数据操纵语言

DML(Data Manipulation Language,数据操纵语言) 用来查询或者变更表中的记录。DML 包含以下几种指令。

  • SELECT :查询表中的数据
  • INSERT :向表中插入新数据
  • UPDATE :更新表中的数据
  • DELETE :删除表中的数据

实际使用的 SQL 语句当中有 90% 属于 DML

2.2.3DCL:数据控制语言

DCL(Data Control Language,数据控制语言) 用来确认或者取消对数据库中的数据进行的变更。除此之外,还可以对 RDBMS 的用户是否有权限操作数据库中的对象(数据库表等)进行设定。DCL 包含以下几种指令。

  • COMMIT : 确认对数据库中的数据进行的变更
  • ROLLBACK : 取消对数据库中的数据进行的变更
  • GRANT : 赋予用户操作权限
  • REVOKE : 取消用户的操作权限

2.3SQL书写规范

  • SQL语句要以分号( ; )结尾
  • SQL 不区分关键字的大小写,但是插入到表中的数据是区分大小写的
  • win 系统默认不区分表名及字段名的大小写
  • linux / mac 默认严格区分表名及字段名的大小写 * 本教程已统一调整表名及字段名的为小写,以方便初学者学习使用。
  • 常数的书写方式是固定的

'abc', 1234, '26 Jan 2010', '10/01/26', '2010-01-26'......

  • 单词需要用半角空格或者换行来分隔
  • 只能使用半角英文字母、数字、下划线(_)作为数据库、表和列的名称
  • 名称必须以半角英文字母开头
  • 注释:--

SQL 语句的单词之间需使用半角空格或换行符来进行分隔,且不能使用全角空格作为单词的分隔符,否则会发生错误,出现无法预期的结果。

请大家认真查阅《附录1 - SQL 语法规范》,养成规范的书写习惯。

2.4操作与语句

创建数据库

CREATE DATABASE < 数据库名称 > ;
CREATE DATABASE shop;

创建数据表

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

----------------------------------------

CREATE TABLE product
(product_id CHAR(4) NOT NULL, -- 商品编号
 product_name VARCHAR(100) NOT NULL, -- 商品名称
 product_type VARCHAR(32) NOT NULL, -- 商品种类
 sale_price INTEGER , -- 销售单价
 purchase_price INTEGER , -- 进货单价
 regist_date DATE , -- 登记日期
 PRIMARY KEY (product_id));

四种最基本数据类型

  • INTEGER 型

用来指定存储整数的列的数据类型(数字型),不能存储小数。

  • CHAR 型

用来存储定长字符串,当列中存储的字符串长度达不到最大长度的时候,使用半角空格进行补足,由于会浪费存储空间,所以一般不使用。

  • VARCHAR 型

用来存储可变长度字符串,定长字符串在字符数未达到最大长度时会用半角空格补足,但可变长字符串不同,即使字符数未达到最大长度,也不会用半角空格补足。

  • DATE 型

用来指定存储日期(年月日)的列的数据类型(日期型)。

约束

约束是除了数据类型之外,对列中存储的数据进行限制或者追加条件的功能。

NOT NULL是非空约束,即该列必须输入数据。

PRIMARY KEY是主键约束,代表该列是唯一值,可以通过该列取出特定的行的数据。

DEFAULT DEFAULT 0 默认值

删除表

DROP TABLE < 表名 > ;

DROP TABLE product;

更新表(alter:添加与删除列)

执行后无法恢复

-- 添加列
ALTER TABLE < 表名 > ADD COLUMN < 列的定义 >;
-- 添加一列可以存储100位的可变长字符串的 product_name_pinyin 列
ALTER TABLE product ADD COLUMN product_name_pinyin VARCHAR(100);
-- 删除列
ALTER TABLE < 表名 > DROP COLUMN < 列名 >;

ALTER TABLE product DROP COLUMN product_name_pinyin;

-- 清空表内容
TRUNCATE TABLE TABLE_NAME;

删除列的3种方法比较:

相比drop / deletetruncate用来清除数据时,速度最快。

更新数据(update)

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  
UPDATE product
   SET regist_date = NULL
 WHERE product_id = '0008';  
 
 --------------------------------------------
 --UPDATE 语句的 SET 子句支持同时将多个列作为更新对象。
 -- 基础写法,一条UPDATE语句只更新一列
UPDATE product
   SET sale_price = sale_price * 10
 WHERE product_type = '厨房用具';
UPDATE product
   SET purchase_price = purchase_price / 2
 WHERE product_type = '厨房用具'
 
 -- 合并后的写法
UPDATE product
   SET sale_price = sale_price * 10,
       purchase_price = purchase_price / 2
 WHERE product_type = '厨房用具';  

null值:可用于数据清空。但是,只有未设置 NOT NULL 约束和主键约束的列才可以清空为NULL


插入数据(insert)

INSERT INTO <表名> (列1, 列2, 列3, ……) VALUES (值1, 值2, 值3, ……);
 --------------------------------------------
CREATE TABLE productins
(product_id    CHAR(4)      NOT NULL,
product_name   VARCHAR(100) NOT NULL,
product_type   VARCHAR(32)  NOT NULL,
sale_price     INTEGER      DEFAULT 0,
purchase_price INTEGER ,
regist_date    DATE ,
PRIMARY KEY (product_id)); 

-- 包含列清单
INSERT INTO productins (product_id, product_name, product_type, sale_price, purchase_price, regist_date) VALUES ('0005', '高压锅', '厨房用具', 6800, 5000, '2009-01-15');
-- 省略列清单
INSERT INTO productins VALUES ('0005', '高压锅', '厨房用具', 6800, 5000, '2009-01-15');  

-- 通常的INSERT
INSERT INTO productins VALUES ('0002', '打孔器', '办公用品', 500, 320, '2009-09-11');
INSERT INTO productins VALUES ('0003', '运动T恤', '衣服', 4000, 2800, NULL);
INSERT INTO productins VALUES ('0004', '菜刀', '厨房用具', 3000, 2800, '2009-09-20');

-- 多行INSERT ( DB2、SQL、SQL Server、 PostgreSQL 和 MySQL多行插入)
INSERT INTO productins VALUES ('0002', '打孔器', '办公用品', 500, 320, '2009-09-11'),
                              ('0003', '运动T恤', '衣服', 4000, 2800, NULL),
                              ('0004', '菜刀', '厨房用具', 3000, 2800, '2009-09-20');  
-- Oracle中的多行INSERT
INSERT ALL INTO productins VALUES ('0002', '打孔器', '办公用品', 500, 320, '2009-09-11')
           INTO productins VALUES ('0003', '运动T恤', '衣服', 4000, 2800, NULL)
           INTO productins VALUES ('0004', '菜刀', '厨房用具', 3000, 2800, '2009-09-20')
SELECT * FROM DUAL;  
-- DUAL是Oracle特有(安装时的必选项)的一种临时表A。因此“SELECT *FROM DUAL” 部分也只是临时性的,并没有实际意义。 

- DML :插入数据
STARTTRANSACTION;
INSERT INTO product VALUES('0001', 'T恤衫', '衣服', 1000, 500, '2009-09-20');
INSERT INTO product VALUES('0002', '打孔器', '办公用品', 500, 320, '2009-09-11');
INSERT INTO product VALUES('0003', '运动T恤', '衣服', 4000, 2800, NULL);
INSERT INTO product VALUES('0004', '菜刀', '厨房用具', 3000, 2800, '2009-09-20');
INSERT INTO product VALUES('0005', '高压锅', '厨房用具', 6800, 5000, '2009-01-15');
INSERT INTO product VALUES('0006', '叉子', '厨房用具', 500, NULL, '2009-09-20');
INSERT INTO product VALUES('0007', '擦菜板', '厨房用具', 880, 790, '2008-04-28');
INSERT INTO product VALUES('0008', '圆珠笔', '办公用品', 100, NULL, '2009-11-11');
COMMIT;

2.5练习

2.5.1

编写一条 CREATE TABLE 语句,用来创建一个包含表 1-A 中所列各项的表 Addressbook (地址簿),并为 regist_no (注册编号)列设置主键约束

表1-A 表 Addressbook (地址簿)中的列

create table Addressbook(
regist_no integer not null,
name varchar(128) not null,
address varchar(256) not null,
tel_no char(10),
mail_address char(20),
primary key (regist_no)
);

2.5.2

假设在创建练习1.1中的 Addressbook 表时忘记添加如下一列 postal_code (邮政编码)了,请把此列添加到 Addressbook 表中。

列名 : postal_code

数据类型 :定长字符串类型(长度为 8)

约束 :不能为 NULL

alter table Addressbook add column postal_code char(8) not null;

2.5.3

编写 SQL 语句来删除 Addressbook 表。

drop table Addressbook;

2.5.4

编写 SQL 语句来恢复删除掉的 Addressbook 表。

create table Addressbook(
regist_no integer not null,
name varchar(128) not null,
address varchar(256) not null,
tel_no char(10),
mail_address char(20),
postal_code char(8) not null,
primary key (regist_no)
);