首页 运维知识 关于MySQL之一段完整的创建表格的SQL代码

关于MySQL之一段完整的创建表格的SQL代码

一段完整的创建表格的SQL代码 使用SQL语句创建一张表,不仅可以可以快速熟悉SQL语句,还可以从这看出一个人对该技能点的熟悉程度。 这里先说明几点: PRIMARY KEY:主键…

一段完整的创建表格的SQL代码

使用SQL语句创建一张表,不仅可以可以快速熟悉SQL语句,还可以从这看出一个人对该技能点的熟悉程度。

这里先说明几点:

PRIMARY KEY:主键,一张表中只允许有一个PRIMARY KEY,不允许有NULL值。
UNIQUE KEY:约束,约束确保在非主键列中不输入重复的值,允许有NULL值,而PRIMARY KEY 不允许有NULL值,且一张表中只有一个PRIMARY KEY,而UNIQUE KEY在一张表中可以有多个。
ENGINE=INNODB,表示SQL数据库引擎为INNODB,操作数据库级别为表中的行级别(可以并发操作两行不同的数据库),另外一个引擎为MYISAM,操作数据库级别为整张表,相对来说,MYISAM操作的效率高于INNODB,不过一般数据库中都使用的是INNODB。

-- 如果test数据库不存在,就创建test数据库:
CREATE DATABASE IF NOT EXISTS test;

-- 切换到test数据库
USE test;

-- 删除classes表和students表(如果存在):
DROP TABLE IF EXISTS classes;
DROP TABLE IF EXISTS students;

-- 创建classes表:
CREATE TABLE classes (
id BIGINT NOT NULL AUTO_INCREMENT,
name VARCHAR(100) NOT NULL,
PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- 创建students表:
CREATE TABLE students (
id BIGINT NOT NULL AUTO_INCREMENT,
class_id BIGINT NOT NULL,
name VARCHAR(100) NOT NULL,
gender VARCHAR(1) NOT NULL,
score INT NOT NULL,
PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- 插入classes记录:
INSERT INTO classes(id, name) VALUES (1, \'一班\');
INSERT INTO classes(id, name) VALUES (2, \'二班\');
INSERT INTO classes(id, name) VALUES (3, \'三班\');
INSERT INTO classes(id, name) VALUES (4, \'四班\');

-- 插入students记录:
INSERT INTO students (id, class_id, name, gender, score) VALUES (1, 1, \'小明\', \'M\', 90);
INSERT INTO students (id, class_id, name, gender, score) VALUES (2, 1, \'小红\', \'F\', 95);
INSERT INTO students (id, class_id, name, gender, score) VALUES (3, 1, \'小军\', \'M\', 88);
INSERT INTO students (id, class_id, name, gender, score) VALUES (4, 1, \'小米\', \'F\', 73);
INSERT INTO students (id, class_id, name, gender, score) VALUES (5, 2, \'小白\', \'F\', 81);
INSERT INTO students (id, class_id, name, gender, score) VALUES (6, 2, \'小兵\', \'M\', 55);
INSERT INTO students (id, class_id, name, gender, score) VALUES (7, 2, \'小林\', \'M\', 85);
INSERT INTO students (id, class_id, name, gender, score) VALUES (8, 3, \'小新\', \'F\', 91);
INSERT INTO students (id, class_id, name, gender, score) VALUES (9, 3, \'小王\', \'M\', 89);
INSERT INTO students (id, class_id, name, gender, score) VALUES (10, 3, \'小丽\', \'F\', 85);

-- OK:
SELECT \'ok\' as \'result:\';
免责声明:文章内容不代表本站立场,本站不对其内容的真实性、完整性、准确性给予任何担保、暗示和承诺,仅供读者参考,文章版权归原作者所有。如本文内容影响到您的合法权益(内容、图片等),请及时联系本站,我们会及时删除处理。

作者: 小小编

为您推荐

dell R710 更换raid卡后,raid卡信息没有了,处理方案

dell R710 更换raid卡后,raid卡信息没有了,处理方案

1.将一台服务器(A)的硬盘依次拔出,按相同顺序插入另一台同样配置的服务器(B) 2.启动服务器(B) 3.按提示键盘按...
PL SQL Developer 13连接Oracle数据库并导出数据详细操作教程方法

PL SQL Developer 13连接Oracle数据库并导出数据详细操作教程方法

下载 并安装 PL SQL Developer 13,默认支持中文语言 ========================...
关于一条sql语句在mysql中是如何执行的

关于一条sql语句在mysql中是如何执行的

最近开始在学习mysql相关知识,自己根据学到的知识点,根据自己的理解整理分享出来,本篇文章会分析下一个sql语句在my...
关于sql注入姿势总结(mysql)

关于sql注入姿势总结(mysql)

前言 学习了sql注入很长时间,但是仍然没有系统的了解过,这次总结一波,用作学习的资料。 从注入方法分:基于报错、基于布...
关于Oracle SQL外连接

关于Oracle SQL外连接

SQL提供了多种类型的连接方式,它们之间的区别在于:从相互交叠的不同数据集合中选择用于连接的行时所采用的方法不同。 连接...

发表回复

返回顶部