目录
一、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数据库的数据文件存放在/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 文件。
类型 | 介绍 |
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的检索速度要快
mysql -u (用户)-p (密码)
show databases;
①选中你所要查询的库
use zhang;
②查看zhang库中的表
show tables;
desc zhao;
field :字段名称
type:数据的类型
null:是否允许为空
key:主键
default:默认值
extra:扩展属性
主键:数据库主键,指的是一个列或多列的组合,其值能唯一地标识表中的每一行,通过它可强制表的实体完整性。主键主要是用于其他表的外键关联,以及本记录的修改与删除。
主键是能确定一条记录的唯一标识,主键字段必须唯一,必须非空,一个表中只能有一个主键,主键可以包含一个或多个字段。
SQL语句是用于管理维护数据库,其中包括了对数据的查询、更新、访问、管理等。
DDL | 数据定义语言,用于创建数据库对象,例如 库、表 |
DML | 数据操控语言,对表中的数据去管理 |
DQL | 数据查询语言,用于去对表中的数据进行查询 |
DCL | 数据控制语言,用于修改设置数据库用户权限 |
CREATE DATABASE 数据库名字;
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:设置一个逐渐
DROP TABLE 名字; (删除指定的表)
DROP DATABASE 名字; (删除指定的库)
INSERT INTO 表名(字段1,字段2,等等) VALUES(字段1的内容,字段2的内容)
INSERT INTO zz (id,name,score,passwd)VALUES (1,'zhang',90,123456)
因为zhang为字符所以要加上'' 并且如果想要隐藏密码可以加上password
根据field下去定义需要插入的内容
用select * from zz;去查看插入的内容
如果你想隐藏密码可以加上password(’密码‘)即可
SELECT * from zz 查询zz表中的所有信息
SELECT 字段1,字段2 from 表名 where 条件
select name,score from zz where id=1; 查询zz表中id为1的name和score
UPDATA 表名 SET 字段名=字段名对应修改的内容 where (条件)
UPDATE zz SET name=’zha' where id='5';
DELETE from 表名 where (条件);
DELETE from zz where id= 3; (删除有关zz表中id=3的内容)
SELECT * FROM 表名; 查询表中的数据记录
SELECT id,name from 表名 查询表的对应字段
SELECT id,name from 表名 where (条件)
SELECT name from 表名\G 以竖向方式显示
SELECT * from 表名 limit 2; 只显示前2行
SELECT * from 表名 limit 1,2; 只显示第一行后的前两行
ALTER TABLE 旧表名 rename 新表名;
ALTER TABLE 表名 add age char(40) default ‘未知’; 在表zzz中添加新的字段,默认字为未知
ALTER TABLE 表名 CHANGE 原字段 新字段 数据类型 unique key;
unique key: 唯一键(特性:唯一,但可以为空,空值只允许出现一次)
primary key:唯一且非空
alter table zzz change name users varchar(20) unique key;
ALTER TABLE 表名 DROP 字段名;
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
可以看到添加信息时没有输入id他会自动的去添加id顺序。
create table 新表名 like 需要克隆的表名;
insert into 新表名 select * from 需要拷贝数据的表名;
create table wwww like zzz;
insert into wwww select * from zzz;
create table 新表名 (select * from 需要克隆的表名);
delete from 表名
truncate table 表名
DELETE清空表后,返回的结果内有删除的记录条目;DELETE工作时是一行一行的删除记录数据的;如果表中有自增长字段,使用DELETE FROM 删除所有记录后,再次新添加的记录会从原来最大的记录 ID 后面继续自增写入记录。(例;删除出100个数据,)
TRUNCATE 清空表后,没有返回被删除的条目;TRUNCATE 工作时是将表结构按原样重新建立,因此在速度上 TRUNCATE 会比 DELETE 清空表快;使用 TRUNCATE TABLE 清空表内数据后,ID 会从 1 开始重新记录
drop table table-name
truncate table table-name
delete from table table-name
整理:
不再需要一张表的时候,用 drop
想删除部分数据行的时候,用delete ,并且带上where 语句
保留表面删除所有数据的时候用 truncate
删除速度
drop > truncate > delete
安全性
delete 最好
创建的临时表,show tables是看不到的,因为临时表退出后会自动的销毁
create temporary table 表名
可以看到show tables是看不到表的
外键的定义:如果同一属性的字段x在表一中是主键,而在表二不是主键,则字段x是表二的外键。
主键表和外键表的理解:
以公共关键字作为主键的表为主键表
以公共关键字作为外键的表为外键表
当从表设置了外键约束后插入和删除数据就必须要先从主表删除
●MySQL中6种常见的约束:
主键约束(primary key)
外键约束(foreign key)
非空约束(not null)
唯一性约束(unique [key|index] )
默认值约束(default)
自增约束(auto_increment)
CREATE USER ‘用户名’@‘来源地址’ indentified by ‘密码’
'来源地址': 指定新创建的用户可在哪些主机上登录,可使用IP地址、网段、主机名的形式,本地用户可用localhost,允许任意主机登录可用通配符 %
'密码':
若使用明文密码,直接输入'密码',插入到数据库时由Mysql自动加密;
若使用加密密码,需要先使用SELECT PASSWORD('密码');获取密文,再在语句中添加 PASSWORD '密文';
若省略“IDENTIFIED BY" 部分,则用户的密码将为空(不建议使用)
select password(‘123456’); 获取密文
create user '名字'@'来源' identified by password '获取的密文'
创建的用户在mysql库中的user表里
use mysql;
select user,authentication_string,host from user;
rename user '原名字'@'原来源地址' to ‘新名字'@'新的源地址';
drop user ‘用户名’@‘来源地址’
set password = password(‘密码’)
set password for '用户名'@‘来源地址’ = password('密码');
vim /etc/my.cnf
在【mysqld】 下添加 skip-grant-tables
update mysql.user set authentication_string = password('654321') where user='root' ;
flush privileges; 刷新数据
GRANT:专门用于设置数据库用户的访问权限。如果被指定的用户不存在,则会自动的创建一个新的用户。
GRANT 权限列表 on 数据库名.表名 to '用户名'@'来源地址' identified by ’密码‘;
权限列表:用于列出授权使用的各种数据库操作,以逗号进行分隔,如“select,insert,update”。使用“all”表示所有权限,可授权执行任何操作。
数据库名.表名:用于指定授权操作的数据库和表的名称,其中可以使用通配符 “*” 。例如,使用“kgc.*”表示授权操作的对象为 kgc数据库中的所有表。
'
用户名'@'来源地址':用于指定用户名称和允许访问的客户机地址,即谁能连接、能从哪里连接。来源地址可以是域名、IP 地址,还可以使用“%”通配符,表示某个区域或网段内的所有地址,如“%.accp.com”、“192.168.80.%”等。
IDENTIFIED BY:用于设置用户连接数据库时所使用的密码字符串。在新建用户时,若省略“identified by”部分, 则用户的密码将为空。
grant select on ning.* to 'zzzzz'@'localhost' identified by '123456';
测试使用zzzzz用户登录mysql
grant all on *.* to 'zzzzz'@'%' identified by '123456';
在客户端上测试
授权用户的权限是:all privilege
all privilege的权限:
refernces:
execute :
mysql -u root -p123456
show grants for '用户名'@'来源地址';
REVOKE 权限列表 on 数据库名.表名 from '用户名'@'来源地址';
show grants for 'zzzzz'@'localhost';
revoke select on ning.* from 'zzzzz'@'localhost';
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 用户@主机;