Mysql数据库的基本操作和用户的管理

目录

一、mysql的概述

二、MySQL数据库

2.1 数据库常见的类型

2.2 如何去进入到MySQL数据库

2.3 MySQL数据库的管路操作

2.3.1 查看数据库

2.3.2 查看数据库中表

 2.3.3 查看表的结构组成

 三、SQL的语句

3.1 SQL语言的分类

3.2 DDL的语法

3.2.1创建新的数据库

 3.2.2 创建一个新的表

 3.2.3 删除指定的数据表和库

 3.3 DML的语言

3.3.1 向表中插入内容

  3.3.2 查询数据

3.3.3 修改、更新数据表的记录数据

 3.3.4 删除不需要的表内容

3.4 DQL查询语言

3.4.1 查询数据记录

 3.5 DCL 修改表名和表结构

3.5.1 修改表名

3.5.2 修改表结构添加

3.5.3 修改表的字段

 3.5.4 删除字段

3.6 创建一个新的表(拓展)

3.7 数据表的高级操作

3.7.1 克隆表的表结构

 3.7.2 克隆表结构的同时把数据克隆

3.7.3 清空表内的所有数据

 3.7.4 删除表类型

3.8 创建临时表

3.9 创建外键约束

四、数据库用户的管理

4.1 创建新用户

4.1.1 使用密文创建用户

4.2 查看用户的信息

4.3 重命名用户

4.4 删除用户

4.5 修改当前的用户密码

4.6 修改其他用户的密码 

4.7 解决root密码忘记办法

4.7.1 修改配置文件

4.7.2 使用update修改root密码

 五、数据库用户授权

5.1 授予权限

5.1.1 允许用户zzzzz在本地查询ning库中所有表的数据记录,禁止查询其他数据库记录

 5.1.2 允许用户zzzzz在所有终端远程连接mysql,且拥有所有权限

5.2 授权用户的权限

5.3 查看权限

 5.4 撤销权限

总结


一、mysql的概述

MySQL数据库的数据文件存放在/usr/local/mysq1/data目录下,每个数据库对应一个子目录,
用于存储数据表文件。每个数据表对应为三个文件,扩展名分别为“. frm"、" .MYD"和“.MYI"。
 
MYD"文件是MyISAM存储引擎专用,存放MyISAM表的数据。
每一个MyISAM表都会有一个“.MYD”文件与之对应,同样存放于所属数据库的文件夹下,和“.frm" 文件在一起。
 
”.MYI"文件也是专属于MyISAM 存储引擎的,主要存放MyISAM表的索引相关信息。对于MyISAM
存储来说,可以被cache的内容主要就是来源于“.MYI"文件中。每一个MyISAM表对应一个“.MYI"文件,存放于位置和“. frm"以及“.MYD”一样。
 
MyISAM存储引擎的表在数据库中,每一个表都被存放为三个以表名命名的物理文件( frm, myd,myi)。每个表都有且仅有这样三个文件做为MyISAM存储类型的表的存储,也就是说不管这个表有多少个索引,都是存放在同一个.MYI文件中。
 
另外还有“. ibd"和ibdata 文件,这两种文件都是用来存放Innodb数据的,之所以有两种文件来存放Innodb的数据(包括索引),是因为Innodb的数据存储方式能够通过配置来决定是使用共享表空间存放存储数据,还是独享表空间存放存储数据。
独享表空间存储方式使用“. ibd"文件来存放数据,且每个表一个“.ibd"文件,文件存放在和MyISAM数据相同的位置。如果选用共享存储表空间来存放数据,则会使用ibdata文件来存放,所有表共同使用一个(或者多个,可自行配置) ibdata 文件。

二、MySQL数据库

2.1 数据库常见的类型

类型 介绍
int 整型(定义整数类型数据)
float 单精度浮点。4字节23位,精准到小数点后六位
double 双精度浮点。8字节64位
char 固定长度的字符类型,定义字符类数据,不足的空格补齐
varchar

可变长度的字符类型

text 文本
image 图形
decimal (5,2)指5个有效长度数字,小数点后面为2位

比如float(5,2)如果插入个数位123.456,他存储时就会显示123.45,总个数为5位小数点后面是2位

