MySQL常用命令学习笔记

学习视频地址

文章目录

一、虚拟机内:

启动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 哪个表(哪个字段);

以上的操作都是物理外键,数据库级别的外键,不建议是使用~(避免数据库过多造成困扰,了解即可!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值