mysql8建立的table保存在哪_【SQL必知必会笔记(1)】数据库基础、SQL、MySQL8.0.16下数据库、表的创建及数据插入...

1.数据库基础

SQL是一种专门用来与数据库沟通的语言,因此在学习SQL之前,我们应该对数据库和数据库技术的某些基本概念有所了解。

本节主要介绍数据库及数据库技术的重要基本概念。

1.1 数据库(database)

数据库:保存//有组织的数据//的容器(通常是一个文件或者一组文件)。

最简单的办法是将数据库想象为一个文件柜。这个文件柜是一个存放数据的物理位置,不管数据是什么,也不管数据是如何组织的。

注意:

我们常说的数据库软件,应该称为数据库管理系统(DBMS)

数据库,则是通过DBMS操纵的容器

1.2 表(table)

你往文件柜里放资料时,并不是随便将他们扔进某个抽屉就完事了,而是在文件柜中创建文件,然后将相关的资料放入特定的文件中。

在数据库领域中,这种文件称为表。表是一种结构化的文件,可以用来存储某种特定类型的数据。例如,表可以保存顾客清单、产品目录,或者其他信息清单。

表:某种特定类型数据的结构化清单。

这里的关键一点在于,存储在表中的数据是同一类型的数据或清单。

但是这里的类型不是指数据类型,比如,不应该将顾客的清单与订单的清单存储在同一个数据库表中,

顾客的清单为一个类型,订单的清单为一个类型。

表名:每个表都有一个名字来标识自己,这个名字在同一个数据库中是唯一的。

说明:使表名成为唯一的,实际上是数据库名和表名等的组合。有的数据库还使用数据库拥有者的名字作为唯一名的一部分。

也就是说,虽然在相同的数据库中不能两次使用相同的表名,但在不同的数据库中完全可以使用相同的表名。

表具有一些特性,这些特性定义了数据在表中如何存储,包含存储什么样的数据、数据如何分解、各部分信息如何命名等信息。

描述表的这组信息就是所谓的模式。

模式(schema):关于数据库和表的布局及特性的信息。

模式可以用来描述数据库中特定的表,也可以用来描述整个数据库(和其中表的关系)。

1.3 列和数据类型

列(column):表中的一个字段。

所有表都是由一个或多个列组成的;

列储存表中某部分的信息。

可以根据自己的具体需求,来决定把数据分解到何种程度。

数据类型(datatype):所允许的//数据的类型,定义了列可以存储哪些数据种类。

每个表列都有相应的数据类型,它限制(或允许)该列中存储的数据。

数据类型还帮助正确地分类数据,并在优化磁盘使用方面起到重要的作用。因此,在创建表时必须特别关注所用的数据类型。

注意: 数据类型兼容。在创建表结构时,要注意不同DBMS在数据类型种类、名称等方面的差异。

1.4 行

行(row):表中的一个记录。

表中的数据是按行存储的,所保存的每个记录存储在自己的行内。

1.5 主键

主键(primary key):一列(或一组列),其值能够唯一标识表中的每一行。

提示:应该总是定义主键。虽然并不总是需要主键,但多数数据库设计者都会保证他们创建的每个表具有一个主键,以便于以后的数据操作和管理。

表中的任何列都可以作为主键,只要它满足以下条件:

任意两行都不具有相同的主键值;

每一行必须具有一个主键值(主键列不允许NULL值);

主键列中的值不允许修改或更新;

主键值不能重用(如果某行从表中删除,它的主键不能赋给以后的新行)

可以用一列或多列作为主键,在使用多列作为主键时:

上述条件必须应用到//作为主键的//所有列,所有列值的组合必须是唯一的(但单个列的值可以不唯一)

2.什么是SQL

SQL:是结构化查询语言(Structured Query Language)的缩写,是一种专门用来与//数据库//沟通的语言。

设计SQL的目的:提供一种从数据库中读写数据的简单有效的方法。

SQL的优点:

几乎所有重要的DBMS都支持SQL,所以学习此语言使我们几乎能与所有数据库打交道。

简单易学。SQL的语句全都是由有很强描述性的英语单词组成,而且这些单词的数目不多。

SQL虽然看上去很简单,但实际上是一种强有力的语言,灵活使用其语言元素,可以进行非常复杂和高级的数据库操作。

说明:

SQL的扩展。许多DBMS厂商通过增加语句或指令,对SQL进行了扩展。这种扩展的目的是提供执行特定操作的额外功能或简化方法。

标准SQL由ANSI标准委员会管理,从而称为ANSI SQL。

所有主要的DBMS,都支持ANSI SQL,也有自己的扩展。各个实现都有自己的名称,如PL/SQL、Transact-SQL等。