●char与varchar的区别

char(n)n位数字是确定字符数的长度。如果你存储时小于n,则会以空格去代替。

char(4)就是不管你存入多少个字符,都只会去占用4个字节。

varchar需要使用1或2个额外字节记录字符串的长度,varchar(1000)的列则需要1002 个字节,因为需要2个字节存储长度信息。

char要比varchar的检索速度要快

2.2 如何去进入到MySQL数据库

mysql -u (用户)-p (密码)

Mysql数据库的基本操作和用户的管理_第1张图片

2.3 MySQL数据库的管路操作

2.3.1 查看数据库

show databases;

 Mysql数据库的基本操作和用户的管理_第2张图片

2.3.2 查看数据库中表

①选中你所要查询的库

use zhang;

②查看zhang库中的表

show tables;

Mysql数据库的基本操作和用户的管理_第3张图片

 2.3.3 查看表的结构组成

desc zhao;

Mysql数据库的基本操作和用户的管理_第4张图片

field :字段名称

type:数据的类型

null:是否允许为空

key:主键

default:默认值

extra:扩展属性

主键:数据库主键,指的是一个列或多列的组合,其值能唯一地标识表中的每一行,通过它可强制表的实体完整性。主键主要是用于其他表的外键关联,以及本记录的修改与删除。

主键是能确定一条记录的唯一标识,主键字段必须唯一,必须非空,一个表中只能有一个主键,主键可以包含一个或多个字段。

 三、SQL的语句

SQL语句是用于管理维护数据库,其中包括了对数据的查询、更新、访问、管理等。

3.1 SQL语言的分类

DDL 数据定义语言,用于创建数据库对象,例如 库、表
DML 数据操控语言,对表中的数据去管理
DQL

数据查询语言,用于去对表中的数据进行查询

DCL

数据控制语言,用于修改设置数据库用户权限

3.2 DDL的语法

3.2.1创建新的数据库

CREATE DATABASE 数据库名字;

Mysql数据库的基本操作和用户的管理_第5张图片

 3.2.2 创建一个新的表

CREATE TABLE 表名 (字段1 数据类型,字段2 数据类型[,...][,PRIMARY KEY (主键名)]);

CREATE TABLE zz  (id int(5)NOT NULL,name char(10) NOT NULL, score decimal(5,2), passwd char(48) DEFAULT'',PRIMARY KEY (id));

NOT NULL:不允许位空值

DEFAULT:默认值为空

PRIMARY KEY:设置一个逐渐

Mysql数据库的基本操作和用户的管理_第6张图片

Mysql数据库的基本操作和用户的管理_第7张图片

 3.2.3 删除指定的数据表和库

DROP TABLE 名字;         (删除指定的表)

DROP DATABASE 名字;   (删除指定的库)

Mysql数据库的基本操作和用户的管理_第8张图片

 3.3 DML的语言

3.3.1 向表中插入内容

INSERT INTO 表名(字段1,字段2,等等) VALUES(字段1的内容,字段2的内容)

INSERT INTO zz (id,name,score,passwd)VALUES (1,'zhang',90,123456)

因为zhang为字符所以要加上''  并且如果想要隐藏密码可以加上password

Mysql数据库的基本操作和用户的管理_第9张图片

根据field下去定义需要插入的内容 

Mysql数据库的基本操作和用户的管理_第10张图片

 用select * from zz;去查看插入的内容

Mysql数据库的基本操作和用户的管理_第11张图片

如果你想隐藏密码可以加上password(’密码‘)即可

Mysql数据库的基本操作和用户的管理_第12张图片

  3.3.2 查询数据

SELECT * from zz  查询zz表中的所有信息

SELECT 字段1,字段2 from 表名 where 条件

select name,score from zz where id=1;   查询zz表中id为1的name和score

Mysql数据库的基本操作和用户的管理_第13张图片

3.3.3 修改、更新数据表的记录数据

UPDATA 表名 SET 字段名=字段名对应修改的内容 where (条件)

UPDATE zz SET name=’zha' where id='5';

Mysql数据库的基本操作和用户的管理_第14张图片

 3.3.4 删除不需要的表内容

