MySQL数据库基础笔记

MySQL数据库

sql语句分类

分类 全称 说明
DDL 数据库定义语言,用来定义数据库(数据库,表,字段)
DML 数据操作语言,用来对数据表中的数据进行增删改
DQL 数据查询语言,用来查询数据库中的表的记录
DCL 数据控制语言,用来创建数据库、控制数据库的访问权限

DDL语句

DDL操作数据库

查询:

查询所有数据库:

SHOW DATABASES;

查询当前数据库:

select database();

创建:

create database [if not exists]数据库名 [default charset 字符集] [collate 排序规则];(字符集用utf8mb4)长度为4个字节

删除:

drop database [if exists] 数据库名;

使用:

use 数据库名;

查询当前数据库所有表:

show tables;

查询表的结构:

desc 表名;

查询指定表的建表语句:

show creata table 表名;

创建数据表:

create table 表名(
		字段1 类型[comment 字段注释],
		字段2 类型,
		字段3 类型,
		......
		字段n 类型
)[comment 表注释];

DDL-数据类型

MySQL中数据类型很多,主要分为3类:数值型、字符串型、日期时间类型

数值类型

MySQL 支持所有标准 SQL 数值数据类型。

这些类型包括严格数值数据类型(INTEGER、SMALLINT、DECIMAL 和 NUMERIC),以及近似数值数据类型(FLOAT、REAL 和 DOUBLE PRECISION)。

关键字INT是INTEGER的同义词,关键字DEC是DECIMAL的同义词。

BIT数据类型保存位字段值,并且支持 MyISAM、MEMORY、InnoDB 和 BDB表。

作为 SQL 标准的扩展,MySQL 也支持整数类型 TINYINT、MEDIUMINT 和 BIGINT。下面的表显示了需要的每个整数类型的存储和范围。

类型 大小 范围(有符号) 范围(无符号) 用途
TINYINT 1 Bytes (-128,127) (0,255) 小整数值
SMALLINT 2 Bytes (-32 768,32 767) (0,65 535) 大整数值
MEDIUMINT 3 Bytes (-8 388 608,8 388 607) (0,16 777 215) 大整数值
INT或INTEGER 4 Bytes (-2 147 483 648,2 147 483 647) (0,4 294 967 295) 大整数值
BIGINT 8 Bytes (-9,223,372,036,854,775,808,9 223 372 036 854 775 807) (0,18 446 744 073 709 551 615) 极大整数值
FLOAT 4 Bytes (-3.402 823 466 E+38,-1.175 494 351 E-38),0,(1.175 494 351 E-38,3.402 823 466 351 E+38) 0,(1.175 494 351 E-38,3.402 823 466 E+38) 单精度 浮点数值
DOUBLE 8 Bytes (-1.797 693 134 862 315 7 E+308,-2.225 073 858 507 201 4 E-308),0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) 0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) 双精度 浮点数值
DECIMAL 对DECIMAL(M,D) ,如果M>D,为M+2否则为D+2 依赖于M和D的值 依赖于M和D的值 小数值

日期和时间类型

表示时间值的日期和时间类型为DATETIME、DATE、TIMESTAMP、TIME和YEAR。

每个时间类型有一个有效值范围和一个"零"值,当指定不合法的MySQL不能表示的值时使用"零"值。

TIMESTAMP类型有专有的自动更新特性,将在后面描述。

类型 大小 ( bytes) 范围 格式 用途
DATE 3 1000-01-01/9999-12-31 YYYY-MM-DD 日期值
TIME 3 '-838:59:59'/'838:59:59' HH:MM:SS 时间值或持续时间
YEAR 1 1901/2155 YYYY 年份值
DATETIME 8 '1000-01-01 00:00:00' 到 '9999-12-31 23:59:59' YYYY-MM-DD hh:mm:ss 混合日期和时间值
TIMESTAMP 4 '1970-01-01 00:00:01' UTC 到 '2038-01-19 03:14:07' UTC结束时间是第 2147483647 秒,北京时间 2038-1-19 11:14:07,格林尼治时间 2038年1月19日 凌晨 03:14:07 YYYY-MM-DD hh:mm:ss 混合日期和时间值,时间戳

