百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> 看看MySQL数据库高级操纵
分享文章到:

看看MySQL数据库高级操纵

发布时间:01/01 来源:未知 浏览: 关键词:

免费学习引荐:mysql视频教程

文章名目

  • 数据表高级操纵
    • 预备工作:安置MySQL数据库
  • 一、克隆表
    • 办法一
    • 办法二
  • 二、清空表,删除表内的所有数据
    • 办法一
    • 办法二
  • 三、创立暂时表
  • 四、创立外键束缚
    • MySQL中6种常见的束缚
  • 五、数据库会员治理
    • 1、创建会员
    • 2、查看会员信息
    • 3、重命名会员
    • 4、删除会员
    • 5、修改当前登录会员密码
    • 6、修改其他会员密码
    • 7、健忘 root 密码的解决方法
  • 六、数据库会员授权
    • 1、授予权限
    • 2、查看权限
    • 3、撤销权限

数据表高级操纵

预备工作:安置MySQL数据库

Shell足本一键摆设——源码编译安置MySQL

create database CLASS;
use CLASS;

create table TEST (id int not null,name char(20) 	not null,cardid varchar(18) not null unique 	key,primary key (id));

insert into TEST(id,name,cardid) values (1,'zhangsan','123123');

insert into TEST(id,name,cardid) values (2,'lisi','1231231');

insert into TEST(id,name,cardid) values (3,'wangwu','12312312');
select * from TEST;

在这里插入图片描述


一、克隆表

将数据表的数据记载生成到新的表中

办法一

例:create table TEST01 like TEST;
select * from TEST01;

desc TEST01;
insert into TEST01 select * from TEST;
select * from TEST01;

在这里插入图片描述

办法二

例:create table TEST02 (select * from TEST);
select * from TEST02;

在这里插入图片描述

二、清空表,删除表内的所有数据

办法一

delete from TEST02;

#DELETE清空表后,返回的结果内有删除的记载条目;DELETE工作时是一行一行的删除记载数据的;假如表中有自增长字段,使用DELETE FROM 删除所有记载后,再次新增加的记载会从本来最大的记载 ID 后面连续自增写入记载

在这里插入图片描述

例:create table if not exists TEST03 (id int primary 	key auto_increment,name varchar(20) not null,cardid varchar(18) not null unique key);
show tables;

insert into TEST03 (name,cardid) values ('zhangsan','11111');		
select * from TEST03;
delete from TEST03;

insert into TEST03 (name,cardid) values ('lisi','22222');
select * from TEST03;

在这里插入图片描述

办法二

例:select * from TEST03;
truncate table TEST03;
insert into TEST03 (name,cardid) values ('wangwu','33333');
select * from TEST03;

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

在这里插入图片描述


三、创立暂时表

暂时表创立成功之后,使用SHOW TABLES命令是看不到创立的暂时表的,暂时表会在连接退出后被烧毁。 假如在退出连接此前,也可以可施行增删改查等操纵,比方使用 DROP TABLE 语句手动直接删除暂时表。

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

例:create temporary table TEST04 (id int not null,name varchar(20) not null,cardid varchar(18) not null unique key,primary key (id));
show tables;

insert into TEST04 values (1,'haha','12345');	
select * from TEST04;

在这里插入图片描述在这里插入图片描述

四、创立外键束缚

包管数据的完全性和一致性
外键的定义:假如统一个属性字段x在表一中是主键,而在表二中不是主键,则字段x称为表二的外键。

主键表和外键表的懂得:
1、以公共关键字作为主键的表为主键表(父表、主表)
2、以公共关键字作为外键的表为外键表(从表、表面)

留意:与外键关联的主表的字段必需设定为主键,要求从表不克不及是暂时表,主从表的字段具有雷同的数据类型、字符长度和束缚

例:create table TEST04 (hobid int(4),hobname varchar(50));
create table TEST05 (id int(4) primary key auto_increment,name varchar(50),age int(4),hobid int(4));

alter table TEST04 add constraint PK_hobid primary key(hobid);
alter table TEST05 add constraint FK_hobid foreign key(hobid) references TEST04(hobid);

在这里插入图片描述

例:增加数据记载
insert into TEST05 values (1,'zhangsan','20',1);
insert into TEST04 values (1,'sleep');
insert into TEST05 values (1,'zhangsan',20,1);

在这里插入图片描述

例:drop table TEST04;
drop table TEST05;
drop table TEST04;

在这里插入图片描述
注:假如要删除外键束缚字段
先删除外键束缚,再删除外键名,此处不演示

show create table TEST05;
alter table TEST05 drop foreign key FK_hobid;
alter table TEST05 drop key FK_hobid;
desc TEST05;