DELETE from 表名 where (条件);

DELETE from zz where id= 3; (删除有关zz表中id=3的内容)

Mysql数据库的基本操作和用户的管理_第15张图片

3.4 DQL查询语言

3.4.1 查询数据记录

SELECT * FROM 表名;  查询表中的数据记录

SELECT id,name  from  表名     查询表的对应字段

SELECT id,name  from 表名 where (条件)

Mysql数据库的基本操作和用户的管理_第16张图片

Mysql数据库的基本操作和用户的管理_第17张图片

Mysql数据库的基本操作和用户的管理_第18张图片

 SELECT name  from 表名\G   以竖向方式显示

SELECT * from 表名 limit 2;   只显示前2行

SELECT * from 表名 limit 1,2; 只显示第一行后的前两行

Mysql数据库的基本操作和用户的管理_第19张图片

Mysql数据库的基本操作和用户的管理_第20张图片

 3.5 DCL 修改表名和表结构

3.5.1 修改表名

ALTER TABLE 旧表名  rename  新表名;

Mysql数据库的基本操作和用户的管理_第21张图片  

3.5.2 修改表结构添加

 ALTER TABLE 表名 add age char(40) default ‘未知’;   在表zzz中添加新的字段,默认字为未知

Mysql数据库的基本操作和用户的管理_第22张图片

Mysql数据库的基本操作和用户的管理_第23张图片

3.5.3 修改表的字段

ALTER TABLE 表名 CHANGE 原字段  新字段  数据类型   unique key;

unique key: 唯一键(特性:唯一,但可以为空,空值只允许出现一次)

primary key:唯一且非空 

alter table zzz change name users varchar(20) unique key;

Mysql数据库的基本操作和用户的管理_第24张图片

 3.5.4 删除字段

ALTER TABLE 表名 DROP 字段名;

Mysql数据库的基本操作和用户的管理_第25张图片

3.6 创建一个新的表(拓展)

create table if not exists CLASS4 (id int(4) zerofill primary key auto_increment,student_name varchar(20) not null,cardid varchar(18) not null unique key,hobby varchar(50));
 

if not exists    表示检测要创建的表是否已存在,如果不存在就继续创建
int(4) zerofill    表示若数值不满4位数,则前面用“0”填充,例0001
auto_increment    表示此字段为自增长字段,即每条记录自动递增1,默认从1开始递增;自增长字段数据不可以重复;自增长字段必须是主键;如添加的记录数据没有指定此字段的值且添加失败也会自动递增一次
unique key    表示此字段唯一键约束,此字段数据不可以重复;一张表中只能有一个主键, 但是一张表中可以有多个唯一键
not null    表示此字段不允许为NULL

Mysql数据库的基本操作和用户的管理_第26张图片

可以看到添加信息时没有输入id他会自动的去添加id顺序。

3.7 数据表的高级操作

3.7.1 克隆表的表结构

create table 新表名 like 需要克隆的表名;

insert into 新表名 select * from 需要拷贝数据的表名;

create table wwww like zzz;

insert into wwww select * from zzz;

Mysql数据库的基本操作和用户的管理_第27张图片

 

 Mysql数据库的基本操作和用户的管理_第28张图片

 3.7.2 克隆表结构的同时把数据克隆

create table 新表名 (select * from 需要克隆的表名);

Mysql数据库的基本操作和用户的管理_第29张图片

3.7.3 清空表内的所有数据

delete from 表名

 truncate table 表名

DELETE清空表后,返回的结果内有删除的记录条目;DELETE工作时是一行一行的删除记录数据的;如果表中有自增长字段,使用DELETE FROM 删除所有记录后,再次新添加的记录会从原来最大的记录 ID 后面继续自增写入记录。(例;删除出100个数据,)

 TRUNCATE 清空表后,没有返回被删除的条目;TRUNCATE 工作时是将表结构按原样重新建立,因此在速度上 TRUNCATE 会比 DELETE 清空表快;使用 TRUNCATE TABLE 清空表内数据后,ID 会从 1 开始重新记录

 3.7.4 删除表类型

drop table table-name

  • 属于DDL
  • 不可回滚
  • 不可带where
  • 表内容和结构删除
  • 删除速度快