字符串类型

字符串类型指CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM和SET。

类型 大小 用途
CHAR 0-255 bytes 定长字符串
VARCHAR 0-65535 bytes 变长字符串
TINYBLOB 0-255 bytes 不超过 255 个字符的二进制字符串
TINYTEXT 0-255 bytes 短文本字符串
BLOB 0-65 535 bytes 二进制形式的长文本数据
TEXT 0-65 535 bytes 长文本数据
MEDIUMBLOB 0-16 777 215 bytes 二进制形式的中等长度文本数据
MEDIUMTEXT 0-16 777 215 bytes 中等长度文本数据
LONGBLOB 0-4 294 967 295 bytes 二进制形式的极大文本数据
LONGTEXT 0-4 294 967 295 bytes 极大文本数据

注意:char(n) 和 varchar(n) 中括号中 n 代表字符的个数,并不代表字节个数,比如 CHAR(30) 就可以存储 30 个字符。

CHAR 和 VARCHAR 类型类似,但它们保存和检索的方式不同。它们的最大长度和是否尾部空格被保留等方面也不同。在存储或检索过程中不进行大小写转换。

char(10)最多只能放十个,不满十个用空格补全,性能较好,定长字符(空间换时间)

varchar(10)最多只能放10个,存储一个字符只占一个字符,性能较差,边长字符在使用过程中需要计算长度,(时间换空间)

BINARY 和 VARBINARY 类似于 CHAR 和 VARCHAR,不同的是它们包含二进制字符串而不要非二进制字符串。也就是说,它们包含字节字符串而不是字符字符串。这说明它们没有字符集,并且排序和比较基于列值字节的数值值。

BLOB 是一个二进制大对象,可以容纳可变数量的数据。有 4 种 BLOB 类型:TINYBLOB、BLOB、MEDIUMBLOB 和 LONGBLOB。它们区别在于可容纳存储范围不同。

有 4 种 TEXT 类型:TINYTEXT、TEXT、MEDIUMTEXT 和 LONGTEXT。对应的这 4 种 BLOB 类型,可存储的最大长度不同,可根据实际情况选择。

易错
  1. 列名应该在类型之前,不需要使用单引号: 列名(例如'编号','员工工号')应该在类型(例如 INT,VARCHAR)之前,而且不需要使用单引号。
  2. CHAR 类型的长度不需要指定为 1: 当使用 CHAR 类型时,不需要指定长度为 1。如果你希望性别只存储一个字符,可以保留 CHAR 类型而不用指定长度。
  3. UNSIGNED 关键字放在 INT 后面: 如果你希望年龄是无符号整数,应该将 UNSIGNED 放在 INT 后面。
  4. 去掉最后一个逗号: 列定义的最后一个后面不需要逗号。

这个修改后的语句应该能够正确创建一个名为 renshi 的员工表。

MySQL中的主键

主键的定义

主键:表中经常有一个列或多列的组合,其值能唯一地标识表中的每一行。这样的一列或多列称为表的主键,通过它可强制表的实体完整性。当创建或更改表时可通过定义 PRIMARY KEY 约束来创建主键。一个表只能有一个 PRIMARY KEY 约束,而且 PRIMARY KEY 约束中的列不能接受空值。由于 PRIMARY KEY 约束确保唯一数据,所以经常用来定义标识列。

use scholldb;
create table student(
学号 char(10) not null primary key, //设置主键为学号,且是唯一主键
姓名 char(10) not null
);
联合主键

关系数据库实际上还允许通过多个字段唯一标识记录,即两个或更多的字段都设置为主键,这种主键被称为联合主键。对于联合主键,允许一列有重复,只要不是所有主键列都重复即可。

use scholldb;
create table student(
学号 char(10) not null ,
课程号 char(10) not null ,
成绩 float(5,2) ,
primary key(学号,课程号)   //联合外键为学号课程号
);
查询表中主键的命令:desc (表名);

MySQL中外键

保持数据的一致性、完整性。在一个库中使用多表中的主键定义一个外键,保持数据的完整性。

引用全部在一个表时数据太多太杂,所以拆为多个表,在表中设置唯一关字,然后作为表的主键,作为其他表的外键,当多表联合查询时作为关键字段

