MySQL第一章第二章

本文介绍了数据库的基本概念,包括关系型数据库如MySQL和非关系型数据库的区别,以及数据库管理系统DBMS的作用。详细阐述了MySQL的安装和基本命令,如查看和操作数据库。文章还深入讨论了数据库的列类型、字段属性以及如何创建和修改数据库表,特别是外键的概念和在创建表时添加外键约束的方法。
摘要由CSDN通过智能技术生成

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档



1.1、什么是数据库
数据库:DB(DataBase)

概念:数据仓库,软件,安装在操作系统之上

作用:存储数据,管理数据

1.2、数据库分类
关系型数据库:SQL(Structured Query Language)

MySQL、Oracle、Sql Server、DB2、SQLlite
通过表和表之间,行和列之间的关系进行数据的存储
通过外键关联来建立表与表之间的关系
非关系型数据库:NoSQL(Not Only SQL)

Redis、MongoDB
指数据以对象的形式存储在数据库中,而对象之间的关系通过每个对象自身的属性来决定
1.3、相关概念
DBMS(数据库管理系统)

数据库的管理软件,科学有效的管理、维护和获取我们的数据
MySQL就是数据库管理系统


1.4、MySQL及其安装
MySQL最新版8.0.21安装配置教程~
1.5、基本命令
所有的语句都要以分号结尾

show databases;    --查看当前所有的数据库
use 数据库名;    --打开指定的数据库
show tables;    --查看所有的表
describe/desc 表名;    --显示表的信息
create database 数据库名;    --创建一个数据库
exit    --退出连接

 


 

2、操作数据库
2.1、操作数据库
1、创建数据库

CREATE DATABASE [IF NOT EXISTS] 数据库名;

2、删除数据库

DROP DATABASE [if EXISTS] 数据库名;

3、使用数据库

--如果表名或者字段名是特殊字符,则需要带``
use 数据库名;

4、查看数据库

SHOW DATABASES;

 2.2、数据库的列类型

 

数据类型描述大小
tinyint十分小的数据1个字节
smallint较小的数据2个字节
mediumint中等大小的数据3个字节
int标准的整数4个字节
bigint较大的数据8个字节
float浮点数4个字节
double浮点数8个字节
decimal字符串形式的浮点数,一般用于金融计算

字符串

数据类型描述大小
char字符串固定大小0~255
varchar可变字符串0~65535
tinytext微型文本2^8-1
text文本串2^16-1

时间日期

数据类型描述格式
date日期格式YYYY-MM-DD
time时间格式HH:mm:ss
datetime最常用的时间格式YYYY-MM-DD HH:mm:ss
timestamp时间戳,1970.1.1到现在的毫秒数
year年份表示

null

  • 没有值,未知
  • 不要使用NULL值进行计算

2.3、数据库的字段属性

UnSigned

无符号的
声明了该列不能为负数
ZEROFILL

0填充的
不足位数的用0来填充 , 如int(3),5则为005
Auto_InCrement

通常理解为自增,自动在上一条记录的基础上默认+1

通常用来设计唯一的主键,必须是整数类型

可定义起始值和步长

当前表设置步长(AUTO_INCREMENT=100) : 只影响当前表
SET @@auto_increment_increment=5 ; 影响所有使用自增的表(全局)
NULL 和 NOT NULL

默认为NULL , 即没有插入该列的数值
如果设置为NOT NULL , 则该列必须有值
DEFAULT

默认的
用于设置默认值
例如,性别字段,默认为"男" , 否则为 “女” ; 若无指定该列的值 , 则默认值为"男"的值
拓展:每一个表,都必须存在以下五个字段:

名称描述
id主键
version乐观锁
is_delete伪删除
gmt_create创建时间
gmt_update修改时间

2.4、创建数据库表

