mysql数据库中数据表高级操作用户管理用户授权。
Posted 沉入深海
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql数据库中数据表高级操作用户管理用户授权。相关的知识,希望对你有一定的参考价值。
mysql数据库中数据表高级操作、用户管理、用户授权。
一、数据库表结构高级操作
1.克隆表
将数据表的数据记录生成到一个新的表中
1.1方法一:用 like 复制表格式再进行复制表数据内容
create table tt1 like tt; #复制格式,通过LIKE方法,复制KY08表结构生成test01表
insert into tt1 select * from tt; #备份内容
1.2 直接一步创建(CTEATE加SELECT组合的方式)
CREATE TABLE tt2 (SELECT * from tt);
show create table tt2\\G #获取数据表的表结构、索引等信息
SELECT * from tt2;
2.清空表,删除表内的所有数据
delete
delete from tt2;
#DELETE清空表后,返回的结果内有删除的记录条目; DELETE 工作时是一行一行的删除记录数据的;如果表中有自增长字段,使用DELETE FROM 删除所有记录后,再次新添加的记录会从原来最大的记录ID后面继续自增写入记录。
truncate
truncate table tt2;
#TRUNCATE清空表后,没有返回被删除的条目: TRUNCATE 工作时是将表结构按原样重新建立,因此在速度上TRUNCATE会比DELETE清空表快;使用TRUNCATE TABLE 清空表内数据后,ID会从1开始重新记录。
3.创建临时表
临时表创建成功之后,使用SHOW TABLES命令是看不到创建的临时表的,临时表会在连接退出后被销毁。 如果在退出连接之前,也可以可执行增删改查等操作,比如使用 DROP TABLE 语句手动直接删除临时表。
CREATE TEMPORARY TABLE 表名;
4.创建外键约束,保证数据的完整性和一致性
4.1MySQL中6种常见的约束
主键约束(primary key)
外键约束(foreign key)
非空约束(not null)
唯一性约束(unique [key|index])
默认值约束(default)
自增约束(auto_increment)
外键:如果同一个属性字段x在表一中是主键,而在表二中不是主键,则字段x称为表二的外键。
4.2 主键表和外键表的理解
(1)以公共关键字作主键的表为主键表(父表、主表)
(2)以公共关键字作外键的表为外键表(从表、外表)
注意:与外键关联的主表的字段必须设置为主键。要求从表不能是临时表,主表外键字段和从表的字段具备相同的数据类型、字符长度和约束。
4.3 实例
#创建从表 A
create table A (id int(4),name varchar(16),hobtype varchar(30));
#创建主表 B
create table B (hobtype varchar(30),hob varchar(20));
#为主表B和A添加一个主键约束。主键名建议以"PK_”开头。
alter table A add constraint PK_id primary key (id);
alter table B add constraint PK_id primary key (hobtype);
#在表A中为从表B表添加外键,并将B表的hobtype字段和A表的hobtype字段建立外键关联。外键名建议以"FK_”开头。
alter table A add constraint FK_hobtype foreign key (hobtype) references B (hobtype) ;
desc A;
desc B;
查看结构情况显示外键关联
show create table A;
4.5插入新的数据记录时,要先主表再从表
insert into B values(1,'RUNNING');
insert into B values(2,'read');
insert into A values(1,'RAIN',2);
insert into A values(2,'cmm',1);
这里需要先在主表 再在从表。这里我弄错 主表和从表了,因此报错。
以下正确
删数据记录时,要先从表再主表,也就是说删除主键表时必须要先删除其他与之相关联的表
查看和删除外键约束
show create table A\\G; #查看表A的结构
alter table A drop foreign key FK_hob; #删除关联
alter table A drop key FK_hob; #删除外键
desc A; #查看结构
二、数据库用户管理
1.新建用户
create user '用户名'@'来源地址' identified by '密码';
create user 'rain'@'localhost' identified by 'abc123';
用户名:用来登录mysql的用户
来源地址:指定新创建的用户可在哪些主机上登录,可使用IP地址、网段、主机名的形式,本地用户可用localhost,允许任意主机登录。可以使用通配符 %表示所有
2.查看用户信息
use mysql;
select User,authentication_string,Host from user;
3.用户重命名
rename user 'rain'@'localhost' to 'rainnew'@'localhost';
select User,authentication_string,Host from user;
4.删除用户
drop user 'rainnew'@'localhost';
select User,authentication_string,Host from user;
5.修改当前登录用户密码
set password = password('666666');
quit
mysql -u root -p
6.修改其他用户密码
SET PASSWORD FOR '用户'@'localhost' = ‘PASSWORD’ ;
set password for 'rainnn'@'localhost'='666666';
7.忘记root密码的解决办法
1.通过修改配置文件,达到免密登录到mysql。
vim /etc/my.cnf
[mysqld]
skip-grant-tables #添加,使登录mysql不使用授权表
systemctl restart mysqld
mysql #直接登录
2.使用update修改root密码,刷新数据库。
UPDATE mysql.user SET AUTHENTICATION_STRING = PASSWORD('mm1234') where user='root';
FLUSH PRIVILEGES;
quit
mysql -u root -pabc123
注意:最后再把/etc/my.cnf 配置文件里的skip-grant-tables 删除,并重启mysql服务。
8.数据库用户授权
1、授予权限
- GRANT语句:专门用来设置数据库用户的访问权限。当指定的用户名不存在时,GRANT语句将会创建新的用户;当指定的用户名存在时,GRANT语句用于修改用户信息。
GRANT 权限列表 ON 数据库名.表名 TO '用户名'@'来源地址' IDENTIFIED BY '密码';
grant select on rain.* to 'rainnn'@'localhost' identified by 'abc123';
字段命令解释:
- 权限列表:用于列出授权使用的各种数据库操作,以逗号进行分隔,如“select, insert, update”。使用"all"表示所有权限,可授权执行任何操作。
- 数据库名.表名:用于指定授权操作的数据库和表的名称,其中可以使用通配符""。例如,使用“kgc."表示授权操作的对象为xyw数据库中的所有表。
- ‘用户名@来源地址’:用于指定用户名称和允许访问的客户机地址,即谁能连接、能从哪里连接。来源地址可以是域名、IP地址,还可以使用“%”通配符,表示某个区域或网段内的所有地址,如“%.xyw.com"、“192. 168.80.%”等。
- IDENTIFIED BY:用于设置用户连接数据库时所使用的密码字符串。在新建用户时,若省略“IDENTIFIED BY"部分,则用户的密码将为空。
验证:
2、查看权限
mysql -u 用户名 -p密码
SHOW GRANTS FOR 用户名@来源地址;
3、撤销权限
REVOKE 权限列表 ON 数据库名.表名 FROM 用户名@来源地址;
REVOKE ALL ON *.* FROM 'rainnn'@'%'; #这里的.*.表示 :数据库.表
SHOW GRANTS FOR 'rainnn'@'%';
#USAGE权限只能用于数据库登陆,不能执行任何操作; USAGE权限不能被回收,即REVOKE不能删除用户。
flush privileges;
以上是关于mysql数据库中数据表高级操作用户管理用户授权。的主要内容,如果未能解决你的问题,请参考以下文章