truncate  table table-name

  • 属于DDL
  • 不可回滚
  • 不可带where
  • 表内容删除
  • 删除速度快

delete   from   table table-name

  • 属于DML
  • 可回滚(可恢复)
  • 表结构在,表内容要看where执行的情况
  • 删除速度慢,需要逐行删除

整理:

不再需要一张表的时候,用 drop

想删除部分数据行的时候,用delete ,并且带上where 语句

保留表面删除所有数据的时候用 truncate 

删除速度

drop > truncate > delete

安全性

delete 最好

3.8 创建临时表

创建的临时表,show tables是看不到的,因为临时表退出后会自动的销毁

create temporary table 表名

Mysql数据库的基本操作和用户的管理_第30张图片

可以看到show tables是看不到表的

3.9 创建外键约束

外键的定义:如果同一属性的字段x在表一中是主键,而在表二不是主键,则字段x是表二的外键。

主键表和外键表的理解:

以公共关键字作为主键的表为主键表

以公共关键字作为外键的表为外键表

当从表设置了外键约束后插入和删除数据就必须要先从主表删除

●MySQL中6种常见的约束:

  1. 主键约束(primary key)

  2. 外键约束(foreign key)

  3. 非空约束(not null)

  4. 唯一性约束(unique [key|index] )

  5. 默认值约束(default)

  6. 自增约束(auto_increment)

四、数据库用户的管理

4.1 创建新用户

CREATE USER ‘用户名’@‘来源地址’ indentified by ‘密码’

'来源地址':   指定新创建的用户可在哪些主机上登录,可使用IP地址、网段、主机名的形式,本地用户可用localhost,允许任意主机登录可用通配符  %

'密码':

若使用明文密码,直接输入'密码',插入到数据库时由Mysql自动加密;
 若使用加密密码,需要先使用SELECT PASSWORD('密码');获取密文,再在语句中添加 PASSWORD '密文';
若省略“IDENTIFIED BY" 部分,则用户的密码将为空(不建议使用)
Mysql数据库的基本操作和用户的管理_第31张图片

Mysql数据库的基本操作和用户的管理_第32张图片 

4.1.1 使用密文创建用户

select password(‘123456’);  获取密文

create user '名字'@'来源' identified by password '获取的密文'

4.2 查看用户的信息

创建的用户在mysql库中的user表里

use mysql;

select user,authentication_string,host from user;

Mysql数据库的基本操作和用户的管理_第33张图片

4.3 重命名用户

rename user '原名字'@'原来源地址' to ‘新名字'@'新的源地址';

Mysql数据库的基本操作和用户的管理_第34张图片 

4.4 删除用户

drop user ‘用户名’@‘来源地址’

Mysql数据库的基本操作和用户的管理_第35张图片 

4.5 修改当前的用户密码

set password = password(‘密码’)

Mysql数据库的基本操作和用户的管理_第36张图片 

Mysql数据库的基本操作和用户的管理_第37张图片 

4.6 修改其他用户的密码 

 set password for '用户名'@‘来源地址’ = password('密码');

Mysql数据库的基本操作和用户的管理_第38张图片

4.7 解决root密码忘记办法

4.7.1 修改配置文件

vim /etc/my.cnf

在【mysqld】 下添加 skip-grant-tables

Mysql数据库的基本操作和用户的管理_第39张图片

Mysql数据库的基本操作和用户的管理_第40张图片 

4.7.2 使用update修改root密码

update mysql.user set authentication_string = password('654321') where user='root' ;

flush privileges;   刷新数据

Mysql数据库的基本操作和用户的管理_第41张图片

Mysql数据库的基本操作和用户的管理_第42张图片 

 五、数据库用户授权

5.1 授予权限

GRANT:专门用于设置数据库用户的访问权限。如果被指定的用户不存在,则会自动的创建一个新的用户。

GRANT 权限列表 on 数据库名.表名 to '用户名'@'来源地址' identified by ’密码‘;

权限列表:用于列出授权使用的各种数据库操作,以逗号进行分隔,如“select,insert,update”。使用“all”表示所有权限,可授权执行任何操作。
 