CREATE TABLE IF NOT EXISTS `student`(
	`id` INT(4)	NOT NULL AUTO_INCREMENT COMMENT '学号',
	`name` VARCHAR(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
	`pwd` VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '密码',
	`sex` VARCHAR(2) NOT NULL DEFAULT '女' COMMENT '性别',
	`birthday` DATETIME DEFAULT NULL COMMENT '出生日期',
	`address` VARCHAR(100) DEFAULT NULL COMMENT '家庭住址',
	`email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
	PRIMARY KEY (`id`)
)ENGINE=INNODB DEFAULT CHARSET=utf8

注意点

  • 表名和字段尽量使用``括起来

  • AUTO_INCREMENT 代表自增

  • 所有的语句后面加逗号,最后一个不加

  • 字符串使用单引号括起来

  • 主键的声明一般放在最后,便于查看

  • 不设置字符集编码的话,会使用MySQL默认的字符集编码Latin1,不支持中文,可以在my.ini里修改

  • 2.6、修改数据库

  • 修改表名 : ALTER TABLE 旧表名 RENAME AS 新表名

    添加字段 : ALTER TABLE 表名 ADD字段名 列属性[属性]

    修改字段 :

    ALTER TABLE 表名 MODIFY 字段名 列类型[属性]
    ALTER TABLE 表名 CHANGE 旧字段名 新字段名 列属性[属性]
    删除字段 : ALTER TABLE 表名 DROP 字段名

    -- 修改表名
    -- ALTER TABLE 旧表名 RENAME AS 新表名
    ALTER TABLE teacher RENAME AS teachers;

    -- 增加表的字段
    -- ALTER TABLE 表名 ADD 字段名 列属性
    ALTER TABLE teachers ADD age INT(11);

    -- 修改表的字段(重命名,修改约束)
    -- ALTER TABLE 表名 MODIFY 字段名 [列属性];
    ALTER TABLE teachers MODIFY age VARCHAR(11);-- 修改约束
    -- ALTER TABLE 表名 CHANGE 旧名字 新名字 [列属性];
    ALTER TABLE teachers CHANGE age age1 INT(1);-- 字段重命名

    -- 删除表的字段
    -- ALTER TABLE 表名 DROP 字段名
    ALTER TABLE teachers DROP age1;

    语法:DROP TABLE [IF EXISTS] 表名

    IF EXISTS为可选 , 判断是否存在该数据表
    如删除不存在的数据表会抛出错误
    -- 删除表(如果存在再删除)
    DROP TABLE IF EXISTS teachers;
    所有的创建和删除尽量加上判断,以免报错~


    3、MySQL数据管理
    3.1、外键
    外键概念

    如果公共关键字在一个关系中是主关键字,那么这个公共关键字被称为另一个关系的外键。由此可见,外键表示了两个关系之间的相关联系。以另一个关系的外键作主关键字的表被称为主表,具有此外键的表被称为主表的从表。

    在实际操作中,将一个表的值放入第二个表来表示关联,所使用的值是第一个表的主键值(在必要时可包括复合主键值)。此时,第二个表中保存这些值的属性称为外键(foreign key)。

    外键作用:

    保持数据一致性,完整性,主要目的是控制存储在外键表中的数据,约束。使两张表形成关联,外键只能引用外表中的列的值或使用空值。

    目标:学生表(student)的gradeid字段 要去引用年级表(grade)的 gradeid字段

    创建外键
    方式一:在创建表的时候增加约束

  • /*
    	1. 定义外键key
    	2. 给外键添加约束(执行引用)references 引用
    */
    CREATE TABLE IF NOT EXISTS `student`(
    	`id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
    	`name` VARCHAR(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
    	`pwd` VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '密码',
    	`sex` VARCHAR(2)	NOT NULL DEFAULT '女' COMMENT '性别',
    	`birthday` DATETIME DEFAULT NULL COMMENT '出生日期',
    	`address` VARCHAR(100) DEFAULT NULL COMMENT '家庭住址',
    	`email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
    	`gradeid` INT(10) NOT NULL COMMENT '学生的年级',
    	PRIMARY KEY (`id`),
    	KEY `FK_gradeid` (`gradeid`),
    	CONSTRAINT `FK_gradeid` FOREIGN KEY (`gradeid`) REFERENCES `grade`(`gradeid`)
    )ENGINE=INNODB DEFAULT CHARSET=utf8
    
    -- 创建年级表
    CREATE TABLE `grade`(
    	`gradeid` INT(10) NOT NULL COMMENT '年级id',
    	`gradename` VARCHAR(50) NOT NULL COMMENT '年纪名称',
    	PRIMARY KEY (`gradeid`)
    )ENGINE=INNODB DEFAULT CHARSET=utf8
    

    删除有外键关系的表的时候,必须要先删除引用别人的表(从表),再删除被引用的表(主表)

  • 方法二:创建表成功后,添加外键约束

  • /*
    	1. 定义外键key
    	2. 给外键添加约束(执行引用)references 引用
    */
    CREATE TABLE IF NOT EXISTS `student`(
    	`id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
    	`name` VARCHAR(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
    	`pwd` VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '密码',
    	`sex` VARCHAR(2)	NOT NULL DEFAULT '女' COMMENT '性别',
    	`birthday` DATETIME DEFAULT NULL COMMENT '出生日期',
    	`address` VARCHAR(100) DEFAULT NULL COMMENT '家庭住址',
    	`email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
    	`gradeid` INT(10) NOT NULL COMMENT '学生的年级',
    	PRIMARY KEY (`id`)
    )ENGINE=INNODB DEFAULT CHARSET=utf8
    
    -- 创建表的时候没有外键关系
    ALTER TABLE `student`
    ADD CONSTRAINT `FK_gradeid` FOREIGN KEY(`gradeid`) REFERENCES `grade`(`gradeid`);
    
    -- 创建年级表
    CREATE TABLE `grade`(
    	`gradeid` INT(10) NOT NULL COMMENT '年级id',
    	`gradename` VARCHAR(50) NOT NULL COMMENT '年纪名称',
    	PRIMARY KEY (`gradeid`)
    )ENGINE=INNODB DEFAULT CHARSET=utf8
    

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值