MySQL复习笔记

关系型数据库管理系统

特点:体积小、速度快、总体拥有成本低、开放源码

指令作用
sudo apt-get install mysql-server安装MySQL服务端、核心程序
sudo apt-get install mysql-client安装MySQL客户端
sudo service mysql start打开MySQL服务
mysql -u root -p使用root用户登录
show databases;查看有哪些数据库
use information_schema连接数据库
show tables;查看表
quit退出
exit退出
CREATE DATABASE mysql_shiyan;创建数据库
use mysql_shiyan连接数据库
CREATE TABLE employee (id int(10),name char(20),phone int(12));创建表

数据类型大小(字节)用途格式
INT4整数
FLOAT4单精度浮点数
DOUBLE4双精度浮点数
ENUM单选,比如性别ENUM(‘a’,’b’,’c’)
SET多选
DATE3日期YYYY-MM-DD
TIME3时间点或持续时间HH:MM:SS
YEAR1年份值YYYY
CHAR0~255定长字符串
VARCHAR0~255变长字符串
TEXT0~65535长文本数据

CHAR和VARCHAR的区别: CHAR的长度是固定的,而VARCHAR的长度是可以变化的,比如,存储字符串“abc”,对于CHAR (10),表示存储的字符将占10个字节(包括7个空字符),而同样的VARCHAR(12)则只占用3个字节的长度,12只是最大值,当你存储的字符小于12时,按实际长度存储。

ENUM和SET的区别: ENUM类型的数据的值,必须是定义时枚举的值的其中之一,即单选,而SET类型的值则可以多选。


INSERT INTO 表的名字(列名a,列名b,列名c) VALUES(值1,值2,值3);

约束

约束类型主键默认值唯一外键非空
关键字PRIMARY KEYDEFAULTUNIQUEFOREIGN KEYNOT NULL
主键

主键(PRIMARY KEY)是用于约束表中的一行,作为这一行的标识符,在一张表中通过主键就能准确定位到一行,因此主键十分重要。行中的主键不能有重复且不能为空。

CREATE TABLE employee (
    id INT(10)PRIMARY KEY,
    name CHAR(10)
);
默认值约束

默认值约束(DEFAULT)规定,当有DEFAULT约束的列,插入数据为空时,该怎么办。

唯一约束

唯一约束(UNIQUE)比较简单,它规定一张表中指定的一列的值必须不能有重复值,即这一列每个值都是唯一的。

外键

外键(FOREIGN KEY)既能确保数据完整性,也能表现表之间的关系。
一个表可以有多个外键,每个外键必须REFERENCES(参考)另一个表的主键,被外键约束的列,取值必须在它参考的列中有对应值。

非空约束

非空约束(NOT NULL),听名字就能理解,被非空约束的列,在插入值时必须非空。


SELECT

通配符

关键字 LIKE 在SQL语句中和通配符一起使用,通配符代表未知字符。SQL中的通配符是 _ 和 % 。其中 _ 代表一个未指定字符,% 代表不定个未指定字符。

对结果排序

默认情况下,ORDER BY的结果是升序排列,而使用关键词ASC和DESC可指定升序或降序排序。

SQL内置函数和计算

函数名COUNTSUMAVGMAXMIN
作用计数求和求平均值最大值最小值

其中COUNT函数可用于任何数据类型(因为它只是计数),而另4个函数都只能对数字类数据类型做计算


修改和删除

删除数据库

DROP DATABASE test_01;

重命名一张表

RENAME TABLE 原名 TO 新名字;

ALTER TABLE 原名 RENAME 新名;

ALTER TABLE 原名 RENAME TO 新名;

删除一张表

DROP TABLE 表名字;

增加一列

ALTER TABLE 表名字 ADD COLUMN 列名字 数据类型 约束;

ALTER TABLE 表名字 ADD 列名字 数据类型 约束;

删除一列

ALTER TABLE 表名字 DROP COLUMN 列名字;

ALTER TABLE 表名字 DROP 列名字;

重命名一列

ALTER TABLE 表名字 CHANGE 原列名 新列名 数据类型 约束;

改变数据类型

ALTER TABLE 表名字 MODIFY 列名字 新数据类型;

修改表中某个值

UPDATE 表名字 SET1=值1,列2=值2 WHERE 条件;

删除一行记录

DELETE FROM 表名字 WHERE 条件;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值