本系列笔记所涉及的主要是ANSI SQL。在使用某种DBMS特定的SQL时,会特别说明。

3.创建后续练习所需数据库、表(MySQL8.0.16)

3.1 创建数据库

成功登陆MySQL之后,执行CREATE DATABASE tysql;,创建数据库tysql;

然后执行USE tysql;,使用tysql数据库。

下面的一系列操作就是在tysql创建各种数据表,并规定主、外键约束,插入数据

3.2 创建数据库表

编写SQL语句需要良好地理解基本数据库设计。如果不知道什么信息存放在什么表中,表与表之间如何互相关联,行中数据如何分解,那么编写高效的SQL是不可能的。

数据库管理员通常使用关系图来说明数据库表的关联方式。外键定义了这些关系。下图是要创建的5个表的关系图:

74b7742892382f2c10a65b717573a659.png

3.2.1开始创建数据库表

Customers表

CREATE TABLE Customers

(

cust_id char(10) NOT NULL ,

cust_name char(50) NOT NULL ,

cust_address char(50) NULL ,

cust_city char(50) NULL ,

cust_state char(5) NULL ,

cust_zip char(10) NULL ,

cust_country char(50) NULL ,

cust_contact char(50) NULL ,

cust_email char(255) NULL

);

OrderItems表

CREATE TABLE OrderItems

(

order_num int NOT NULL ,

order_item int NOT NULL ,

prod_id char(10) NOT NULL ,

quantity int NOT NULL ,

item_price decimal(8,2) NOT NULL

);

Orders表

CREATE TABLE Orders

(

order_num int NOT NULL ,

order_date datetime NOT NULL ,

cust_id char(10) NOT NULL

);

Products表

CREATE TABLE Products

(

prod_id char(10) NOT NULL ,

vend_id char(10) NOT NULL ,

prod_name char(255) NOT NULL ,

prod_price decimal(8,2) NOT NULL ,

prod_desc text NULL

);

Vendors表

CREATE TABLE Vendors

(

vend_id char(10) NOT NULL ,

vend_name char(50) NOT NULL ,

vend_address char(50) NULL ,

vend_city char(50) NULL ,

vend_state char(5) NULL ,

vend_zip char(10) NULL ,

vend_country char(50) NULL

);

3.2.2 为各表定义主、外键约束

定义主键约束:

ALTER TABLE Customers ADD PRIMARY KEY (cust_id);

ALTER TABLE OrderItems ADD PRIMARY KEY (order_num, order_item);

ALTER TABLE Orders ADD PRIMARY KEY (order_num);

ALTER TABLE Products ADD PRIMARY KEY (prod_id);

ALTER TABLE Vendors ADD PRIMARY KEY (vend_id);

定义外键约束:

ALTER TABLE OrderItems ADD CONSTRAINT FK_OrderItems_Orders FOREIGN KEY (order_num) REFERENCES Orders (order_num);

ALTER TABLE OrderItems ADD CONSTRAINT FK_OrderItems_Products FOREIGN KEY (prod_id) REFERENCES Products (prod_id);

ALTER TABLE Orders ADD CONSTRAINT FK_Orders_Customers FOREIGN KEY (cust_id) REFERENCES Customers (cust_id);

ALTER TABLE Products ADD CONSTRAINT FK_Products_Vendors FOREIGN KEY (vend_id) REFERENCES Vendors (vend_id);

3.3 插入数据

Customers表

INSERT INTO Customers(cust_id, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country, cust_contact, cust_email)

VALUES('1000000001', 'Village Toys', '200 Maple Lane', 'Detroit', 'MI', '44444', 'USA', 'John Smith', 'sales@villagetoys.com');

INSERT INTO Customers(cust_id, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country, cust_contact)

VALUES('1000000002', 'Kids Place', '333 South Lake Drive', 'Columbus', 'OH', '43333', 'USA', 'Michelle Green');

INSERT INTO Customers(cust_id, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country, cust_contact, cust_email)

VALUES('1000000003', 'Fun4All', '1 Sunny Place', 'Muncie', 'IN', '42222', 'USA', 'Jim Jones', 'jjones@fun4all.com');

INSERT INTO Customers(cust_id, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country, cust_contact, cust_email)

VALUES('1000000004', 'Fun4All', '829 Riverside Drive', 'Phoenix', 'AZ', '88888', 'USA', 'Denise L. Stephens', 'dstephens@fun4all.com');

INSERT INTO Customers(cust_id, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country, cust_contact)

VALUES('1000000005', 'The Toy Store', '4545 53rd Street', 'Chicago', 'IL', '54545', 'USA', 'Kim Howard');

Vendors表