数据库名.表名:用于指定授权操作的数据库和表的名称,其中可以使用通配符 “*” 。例如,使用“kgc.*”表示授权操作的对象为 kgc数据库中的所有表。
'

用户名'@'来源地址':用于指定用户名称和允许访问的客户机地址,即谁能连接、能从哪里连接。来源地址可以是域名、IP 地址,还可以使用“%”通配符,表示某个区域或网段内的所有地址,如“%.accp.com”、“192.168.80.%”等。
 

IDENTIFIED BY:用于设置用户连接数据库时所使用的密码字符串。在新建用户时,若省略“identified by”部分, 则用户的密码将为空。

5.1.1 允许用户zzzzz在本地查询ning库中所有表的数据记录,禁止查询其他数据库记录

grant select on ning.* to 'zzzzz'@'localhost' identified by '123456';

Mysql数据库的基本操作和用户的管理_第43张图片

测试使用zzzzz用户登录mysql

Mysql数据库的基本操作和用户的管理_第44张图片 

Mysql数据库的基本操作和用户的管理_第45张图片 

 5.1.2 允许用户zzzzz在所有终端远程连接mysql,且拥有所有权限

grant all on *.* to 'zzzzz'@'%' identified by '123456';

在客户端上测试

Mysql数据库的基本操作和用户的管理_第46张图片 

5.2 授权用户的权限

授权用户的权限是:all privilege

 all   privilege的权限:

  • insert (插入数据)
  • select  (查询数据)
  • update  (更新表的数据)
  • delete   (删除表中数据)
  • create   (创建库、表)
  • drop    (删除库、表)

refernces:

  • index (建立索引)
  • alter   (更改表属性)
  • create  temp  orary  tableslock  tables  (锁表

execute :

  • create  view   (创建视图)
  • show  view     (显示视图)
  • create  routine   (创建存储过程)
  • alter  routine    (修改存储过程)
  • event   (事件)
  • trigger   on   (创建触发器)

5.3 查看权限

mysql -u root -p123456

show grants for '用户名'@'来源地址';

Mysql数据库的基本操作和用户的管理_第47张图片

 5.4 撤销权限

REVOKE 权限列表 on 数据库名.表名 from '用户名'@'来源地址';

show grants for 'zzzzz'@'localhost';

revoke select on ning.* from 'zzzzz'@'localhost';

Mysql数据库的基本操作和用户的管理_第48张图片

总结

 1、展示数据库;show databases;
2、创建数据库:create database 数据库名
3、进入该数据库:use 数据库
4、创建表结构:create table 表名(字段1 数据类型 NOT NULL,字段2,数据类型 NOT NULL…primary key(某唯一字段));
5、展示该数据库中的表:show tables;
6、插入表内容:insert into 表名 values (结构对应值);
7、按照条件查询内容:select * from 表名 where 字段 = 值;
8、更新数据:update 表名 set 字段=新值 where 字段=值;
9、删除表信息:delete from 表名 where 字段 = 值;
10、只查询当前表中的前2个:select * from 表名 limit=2;
11、只查询当前表中的4-5的用户:select * from 表名 limit 3,2;
12、更改表名:alter table 表名 rename 新表名
13、扩展表结构:alter table 表名 add 新字段 数据类型 default ‘添加默认’;
14、删除指定的表:drop table 表名;
15、克隆表:create table 新表名 like 旧表名,备份内容:insert into 新表名 select * from 旧表名;
16、 清空表、删除表内所有数据:delete from 表名;truncate table 表名;17、授权:grant all privileges on 数据库.数据表 to ‘用户名’@'主机名’identified by ‘密码’;
18、删除授权:revoke all privileges on 数据库.数据表 from 用户@主机;

19、克隆表:create table 新表名 like 旧表名,备份内容:insert into 新表名 select * from 旧表名;

20、 清空表、删除表内所有数据:delete from 表名;truncate table 表名;

21、 授权:grant all privileges on 数据库.数据表 to ‘用户名’@'主机名’identified by ‘密码’;

22、 删除授权:revoke all privileges on 数据库.数据表 from 用户@主机;
 


 

你可能感兴趣的:(mysql,数据库,database)