为了一张表记录的数据不要太过冗余。这和软件project的模块化思想差点儿相同类似,仅仅只是在数据库中是对表关系进行解耦,尽量让表 记录的数据单一化。假如一张学生表中把成绩和学生信息放在一张表中就太冗余了,成绩全然能够以学生的id作为区分标识。

列:在一个数据库中定义A表的外键来自B表中的C字段,此时A表作为B表的父表

创建表时创建外键
[CONSTRAINT <外键名>] FOREIGN KEY 字段名 [,字段名2,…]
REFERENCES <主表名> 主键列1 [,主键列2,…]
//
1、
create table student(
学号 char(11) not null foreign key,   
//在定义主键时添加外键。(在添加外键约束之前,必须确保引用表中的主键列已经定义)
姓名 char(10) not null 
);

2、
FOREIGN KEY(deptId) REFERENCES tb_dept1(id)
create table student(
学号 char(11) not null,
姓名 char(10) not nll,
foreign key (学号) references course(学号)
//创建数据表student,并在表student上创建外键约束,让它的键 学号 作为外键引表到 course表中 的学号字段
);
对已有表创建外键

单个主键

ALTER TABLE student
ADD FOREIGN KEY (班级编号) REFERENCES class(班级编号);
//将表student中的班级编号字段作为外键引用class中的班级编号作为主键

多个主键

alter table score
add foreign key (学号) references student(学号),
add foreign key (课程号) references student(课程号);

check完整性约束

Check完整性约束是一种用于限制表中数据值的约束。它定义了一个条件,该条件必须在插入或更新数据时得到满足。如果数据不符合约束条件,操作将被拒绝并抛出错误。

通过使用Check完整性约束,可以确保表中的数据满足特定的条件,例如范围、数据类型、格式等。这样可以防止非法或无效的数据进入表中,提高数据的准确性和一致性。

以下是创建Check完整性约束的一般语法:

ALTER TABLE 表名称
ADD CONSTRAINT 约束名称 CHECK (条件);

其中,"表名称" 是要添加约束的表名,"约束名称" 是约束的名称(可以自定义),"条件" 是定义约束的条件表达式。

数据插入

INSERT...VLAUES语句
insert into 表名 vlaues (值);
insert into 表名(字段1,字段2,) values(值1,值2);
REPLACE INSERT语句

此语句的作用是当我们在插入一条数据时,如果此条已经存在,那么先删除原来存在的数据再添加插入的数据,如果不存在那么直接插入新的数据。注意:却分是否存在是通过主键来确定的

replace into 表(字段) values(值);
INSERT IGNORE INTO 语句

此语句的作用是如果插入的数据已经存在那么就忽略插入的数据(也就是不改变原来的数据),如果不存在则插入新的数据。注意:却分是否存在是通过主键来确定的

insert ignore into 表(字段) values (值);
set插入

知道部分值插入数据,插入已知值,其他值为空(主键不能为空)

insert into 表 set 字段1=‘值1’ , 字段2=‘值2’ ...  ;
传递参数

MySQL中的limit

约束行数,输出约束行

其次第一行的量为0,而不是1

SELECT 字段名 FROM 表名 LIMIT offset , 列数;

mysql 中的concat函数

作用:将多个字符串连接成一个字符串

concat (str1 , str2, ...) ;
SELECT CONCAT(地区, '省或市') FROM student;  #不添加新列查看
select concat(地区,'省或市')as 新列名 from student ; #添加新列查看
UPDATE student SET 地区 = CONCAT(地区, '省或市');  # 直接更改数据

MySQL中数据更新/修改

只改想改的数据:

update 表名 set 字段名=值 where 条件子句;

update student set 出生日期='1998-02-10' where id = 1;
#在表student中把id=1的记录字段为出生日期的数据改变为1998-01-10
修改全部数据:
update 表名 set 字段名1=值1,字段名2=值2...,字段名n=值n;

#对于NULL不能用=符号,要用is null
修改表结构:

alter table 表名 修改的动作语法

列:alter table 表名 modify 字段名 数据类型 ; 
列:aller table student modify 姓名 varchar(20) not null ;
#修改student 中的姓名列的数据类型为varchar(20) 并设置为不允许包含空值