INSERT INTO Vendors(vend_id, vend_name, vend_address, vend_city, vend_state, vend_zip, vend_country)

VALUES('BRS01','Bears R Us','123 Main Street','Bear Town','MI','44444', 'USA');

INSERT INTO Vendors(vend_id, vend_name, vend_address, vend_city, vend_state, vend_zip, vend_country)

VALUES('BRE02','Bear Emporium','500 Park Street','Anytown','OH','44333', 'USA');

INSERT INTO Vendors(vend_id, vend_name, vend_address, vend_city, vend_state, vend_zip, vend_country)

VALUES('DLL01','Doll House Inc.','555 High Street','Dollsville','CA','99999', 'USA');

INSERT INTO Vendors(vend_id, vend_name, vend_address, vend_city, vend_state, vend_zip, vend_country)

VALUES('FRB01','Furball Inc.','1000 5th Avenue','New York','NY','11111', 'USA');

INSERT INTO Vendors(vend_id, vend_name, vend_address, vend_city, vend_state, vend_zip, vend_country)

VALUES('FNG01','Fun and Games','42 Galaxy Road','London', NULL,'N16 6PS', 'England');

INSERT INTO Vendors(vend_id, vend_name, vend_address, vend_city, vend_state, vend_zip, vend_country)

VALUES('JTS01','Jouets et ours','1 Rue Amusement','Paris', NULL,'45678', 'France');

Products表

INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)

VALUES('BR01', 'BRS01', '8 inch teddy bear', 5.99, '8 inch teddy bear, comes with cap and jacket');

INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)

VALUES('BR02', 'BRS01', '12 inch teddy bear', 8.99, '12 inch teddy bear, comes with cap and jacket');

INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)

VALUES('BR03', 'BRS01', '18 inch teddy bear', 11.99, '18 inch teddy bear, comes with cap and jacket');

INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)

VALUES('BNBG01', 'DLL01', 'Fish bean bag toy', 3.49, 'Fish bean bag toy, complete with bean bag worms with which to feed it');

INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)

VALUES('BNBG02', 'DLL01', 'Bird bean bag toy', 3.49, 'Bird bean bag toy, eggs are not included');

INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)

VALUES('BNBG03', 'DLL01', 'Rabbit bean bag toy', 3.49, 'Rabbit bean bag toy, comes with bean bag carrots');

INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)

VALUES('RGAN01', 'DLL01', 'Raggedy Ann', 4.99, '18 inch Raggedy Ann doll');

INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)

VALUES('RYL01', 'FNG01', 'King doll', 9.49, '12 inch king doll with royal garments and crown');

INSERT INTO Products(prod_id, vend_id, prod_name, prod_price, prod_desc)

VALUES('RYL02', 'FNG01', 'Queen doll', 9.49, '12 inch queen doll with royal garments and crown');

Orders表

INSERT INTO Orders(order_num, order_date, cust_id)

VALUES(20005, '2012-05-01', '1000000001');

INSERT INTO Orders(order_num, order_date, cust_id)

VALUES(20006, '2012-01-12', '1000000003');

INSERT INTO Orders(order_num, order_date, cust_id)

VALUES(20007, '2012-01-30', '1000000004');

INSERT INTO Orders(order_num, order_date, cust_id)

VALUES(20008, '2012-02-03', '1000000005');

INSERT INTO Orders(order_num, order_date, cust_id)

VALUES(20009, '2012-02-08', '1000000001');

OrderItems表

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20005, 1, 'BR01', 100, 5.49);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20005, 2, 'BR03', 100, 10.99);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20006, 1, 'BR01', 20, 5.99);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20006, 2, 'BR02', 10, 8.99);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20006, 3, 'BR03', 10, 11.99);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20007, 1, 'BR03', 50, 11.49);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20007, 2, 'BNBG01', 100, 2.99);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20007, 3, 'BNBG02', 100, 2.99);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20007, 4, 'BNBG03', 100, 2.99);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20007, 5, 'RGAN01', 50, 4.49);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20008, 1, 'RGAN01', 5, 4.99);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20008, 2, 'BR03', 5, 11.99);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20008, 3, 'BNBG01', 10, 3.49);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20008, 4, 'BNBG02', 10, 3.49);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20008, 5, 'BNBG03', 10, 3.49);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20009, 1, 'BNBG01', 250, 2.49);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20009, 2, 'BNBG02', 250, 2.49);

INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)

VALUES(20009, 3, 'BNBG03', 250, 2.49);

好了,到目前为止我们后续练习需要用到的数据库、表已经创建完毕,并成功插入数据。

后面系列笔记的全部练习全部基于本部分创建的数据库进行。

参考资料:

1.《SQL必知必会》Ben Forta。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值