学习视频地址
文章目录
一、虚拟机内:
启动mysql: systemctl start mysqld // service mysqld start
重启mysql: systemctl restart mysqld //service mysqld restart
停止mysql: systemctl stop mysqld //service mysqld stop
查看mysql状态: systemctl status mysqld // service mysqld status
登录mysql: mysql -u用户 -p密码
查看mysql系统上设置: cat /etc/my.cnf
二、mysql内基本命令:(MySQL关键字不区分大小写)
连接数据库:mysql -u用户名 -p密码
修改密码: alter user 'toor'@'用户IP' identified by '新密码';
查看密码限制: show variables like 'validate_password&';
修改密码限制: set gobal validate_password.限制名 = 新限制;
进入切换相关表库: use 表、库名;
查看mysql库:show databases;
查看mysql表:show tables;
显示数据库中指定表信息: describe 表名;
创建一个数据库:create database 数据库名;
退出连接:exit 、 quit;
单行注释: --
多行注释: /*。。。。*/;
三、数据库xxx语言:
DDL --定义
DML --操作
DQL --查询
DCL --控制
四、操作数据库:[可选],{必选} ([],{}在数据库中使用时不添加)
1. 操作数据库
1.1 创建数据库:
create database [if not exists] 数据库名
1.2 删除数据库:
drop database [if exists] 数据库名
1.3 使用数据库:
--注:如果表名或者字段名是一个特殊字符,就需要带 `` 符号
use 数据库名
eg: use `user`
1.4 查看数据库:
查看mysql库:show databases;
查看mysql表:show tables;
显示数据库中指定表信息: describe 表名
2. 数据库的列类型:
2.1 数值:
tinyint 十分小的数据 1个字节
smallint 较小的数据 2个字节
mediumint 中等大小的数据 3个字节
int **标准的整数** 4个字节 -- 常用的int
bigint 较大的数据 8个字节
float 浮点数 4个字节
double 浮点数 8个字节
decimal 字符串形式的浮点数,常用用金融计算。
2.2 字符串:
char 字符串固定大小 0-255
varchar 可变字符串 0~65535 -- 常用的变量 string
tinytext 微型文本 2^8-1
text 文本串 2^16-1 保存大文本
2.3 时间日期:
date YYYY-MM-DD 日期格式
time HH:mm:ss 时间格式
datetime YYYY-MM-DD HH:mm:ss 最常用的时间格式
year 年份表示
2.4 null
没有值未知
注:不要使用null进行运算,结果为null
3. 数据库的字段属性:
Unsigned:
-- *无符号的整数
-- 声明了该列不能声明为负数
zerofill:
-- 0填充的
-- 不足的位数,使用0来填充, int(3) , 5 --- 005
自增:
-- 通常理解为自增,自动在上一条记录的基础上 + 1(默认)
-- 通常用来设计唯一的主键~index,必须是整数类型
-- 可以自定义主键自增的起始值和步长
非空 NULL not null:
-- 假设设置为 not null ,如果不给他赋值,就会报错
-- null,如果不填写值,默认就是null
默认:
-- 设置默认的值
-- sex,默认的值为男,如果不指定该列的值,则会有默认的值
拓展:
/*每个表都必须存在以下五个字段,在java项目中,表示一个记录存在意义
id 主键
`version` 乐观锁
is_delete 伪删除
gmt_create 创建时间
gmt_update 修改时间
*/
4.创建数据库及其表单:
-- 注意点,使用英文(),表名和字段尽量使用 `` 括起来
-- AUTO_INCREMENT 自增需要与 key 主键配合
-- 语句之间用 ; 隔开
-- 字符串使用 单引号 '' 括起来
-- 所有语句后面加英文的 , 最后一个不用加
-- PRIMARY KEY 主键,一般一个表只有一个唯一的主键;
CREATE DATABASE `student`;
USE student;
CREATE TABLE `student`(
`id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
`name` VARCHAR(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
`pwd` VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '密码',
`birthday` datetime DEFAULT NULL COMMENT '出生日期',
`sex` VARCHAR(2) NOT NULL DEFAULT '男' COMMENT '性别',
`email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
`address` VARCHAR(100) DEFAULT NULL COMMENT '家庭地址',
PRIMARY KEY(`id`)
)ENGINE=INNODB DEFAULT CHARSET=utf8
格式*:
CREATE TABLE [IF NOT EXISTS] '表名'(
`字段名` 列类型 [属性] [索引] [注释],
………………………………………………………………………………………………,
`字段名` 列类型 [属性] [索引] [注释]
)[表类型][字符集设置][注释]
补充常用命令:
SHOW CREATE DATABASE 数据库名 -- 查看创建数据库的语句
SHOW CREATE TABLE 数据表名 -- 查看数据表的定以语句
DESC 表名 -- 显示表的结构
5. 数据表的类型
5.1 关于数据库引擎
-- 关于数据库引擎
INNODB 默认使用的;
MYISAM 早些年使用的;
# | MYISAM | INNODB |
---|---|---|
事务支持 | 不支持 | 支持 |
数据行锁定 | 不支持 | 支持 |
外键约束 | 不支持 | 支持 |
全文索引 | 支持 | 不支持 |
表空间大小 | 较小 | 较大,约为两倍 |
常规使用操作:
· MYISAM -- 节约空间,速度较快
· INNODB -- 安全性高,事务的处理,多表多用户操作
在物理空间存在的位置:
所有数据库文件都在data目录下,本质还是文件的存储!
MySQL引擎在物理文件上的区别
· INNODB 在数据库表中只有一个*.frm文件,以及上层目录下的ibdata1文件
· MYISAM 对应文件:
*.frm 表结构的定以文件
*.MYD 数据文件(data)
*.MYL 索引文件(index)
5.2 设置数据库字符集编码:
CHARSET=utf8
不设置的话,会是mysql默认字符集编码~(不支持中文!)
MySQL的默认编码是Latin1,不支持中文
在my.ini中配置默认的编码
character-set-server=utf8
6.修改删除表:
6.1 修改
-- 修改表名:ALTER TABLE 旧表名 RENAME AS 新表名
ALTER TABLE teacher RENAME AS teacher1
-- 增加表的字段:ALTER TABLE 表名 ADD 字段名 列属性
ALTER TABLE teacher1 ADD age INT(11)
-- 修改表的字段(重命名,修改约束!)
-- ALTER TABLE 表名 MODIFY 字段名 列属性[]
ALTER TABLE teacher1 MODIFY age VARCHER(11) -- 修改约束
-- ALTER TABLE 表名 CHANGE 旧名字 新名字 列属性[]
ALTER TABLE teacher1 CHANGE age age1 int(1) -- 字段重命名
-- 删除表的字段:
ALTER TABLE teacher DROP age1
6.2 删除
-- 删除表(如果表存在再删除)
DROP TABLE IF EXISTS teacher1
所有的创建和删除尽量加上判断++++,以免报错~
注意点:
· 用 `` 包裹字段名
· 注释 -- /**/
· sql关键字大小写不敏感,建议小写
· 所有的符号全部用英文
五.MySQL数据库管理:
1. 外键(了解)
1.1 方法一:在创建表的时候,增加约束(麻烦,比较复杂)
USE student;
CREATE TABLE `grade`(
`gradeid` INT(10) NOT NULL AUTO_INCREMENT COMMENT '年级id',
`gradename` VARCHAR(50) NOT NULL COMMENT '年级名称',
PRIMARY KEY (`gradeid`)
)ENGINE=INNODB DEFAULT CHARSET=utf8;
-- 学生表的gradeid字段,要去引用年级表的gradeid
-- 定义外键 key
-- 给这个外键添加约束 (执行引用)reference 引用
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 '密码',
`birthday` datetime DEFAULT NULL COMMENT '出生日期',
`sex` VARCHAR(2) NOT NULL DEFAULT '男' COMMENT '性别',
`email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
`address` VARCHAR(100) 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
删除有外键的表的时候,必须要先删除引用别人的表(从表),再删除被引用的表(主表)
1.2 方法二:创建表成功后,添加外键约束
CREATE TABLE `grade`(
`gradeid` INT(10) NOT NULL AUTO_INCREMENT COMMENT '年级id',
`gradename` VARCHAR(50) NOT NULL COMMENT '年级名称',
PRIMARY KEY (`gradeid`)
)ENGINE=INNODB DEFAULT CHARSET=utf8;
-- 学生表的gradeid字段,要去引用年级表的gradeid
-- 定义外键 key
-- 给这个外键添加约束 (执行引用)reference 引用
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 '密码',
`birthday` datetime DEFAULT NULL COMMENT '出生日期',
`sex` VARCHAR(2) NOT NULL DEFAULT '男' COMMENT '性别',
`email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
`address` VARCHAR(100) 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`);
-- ALTER TABLE 表 ADD CONSTRAINT 约束名 FOREIGN KEY (作为外键的列) REFERENCES 哪个表(哪个字段);
以上的操作都是物理外键,数据库级别的外键,不建议是使用~(避免数据库过多造成困扰,了解即可!