MySQL中6种常见的束缚

主键束缚primary key
外键束缚foreign key
非空束缚not null
独一束缚unique [key
默许值束缚default
自增束缚auto_increment

五、数据库会员治理

1、创建会员

CREATE USER '会员名'@'来源地址' [IDENTIFIED BY [PASSWORD] '密码'];

‘会员名’:指定将创立的会员名

‘来源地址’:指定新创立的会员可在哪些主机上登录,可使用IP地址、网段、主机名的情势,当地会员可用localhost,同意任意主机登录可用通配符%

‘密码’:若使用明文密码,直接输入’密码’,插入到数据库时由Mysql主动加密;
------若使用加密密码,需要先使用SELECT PASSWORD(‘密码’); 猎取密文,再在语句中增加 PASSWORD ‘密文’;
------若省略“IDENTIFIED BY”部分,则会员的密码将为空(不倡议使用)

例:create user 'zhangsan'@'localhost' identified by '123123';
select password('123123');
create user 'lisi'@'localhost' identified by password '*E56A114692FE0DE073F9A1DD68A00EEB9703F3F1';

在这里插入图片描述


2、查看会员信息

创立后的会员留存在 mysql 数据库的 user 表里

USE mysql;
SELECT User,authentication_string,Host from user;

在这里插入图片描述

3、重命名会员

RENAME USER 'zhangsan'@'localhost' TO 'wangwu'@'localhost';
SELECT User,authentication_string,Host from user;

在这里插入图片描述

4、删除会员

DROP USER 'lisi'@'localhost';
SELECT User,authentication_string,Host from user;

在这里插入图片描述

5、修改当前登录会员密码

SET PASSWORD = PASSWORD('abc123');
quit
mysql -u root -p

在这里插入图片描述

6、修改其他会员密码

SET PASSWORD FOR 'wangwu'@'localhost' = PASSWORD('abc123');
use mysql;
SELECT User,authentication_string,Host from user;

7、健忘 root 密码的解决方法

1、修改 /etc/my.cnf 配置文件,不使用密码直接登录到 mysql

vim /etc/my.cnf
[mysqld]
skip-grant-tables					#增加,使登录mysql不使用授权表
systemctl restart mysqld
mysql								#直接登录

在这里插入图片描述
在这里插入图片描述

2、使用 update 修改 root 密码,刷新数据库

UPDATE mysql.user SET AUTHENTICATION_STRING = PASSWORD('112233') where user='root';
FLUSH PRIVILEGES;
quit

再把 /etc/my.cnf 配置文件里的 skip-grant-tables 删除,并重新启动 mysql 效劳。
mysql -u root -p
112233

在这里插入图片描述

六、数据库会员授权

1、授予权限

GRANT语句:专门用来设定数据库会员的拜访权限。当指定的会员名不存在时,GRANT语句将会创立新的会员;当指定的会员名存在时,GRANT 语句用于修改会员信息。

GRANT 权限列表 ON 数据库名.表名 TO '会员名'@'来源地址' [IDENTIFIED BY '密码'];

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

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

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

#IDENTIFIED BY:用于设定会员连接数据库时所使用的密码字符串。在创建会员时,若省略“IDENTIFIED BY”部分, 则会员的密码将为空。

#同意会员wangwu在当地查询 CLASS 数据库中所有表的数据记载,但制止查询其他数据库中的表的记载。

例:
GRANT select ON CLASS.* TO 'wangwu'@'localhost' IDENTIFIED BY '123456';
quit;
mysql -u wangwu -p
123456
show databases;
use information_schema;
show tables;
select * from INNODB_SYS_TABLESTATS;

#同意会员wangwu在当地长途连接 mysql ,并具有所有权限。

quit;
mysql -u root -p112233
GRANT ALL PRIVILEGES ON *.* TO 'wangwu'@'localhost' IDENTIFIED BY '123456';

flush privileges;
quit

mysql -u wangwu -p123456
create database SCHOOL;

2、查看权限

SHOW GRANTS FOR 会员名@来源地址;

例:
SHOW GRANTS FOR 'wangwu'@'localhost';

3、撤销权限

REVOKE 权限列表 ON 数据库名.表名 FROM 会员名@来源地址;

例:quit;
mysql -u root -p112233
SHOW GRANTS FOR 'wangwu'@'localhost';
REVOKE SELECT ON "CLASS".* FROM 'wangwu'@'localhost';

SHOW GRANTS FOR 'wangwu'@'localhost';

#USAGE权限只能用于数据库登陆,不克不及施行任何操纵;USAGE权限不克不及被回收,即 REVOKE 不克不及删除会员。

flush privileges;
打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有151人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板