修改数据类型:

alter table 表名 modify 字段 新数据类型;
alter table c1 modify name varchar(20) not null;

修改字段名:

alter table 表名 change 旧字段名 新字段名 新数据类型;
alter table c3 change name name1 varchar(30) not null

修改表之增加主键:

alter table 表名 add constraint 约束名字 约束类型[字段];
alter table c5 add constraint PK_c5_id primary key(id);   

说明:PK_c5_id是约束名(指定主键约束为PK_c5_id,对大部分数据库有效但对于MySql无效,此主键约束名仍为primary)
在建表时给主键个性化名字较好

修改表名:

rename table 旧表名 to 新表名;
rename table c5 to cc55;

建表后添加唯一性约束:

alter table 表名 add unique(字段名)

alter table c9 add unique(id);

建表后添加默认值约束:

alter table 表名 alter 列名 set default’默认值’;

alter table c11 alter name set default “欧”;

建表后添加非空约束:

alter 表名 modify 字段名字段类型not null;

alter table c12 modify id int not null;

建表以后添加外键:

alter table 表名称 add foreign key (列名称) references关联表名称(列名称);

alter	table stuInfo add foreign key (scode) references score(studentID);

MySQL中的数据删除

Mysql删除表中的数据有三种方法,分别是delete ,drop,truncate

delete删除数据
delete from 表名 where 条件

一行一行的删除,可以滚动,删除 之后不释放空间,保留表的数据结构

列:delete from student where 出生日期<1997-01-01
drop删除数据
drop table 表名

直接删除全部删除,不可找回,删除完之后释放空间

truncat删除数据
truncate table 表名

删除表的所有数据,删除完之后释放空间,保留数据结构不可以回滚,不可以找回,不能与where连用

mysql中的数据查询

单表查询

选择表中的若干列

指定查询

select 列1,列2...form 表名;

经过计算的查询

MySQL中的视图

什么是视图:一个虚拟表,主要是select语句执行返回的结果集。视图结果动态生成主要是sql语句执行结果与联合,基于查询结果。

视图的创建

语法:create view 视图名 [列表名] as select 语句

MySQL数据库用户管理

添加和删除用户

创建用户
create user 用户名 identified by '密码';

添加一个新用户user密码为root

IDENTIFIED BY 用于设定密码,MySQL 会先将密码进行加密,在将其保存到 user 表

列:create user 'user'@'localhost' identified by 'root';
查看当前已有用户

MySQL 中所有的用户及权限信息都存储在默认数据库 mysql 的 user 表中。

进入 mysql 数据库,通过 desc user; 可以查看 user 表的结构。

use mysql;
desc user;    //查看user表的结构

host: 允许访问的主机地址,localhost 为本机,% 为任何主机。

user: 用户名

authentication_string: 加密后的密码值,哈希函数加密不可逆,在传入密码值时通过相同的加密方式加密对比加密值判断

使用 select * from user; 查看 user 表中当前有哪些用户。

select host,user,authentication_string from user;
账号重命名
rename user 原来用户名 to 新的用户名;

仅 MySQL 5及之后的版本支持 RENAME USER
MySQL 5以前的版本,要重命名一个用户,可使用 UPDATE 直接更新 user 表(谨慎操作)。

修改密码
set password for 用户= password('password');

可以使用 SET PASSWORD 语句重置账号密码。

使用 SET PASSWORD 重置账号密码。新密码必须通过 Password() 函数进行加密。

当不指定用户名时, SET PASSWORD 会重置当前登录用户的密码

SET PASSWORD = Password('password');
删除用户

drop user 用来删除一个或多个MySQL用户,并取消相关权限

Drop user 用户1,用户2,... ;

删除用户user

drop user user@localhost;

权限管理

用户认证

形式:

用户名+主机  远程主机也可链接
授权
grant [权限1,权限2,权限3] on *.* to user@'host' identified by 'password';
查看当前权限
show grants;

查看指定用户的权限

show grants for admin@localhost; 
posted @ 2024-03-17 17:29  有一大盒  阅读(48)  评论(0编辑  收藏  举报