MYSQL基础

一.了解数据库

1.数据库的基本概念

  1. 数据(Data)
    描述事物的符号记录
    (包括数字,文字,图形,图像,声音,档案记录等,以“记录”形式按统一的格式进行存储)

  2. 将不同的记录组织在一起用来存储具体数据
  3. 数据库
    表的集合,是存储数据的仓库
    以一定的组织方式存储的相互有关的数据集合
  4. 数据库管理系统(DBMS)
    是实现对数据库资源有效组织、管理和存取的系统软件
  5. 数据库系统
    是一个人机系统,由硬件、os、数据库、DBMS、应用软件和数据库用户组成
    用户可以通过DBMS或应用程序操作数据库
    2.数据库系统发展史
    第一代数据库
    自20世纪60年代起,第一代数据库系统问世是层次模型与网状模型的数据库系统
    为统一管理和共享数据提供了有力的支撑
    第二代数据库
    20世纪70年代初,第二代数据库——关系数据库开始出现
    20世纪80年代初,IBM公司的关系数据库系统DB2问世,开始逐步取代层次与网状模型的数据库,成为行业主流
    到目前为止,关系数据库系统仍占领数据库应用的主要地位
    3.当今主流数据库介绍
    名称 介绍
    SQL Server (微软公司产品) • 面向Windows操作系统 简单易用
    Oracle (甲骨文公司产品) 面向所有主流平台 安全、完善,操作复杂
    DB2 (IBM公司产品) 面向所有主流平台 大型、安全、完善
    MySQL (甲骨文公司收购) 免费 开源、体积小
    4.关系数据库
  • 关系数据库系统是基于关系模型的数据库系统
  • 关系模型的数据结构使用简单易懂的二_维数据表
  • 关系模型可用简单的“实体关系”(E-R) 图来表示
  • E-R图中包含了实体(数据对象)、关系和属性三个要素
    1
    2
    3
    4
    实体
    也称为实例,对应现实世界中可区别于其它对象的“事件”或“事物”
    属性
    实体所具体的某一特性,一个实体可以有多个属性
    联系
    实体集之间的对应关系称为联系,也称为关系

所有实体及实体之间联系的集合构成一个关系数据库

关系数据库的存储结构是二维表格
在每个二维表中
每一行称为一条记录,用来描述一个对象的信息
每一列称为一个字段,用来描述对象的一个属性
常用的关系数据库:
Oracle , MySQL
SQLServer、Sybase
Informix、access
DB2、FoxPRO
5.非关系数据库
非关系数据库介绍:

非关系数据库也被称作NoSQL (Not Only SQL)

存储数据不以关系模型为依据,不需要固定的表格式

非关系型数据库的优点:

数据库可高并发读写
对海数据高效率存储与访问
数据库具有高扩展性与高可用性
常用的非关系数据库:Redis、mongoDB等

6.MySQL数据库介绍
(1)了解MySQL数据库
一款深受欢迎的开源关系型数据库

Oracle旗下的产品

遵守GPL协议,可以免费使用与修改

特点:• 性能卓越、服务稳定
• 开源、无版权限制、成本低
• 多线程、多用户
• 基于C/S (客户端/服务器)架构
• 安全可靠

(2)MySQL商业版与社区版
MySQL商业版是由MySQL AB公司负责开发与维护,需要付费才能使用

MySQL社区版是由分散在世界各地的MySQL开发者、爱好者一起开发与维护,可以免费使用

两者区别
• 商业版组织管理与测试环节更加严格,蚍社区版更稳定
• 商业版不遵守GPL,社区版遵从GPL可以免费使用
• 商业版可获得7*24小时的服务,社区版则没有

(3)MySQL产品阵营
第一阵营: 5.0-5.1阵营,可说是早期产品的延续

第二阵营: 5.4-5.7阵营, 整合了MySQL AB公司、社区和第三方公司开发的存储引擎,从而提高性能

第三阵营: 6.0-7.1阵营, 就是MySQL Cluster版本,为适应新时代对数据库的集群需求而开发

下载网址 ●http://www.dev.mysql.com/downloads

二.MySQL数据库管理

