看看MySQL数据库高级操纵
免费学习引荐: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;