1.常用的数据类型
类型 解释
int 整型
float 单精度浮点 4字节32位
double 双精度浮点 8字节64位
char 固定长度的字符类型
varchar 可变长度的字符类型
text 文本
image 图片
decimal(5,2) 5个有效长度数字,小数点后面有2位
2.查看数据库结构的命令
连接mysql
在这里插入图片描述
查看当前服务器中的数据库
在这里插入图片描述
查看数据库中包含的表
在这里插入图片描述
查看表结构(字段)
在这里插入图片描述
#SQL语句
Structured Query Language 的缩写,即结构化查询语言
关系型数据库的标准语言
SQL语句用于维护管理数据库,包括数据查询、数据更新、访问控制、对象管理等功能

SQL语言分类:
类型 用法
DDL 数据定义语言,用于创建数据库对象,如库、表、索引等
DML 数据操纵语言,用于对表中的数据进行管理
DQL 数据查询语言,用于从数据表中查找符合条件的数据记录
DCL 数据控制语言,用于设置或者更改数据库用户或角色权限

创建及删除数据库和表
创建新的数据库
1. 创建新的数据库
CREATE DATABASE 数据库名;

2. 创建新的表
CREATE TABLE 表名 (字段1 数据类型,字段2 数据类型[,…][,PRIMARY KEY (主键名)]);
#主键一般选择能代表唯一性的字段不允许取空值(NULL),一个表只能有一个主键。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
3.删除指定的数据表
DROP TABLE [数据库名.]表名;
#如不用USE进入库中,则需加上数据库名
在这里插入图片描述
4.删除指定的数据库
DROP DATABASE 数据库名;
在这里插入图片描述
5.管理表中的数据记录
1.向数据表中插入新的数据记录
INSERT INTO 表名(字段1,字段2[,…]) VALUES(字段1的值,字段2的值,…);
在这里插入图片描述
在这里插入图片描述
2.查询数据记录
SELECT 字段名1,字段名2[,…] FROM 表名 [WHERE 条件表达式];
在这里插入图片描述
3.修改、更新数据表中的数据记录
UPDATE 表名 SET 字段名1=字段值1[,字段名2=字段值2] [WHERE 条件表达式];
在这里插入图片描述
6 .修改表名和表结构
1.修改表名
ALTER TABLE 旧表名 RENAME 新表名;
在这里插入图片描述
2.扩展表结构(增加字段)
ALTER TABLE 表名 ADD address varchar(50) default ‘地址不详’;

#default ‘地址不详’:表示此字段设置默认值 地址不详;可与 NOT NULL 配合使用
在这里插入图片描述
3.修改字段(列)名,添加唯一键
ALTER TABLE 表名 CHANGE 旧列名 新列名 数据类型 [unique key];
在这里插入图片描述
4.删除字段
ALTER TABLE 表名 drop 字段名;
在这里插入图片描述
7.数据表高级操作
1.克隆表,将数据表的数据记录生成到新的表中

在这里插入图片描述
通过LIKE 方法,复制WD表结构生成qqq

2.清空表,删除表内的所有数据
方法一:
delete from WQD;
#DELETE清空表后,返回的结果内有删除的记录条目;DELETE工作时是一行一行的删除记录数据的;如果表中有自增长字段,使用DELETE FROM 删除所有记录后,再次新添加的记录会从原来最大的记录 ID 后面继续自增写入记录。

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

3.创建临时表
临时表创建成功之后,使用SHOW TABLES命令是看不到创建的临时表的,临时表会在连接退出后被销毁。 如果在退出连接之前,也可以可执行增删改查等操作,比如使用 DROP TABLE 语句手动直接删除临时表。

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

4.创建外键约束,保证数据的完整性和一致性
主键表和外键表的理解:
(1)以公共关键字作主键的表为主键表(父表、主表)
(2)以公共关键字作外键的表为外键表(从表、外表)

注意:与外键关联的子表的字段必须设置为主键。要求主表外键字段和子表的字段具备相同的数据类型、字符长度和约束。
#创建子表test04
create table test04 (sid int(4),hobname varchar(20));
#为子表添加一个主键约束。主键名建议以“PK_”开头。
alter table test04 add constraint PK_sid primary key test04 (sid);
#为 test03 表添加外键,并将 test03 表的 hobby 字段和 test04 表的 sid 字段建立外键关联。外键名建议以“FK_”开头。
alter table test03 add constraint FK_hob foreign key (hobby) references test04 (sid);

desc test03;

#插入新的数据记录时,要先主表再从表
insert into test04 values (1,‘runing’) ;
insert into test05 values (1,‘zhangsan’,18,1) ;

#删数数据记录时,要先从表再主表,也就是说删除主键表时必须先删除其他与之关联的表。
drop tables test05;
drop tables test04;

#查看和删除外键约束
show create table test03;
alter table test03 drop foreign key FK_hob;
alter table test03 drop key FK_hob;
desc test03;

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

MySQL中6种常见的约束:主键约束(primary key)

                                   外键约束(foreign key) 

                                   非空约束(not null)

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

                                   默认值约束(default)

                                   自增约束(auto_increment)

8.数据库用户管理
1.新建用户
CREATE USER ‘用户名’@‘来源地址’ [IDENTIFIED BY [PASSWORD] ‘密码’];


‘用户名’:指定将创建的用户名
‘来源地址’:指定新创建的用户可在哪些主机上登录,可使用IP地址、网段、主机名的形式,本地用户可用localhost,允许任意主机登录可用通配符%
‘密码’:若使用明文密码,直接输入’密码’,插入到数据库时由Mysql自动加密;
若使用加密密码,需要先使用SELECT PASSWORD(‘密码’); 获取密文,再在语句中添加 PASSWORD ‘密文’;

    若省略“IDENTIFIED BY”部分,则用户的密码将为空(不建议使用)

CREATE USER ‘user1’@‘localhost’ IDENTIFIED BY ‘123456’;

SELECT PASSWORD(‘abc123’);
CREATE USER ‘user2’@‘localhost’ IDENTIFIED BY PASSWORD ‘*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9’;

2.查看用户信息
#创建后的用户保存在 mysql 数据库的 user 表里
USE mysql;
SELECT User,authentication_string,Host from user;

3.重命名用户
RENAME USER ‘zhangsan’@‘localhost’ TO ‘lisi’@‘localhost’;

4.删除用户
DROP USER ‘lisi’@‘localhost’;

5.修改当前登录用户密码
SET PASSWORD = PASSWORD(‘abc123’);

6.修改其他用户密码
SET PASSWORD FOR ‘user1’@‘localhost’ = PASSWORD(‘abc123’);

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(‘abc123’) where user=‘root’;

FLUSH PRIVILEGES;
quit

mysql -u root -pabc123

注意:最后再把 /etc/my.cnf 配置文件里的 skip-grant-tables 删除,并重启 mysql 服务。

9.数据库用户授权
1.授予权限
GRANT语句:专门用来设置数据库用户的访问权限。当指定的用户名不存在时,GRANT语句将会创建新的用户;当指定的用户名存在时,GRANT 语句用于修改用户信息。

GRANT 权限列表ON数据库名。表名TO’用户名‘@’来源地址‘[IDENTIFIED BY ‘密码’];


#权限列表:用于列出授权使用的各种数据库操作,以逗号进行分隔,如“select,insert,update”。使用“all”表示所有权限,可授权执行任何操作。
#数据库名.表名:用于指定授权操作的数据库和表的名称,其中可以使用通配符“”。例如,使用“kgc.”表示授权操作的对象为 kgc数据库中的所有表。
#‘用户名@来源地址’:用于指定用户名称和允许访问的客户机地址,即谁能连接、能从哪里连接。来源地址可以是域名、IP 地址,还可以使用“%”通配符,表示某个区域或网段内的所有地址,如“%.kgc.com”、“192.168.80.%”等。
#IDENTIFIED BY:用于设置用户连接数据库时所使用的密码字符串。在新建用户时,若省略“IDENTIFIED BY”部分, 则用户的密码将为空。


#允许用户 zhangsan 在本地查询 kgc 数据库中 所有表的数据记录,但禁止查询其他数据库中的表的记录。
GRANT select ON kgc.* TO ‘zhangsan’@‘localhost’ IDENTIFIED BY ‘123456’;

#允许用户 lisi 在所有终端远程连接 mysql ,并拥有所有权限。
GRANT ALL [PRIVILEGES] ON . TO ‘lisi’@‘%’ IDENTIFIED BY ‘123456’;

flush privileges;
quit

mysql -u zhangsan -p123456
use kgc;
show tables;
select * from KY08;

2.查看权限
SHOW GRANTS FOR 用户名@来源地址;

例:
SHOW GRANTS FOR ‘lisi’@‘%’;

3.撤销权限
REVOKE 权限列表 ON 数据库名.表名 FROM 用户名@来源地址;

例:
REVOKE ALL ON . FROM ‘lisi’@‘%’;

SHOW GRANTS FOR ‘lisi’@‘%’;
#USAGE权限只能用于数据库登陆,不能执行任何操作;USAGE权限不能被回收,即 REVOKE 不能删除用户。

flush privileges;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值