临海钢结构设计网站,深圳动漫制作,科技守护者下载,dw网页制作怎么改字体大小Mysql Part 1 一、数据库的基本概念1.1 使用数据库的必要性1.2 数据库基本概念1.2.1 数据#xff08;Data#xff09;1.2.2 表1.2.3 数据库1.2.4 数据库管理系统#xff08;DBMS#xff09;1.2.5 数据库系统 1.3 数据库的分类1.3.1 关系数据库 SQL1.3.2 非关系数据库 NoSQL… Mysql Part 1 一、数据库的基本概念1.1 使用数据库的必要性1.2 数据库基本概念1.2.1 数据Data1.2.2 表1.2.3 数据库1.2.4 数据库管理系统DBMS1.2.5 数据库系统 1.3 数据库的分类1.3.1 关系数据库 SQL1.3.2 非关系数据库 NoSQL 1.4 主键 二、MySQL数据库简介2.1 什么是MySQL2.2 MySQL的特点2.3 常用的数据类型2.4 SQL语句2.5 MySQL的约束特性(六大约束)2.6 用navicat for mysql 连接MySQL数据库 三、MySQL数据库基本操作3.1 登录MySQL数据库3.2 查看数据库结构1查看当前服务器中的数据库2查看数据库中包含的表3查看表的结构字段 3.3 创建及删除数据库/font和数据表/font1创建新的数据库2创建新的表3删除指定的数据表4删除指定的数据库 3.4 管理数据表/font中的数据记录/font1向数据表中插入新的数据记录2查询数据记录3修改、更新数据表中的数据记录4在数据表中删除指定的数据记录 3.5 修改表名/font和表结构/font1修改表名2扩展表结构增加字段3修改字段列名添加唯一键4删除字段 3.6 扩展 四、数据表的高级操作4.1 克隆表4.2 清空表4.3 创建临时表4.4 创建外键约束保证数据的完整性和一致性 五、数据库用户管理5.1 新建用户5.2 查看用户信息5.3 重命名用户5.4 删除用户5.5 修改当前登录用户密码5.6 修改其他用户密码5.7 忘记 root 密码的解决办法 六、数据库用户授权6.1 授予权限6.2 查看权限6.3 撤销权限 七、命令总结 一、数据库的基本概念
内核的作用调用硬件资源
1.1 使用数据库的必要性
使用数据库可以高效且条理分明地存储数据使人们能够更加迅速、方便地管理数据。
数据库具有以下特点 1可以结构化存储大量的数据信息方便用户进行有效的检索和访问 2可以有效地保持数据信息的一致性、完整性降低数据冗余 3可以满足应用的共享和安全方面的要求。
数据库技术是计算机科学的核心技术之一具有完备的理论基础。 对数据库基本概念的掌握将有助于对数据库的理解。
1.2 数据库基本概念
1.2.1 数据Data
描述事物的符号记录
包括数字文字、图形、图像、声音、档案记录等
以“记录”形式按统一的格式进行存储
1.2.2 表
将不同的记录组织在一起
用来存储具体数据
1.2.3 数据库
表的集合是存储数据的仓库
以一定的组织方式存储的相互有关的数据集合
1.2.4 数据库管理系统DBMS
数据库管理系统是实现对数据库资源有效组织、 管理和存取的系统软件。 功能 数据库的建立和维护功能包括建立数据库的结构和数据的录入与转换、数据库的 转储与恢复、数据库的重组与性能监视等功能。
数据定义功能包括定义全局数据结构、局部逻辑数据结构、存储结构、保密模式 及信息格式等功能。保证存储在数据库中的数据正确、有效和相容以防止不合语 义的错误数据被输入或输出。
数据操纵功能包括数据查询统计和数据更新两个方面。
数据库的运行管理功能这是数据库管理系统的核心部分包括并发控制、存取控 制、数据库内部维护等功能。
通信功能DBMS 与其他软件系统之间的通信,如 Access 能与其他 Office 组件进行 数据交换。
1.2.5 数据库系统 是一个人机系统由硬件、OS、数据库、DBMS、应用软件和数据库用户组成。 用户可以通过DBMS或应用程序操作数据库。
1.3 数据库的分类
数据库分两大类关系型数据库和非关系型数据库。
1.3.1 关系数据库 SQL
操作命令SQL语句
存储结构二维表格
存储的数据结构化数据
库 - 表 - 二维表格形式的结构化数据 每一行称为一条记录用来描述一个对象的信息
每一列称为一个字段用来描述对象的一个属性。
1.3.2 非关系数据库 NoSQL
存储结构键值对 文档 索引 时间序列 缓存型 Redis Memcached 文档型 MongoDB 索引型 ElasticSearch 时序型 Prometheus InfluxDB
1.4 主键
主键Primary Key是一个数据库表中的一列或一组列用于确保数据的唯一性和数据行的唯一标识。 在表中主键的值是唯一的。
主键具有以下特点 1唯一性主键列中的值必须是唯一的每一行的主键值都不相同。 2非空性主键列的值不能为空也就是不允许为空值或NULL值。 3唯一标识性主键用于识别和区分表中的不同行数据通过主键可以快速定位和访问表中的数据。
主键还可以用于建立表与表之间的关系实现数据的关联和连接操作。
二、MySQL数据库简介
2.1 什么是MySQL
一款深受欢迎的开源关系型数据库 Oracle旗下的产品 遵守GPL协议可以免费使用与修改
2.2 MySQL的特点
● 性能卓越、服务稳定 ● 开源、无版权限制、成本低 ● 多线程、多用户 ● 基于C/S客户端/服务器架构 ● 安全可靠
2.3 常用的数据类型
int 整型 无符号[0,232-1]有符号[-231,2^31-1] float 单精度浮点 4字节32位 double 双精度浮点 8字节64位 char 固定长度的字符类型 varchar 可变长度的字符类型 text 文本 image 图片 decimal(5,2) 5个有效长度数字小数点后面有2位
2.4 SQL语句
SQL语句用于维护管理数据库包括数据查询、数据更新、访问控制、对象管理等功能。
SQL语言分类 DDL数据定义语言用于创建数据库对象如库、表、索引等 DML数据操纵语言用于对表中的数据进行管理 DQL数据查询语言用于从数据表中查找符合条件的数据记录 DCL数据控制语言用于设置或者更改数据库用户或角色权限
2.5 MySQL的约束特性(六大约束)
primary key主键约束 字段的值不能重复且不能为null一个表只能有一个唯一键
uniq key唯一性约束 字段的值不能重复可以为null,一个表可以有多个唯一键
not null (非空约束) 字段的值不能为null
default 默认值约束 字段的值如果没有设置则使用默认值自动填充
auto_increment (自增约束) 字段的值如果没有设置默认会从1开始每次自动递增1要求自增字段必须设置主键
int(N) zerofill (零填充)
2.6 用navicat for mysql 连接MySQL数据库
直接连接navicat无法连接mysql -u root -p #登录数据库show databases;
#修改
use mysql
select host,user from user;
update user set host%where userroot;
flush privileges;配置完成后启动navicat配置相关项配置完成后点击连接测试测试是否能连接成功双击7-6连接到目标数据库三、MySQL数据库基本操作
3.1 登录MySQL数据库
表名和库名区分大小写
命令不区分大小写
mysqladmin -u root -p password 123123 #设置密码mysql -u root -p #登录3.2 查看数据库结构
1查看当前服务器中的数据库
show databases; #大小写不区分分号“;”表示结束2查看数据库中包含的表 方式一 USE 数据库名;
show tables;方式二 show tables from 数据库名;3查看表的结构字段 方式一 切换数据库 use 数据库名;
describe 表名;
或者
desc 表名;方式二 #不切换数据库
desc 库名.表名;3.3 创建及删除数据库和数据表
1创建新的数据库
create database 数据库名;#举个例子
create database byyb;2创建新的表
create table 表名 (字段1 数据类型,字段2 数据类型[,...][,primary key (主键名)]);
#主键一般选择能代表唯一性的字段不允许取空值NULL一个表只能有一个主键。#举个例子
create database byyb;
use byyb;create table by1 ( id int not null,name char(10) not null,score decimal (5,2),passwd char(48) default , primary key (id));desc by1;3删除指定的数据表
drop table [数据库名.]表名; #如不用USE进入库中则需加上数据库名4删除指定的数据库
drop database 数据库名;3.4 管理数据表中的数据记录
1向数据表中插入新的数据记录
insert into表名(字段1,字段2[,...]) values(字段1的值,字段2的值,...);#举个例子
insert into by1(id,name,score,passwd) values(1,zhangsan,70.5,password(123456));
insert into by1(id,name,score,passwd) values(2,lisi,80,123456);
insert into by1(id,name,score,passwd) values(2,lisi,80,123456);
#使用 password(123456),查询数据记录时密码字串以加密形式显示
#若不使用password( )查询时以明文显示2查询数据记录
select 字段名1,字段名2[,...] from 表名 [where 条件表达式];#举个例子
select * from by1; #查询所有数据记录
select id,name,score from by1 where id2; #查询特定的数据记录#扩展用法1
select name from by1\G#以列表方式竖向显示#扩展用法2
select * from by1 limit 2; #只显示头2行
select * from by1 limit 2,3; #显示第2行后的前3行3修改、更新数据表中的数据记录
update 表名 set 字段名1字段值1[,字段名2字段值2] [where 条件表达式];#举个例子
update by1 set name123 where id3;
update by1 set passwd123456 where namezhangsan;4在数据表中删除指定的数据记录
delete from 表名 [where 条件表达式];#举个例子
delete from by1 where id3;3.5 修改表名和表结构
1修改表名
alter table 旧表名 rename 新表名;#举个例子
alter table by1 rename byy12扩展表结构增加字段
alter table 表名 add 新字段 数据类型 [字段属性];#举个例子
alter table 表名 add address varchar(50) default 地址不详;
#default 地址不详表示此字段设置默认值 地址不详可与 NOT NULL 配合使用3修改字段列名添加唯一键
alter table 表名 change 旧字段 新字段 数据类型 [字段属性];#举个例子
ALTER TABLE KY08 CHANGE name user_name varchar(10) unique key;
#CHANGE可修改字段名、数据类型、约束等所有项。4删除字段
alter table 表名 drop 字段名;#举个例子
alter table byy1 drop passwd;3.6 扩展
use byy1;
create table if not exists info (
id int(4) zerofill primary key auto_increment, #指定主键的第二种方式
name varchar(10) not null default 匿名, #不允许为空
cardid int(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表示此字段不允许为NULLcreate table if not exists info (id int(4) zerofill primary key auto_increment,name varchar(10) not null default 匿名,cardid int(18) not null unique key,hobby varchar(50));四、数据表的高级操作
4.1 克隆表
将数据表的数据记录生成到新的表中。 方法一 create table 新表 like 旧表; #克隆表结构insert into 新表 select * from 旧表; #克隆表数据#此方法能保证 新表的表结构、表数据 跟旧表都是一致的#举个例子
create table byy2 like byy1;
insert into byy2 select * from byy1;方法二 create table 新表 (select * from 旧表);
#此方法创建的新表的表数据和旧表是一样的但可能会出现新表的表结构和旧表的不一致#举个例子
create table byy3 (select * from byy1);4.2 清空表
删除表内的所有数据。 方法一 delete from 表名;
#一条一条的删除记录效率较慢自增字段仍然会按照清空前的最大记录继续自增#举个例子
delete from byy3;方法二 truncate table 表名;
#直接重建表清空表效率更快自增字段会重新从1开始自增#举个例子
truncate table byy2;4.3 创建临时表
临时表创建成功之后使用show tables命令是看不到创建的临时表的临时表会在连接退出后被销毁。
如果在退出连接之前也可以可执行增删改查等操作比如使用 drop table语句手动直接删除临时表。
create temporary table 表名 (字段1 数据类型,字段2 数据类型[,...][,primary key (主键名)]);举个例子 create temporary table byyb2 (id int(4) zerofill primary key auto_increment,name varchar(10) not null,cardid int(18) not null unique key,hobby varchar(50));insert into byy2 values(1,zhangsan,123456,running);select * from byy2;
show tables;quitselect * from test03;4.4 创建外键约束保证数据的完整性和一致性
外键的定义如果同一个属性字段X在表一中是主键而在表二中不是主键则字段X称为表二的外键。
主键表和外键表的理解 1以公共关键字作主键的表为主键表父表、主表 2以公共关键字作外键的表为外键表从表、外表
注意与外键关联的主表的字段必须设置为主键。要求从表不能是临时表主从表的字段具备相同的数据类型、字符长度和约束。
主键表
alter table 表名 add primary key (主键字段);外键表
alter table 表名 add foreign key (外键字段) references 主键表名 (主键字段);
#插入新数据时需要先在主键表插入数据再在外键表插入对应数据删除数据时需要先在外键表删除数据再在主键表删除对应数据举个例子 #创建主表 profession
create table profession (pid int(4),proname varchar(50));#创建从表 student
create table student (id int(4) primary key auto_increment,name varchar(10),age int(3),proid int(4));#为主表 profession 添加一个主键约束。主键名建议以“PK_”开头。
alter table profession add constraint PK_pid primary key (pid);#为从表 student 表添加外键并将 student 表的 proid 字段和 profession 表的 pid 字段建立外键关联。外键名建议以“FK_”开头。
alter table student add constraint FK_pro foreign key (proid) references profession (pid);desc student;#插入新的数据记录时要先主表再从表
insert into profession values(1,云计算);
insert into profession values(2,大数据);
insert into student values(1,zhangsan,18,1);
insert into student values(2,lisi,19,1);
insert into student values(3,wangwu,20,2);#删数数据记录时要先从表再主表也就是说删除主键表的记录时必须先删除其他与之关联的表中的记录。
delete from student where proid1;
delete from profession where pid1;#查看外键约束
show create table student;
desc student;#删除外键约束
alter table student drop foreign key FK_pro;
alter table student drop key FK_pro;五、数据库用户管理
DCL数据控制语言用于设置或者更改数据库用户或角色权限
5.1 新建用户
create user 用户名源地址 identified by 密码;用户名
指定将创建的用户名来源地址
指定新创建的用户可在哪些主机上登录
可使用IP地址、网段、主机名的形式
本地用户可用localhost
允许任意主机登录可用通配符%密码
若使用明文密码直接输入密码插入到数据库时由Mysql自动加密若使用加密密码需要先使用select password(密码); 获取密文再在语句中添加 password 密文;若省略“identified by”部分则用户的密码将为空不建议使用create user user1localhost identified by 123456;select passwd(abc123);create user user2localhost identified by PASSWORD *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9;5.2 查看用户信息
#创建后的用户保存在 mysql 数据库的 user 表里
use mysql;
select user,authentication_string,Host from user;#查看当前登录用户
select user();5.3 重命名用户
rename user zhangsanlocalhost to lisilocalhost;5.4 删除用户
drop user lisilocalhost;5.5 修改当前登录用户密码
#修改当前用户的密码
set password password(abc123);5.6 修改其他用户密码
#方式一
set password for user1localhost PASSWORD(abc123);#方式二
alter user 用户名源地址 identified by 密码;alter user root% indentified by abc1235.7 忘记 root 密码的解决办法
1修改 mysql配置文件/etc/my.cnf 不使用密码直接登录到 mysql
vim /etc/my.cnf[mysqld]
skip-grant-tables #添加使登录mysql不使用授权表systemctl restart mysqldmysql #直接登录2使用 update 修改 root 密码刷新数据库
use mysql;update user set authentication_stringpassword(密码) where userroot;FLUSH PRIVILEGES;
quitmysql -u root -pabc123#注意最后再把 /etc/my.cnf 配置文件里的 skip-grant-tables 删除并重启 mysql 服务。六、数据库用户授权
6.1 授予权限
grant语句专门用来设置数据库用户的访问权限。 当指定的用户名不存在时grant语句将会创建新的用户 当指定的用户名存在时 grant 语句用于修改用户信息。
grant 权限列表 on 数据库名.表名 to 用户名来源地址 [indentified by 密码];#权限列表用于列出授权使用的各种数据库操作以逗号进行分隔如“select,insert,update”。使用“all”表示所有权限可授权执行任何操作。
#数据库名.表名用于指定授权操作的数据库和表的名称其中可以使用通配符“*”。例如使用“kgc.*”表示授权操作的对象为 kgc数据库中的所有表。
#用户名来源地址用于指定用户名称和允许访问的客户机地址即谁能连接、能从哪里连接。
#来源地址可以是域名、IP地址还可以使用“%”通配符表示某个区域或网段内的所有地址如“%.byyb.com”、“192.168.80.%”等。
#IDENTIFIED BY用于设置用户连接数据库时所使用的密码字符串。在新建用户时若省略“IDENTIFIED BY”部分则用户的密码将为空。#允许用户 zhangsan 在本地查询 byy 数据库中 所有表的数据记录但禁止查询其他数据库中的表的记录。
grant select ON byy.* TO zhangsanlocalhost IDENTIFIED BY 123456;#允许用户 lisi 在所有终端远程连接 mysql 并拥有所有权限。
GRANT ALL [PRIVILEGES] ON *.* TO lisi% IDENTIFIED BY 123456;flush privileges;
quitmysql -u zhangsan -p123456
use byy;
show tables;
select * from byy1;6.2 查看权限
show grants for 用户名来源地址;#举个例子
show grants for root;6.3 撤销权限
revoke 权限列表 on 数据库名.表名 from 用户名来源地址;#举个例子
#移除用户所有权限
revoke all on *.* from byy;show grants for lisi%;
#USAGE权限只能用于数据库登陆不能执行任何操作
#USAGE权限不能被回收即 REVOKE 不能删除用户。flush privileges;七、命令总结
use 库名;
show tables; show tables from 库名;
desc [库名.]表名;create database 库名;
use 库名;
create table [库名.]表名 (字段1 数据类型, 字段2 数据类型, ....[, primary key (字段)]);drop table [库名.]表名;
drop database 库名;修改表结构
改表名 alter table 旧表名 rename 新表名
增加字段 alter table 表名 add 新字段 数据类型 [字段属性];
修改字段 alter table 表名 change 旧字段 新字段 数据类型 [字段属性];
删除字段 alter table 表名 drop 字段;DML用于管理表数据
insert into 表名 (字段1, 字段2, ...) values (字段1的值, 字段2的值, ...);
insert into 表名 values (字段1的值, 字段2的值, ...); #要按照表结构的字段顺序设置值update 表名 set 字段1值, ... where 条件表达式;delete from 表名 where 条件表达式;DQL用于根据条件查询表数据
select * from 表名 [where 条件表达式];
select 字段1,字段2,... from 表名 [where 条件表达式];select * from 表名\G #纵向查看每行记录字段的值select * from 表名 limit N; #查看表的前N行记录
select * from 表名 limit N,M; #查看表的前N行之后的连续M行记录不包含第N行MySQL 的约束特性
primary key 主键约束 字段的值不能重复且不能为null一个自建的表只能有一个主键
unique key 唯一性约束 字段的值不能重复能为null一个表可以有多个唯一键
not null 非空约束 字段的值不能为null
default 默认值约束 字段的值如果没有设置则使用默认值自动填充
auto_increment 自增约束 字段的值如果没有设置默认会从1开始每次自动递增1要求自增字段必须设置主键
foreign key 外键约束 保证相关联的表数据的完整性和一致性int(N) zerofill 零填充克隆表
create table 新表 like 旧表; #克隆表结构
insert into 新表 (select * from 旧表); #克隆表数据 可实现表结构和表数据与旧表都一样create table 新表 (select * from 旧表); 表数据与旧表一样表结构与旧表可能不一样清空表
delete from 表名; 一条一条的删除记录效率较慢自增字段仍然会按照清空前的最大记录继续自增truncate table 表名; 直接重建表清空表效率更快自增字段会重新从1开始自增临时表
create temporary table 表名 (....); 临时表可以跟普通的表一样增删改查表中的数据但是show tables是查看不到的临时表只能在当前会话中有效在其它会话中或者退出当前会话连接临时都会失效外键约束
主键表 alter table 表名 add primary key (主键字段);
外键表 alter table 表名 add foreign key (外键字段) references 主键表名 (主键字段);插入新数据时需要先在主键表插入数据再在外键表插入对应数据删除数据时需要先在外键表删除数据再在主键表删除对应数据DCL用于管理用户与权限
用户管理
select user(); 查看当前登录的用户create user 用户名源地址 identified by 密码;localhost/IP/网段/主机名/%rename user 旧用户名源地址 to 新用户名源地址;drop user 用户名源地址;select user,host,authentication_string from mysql.user; set password password(密码);
set password for 用户名源地址 password(密码);
alter user 用户名源地址 identified by 密码;找回 root 密码
1修改mysql配置文件在 [mysqld] 下面添加 skip-grant-tables 配置项
2重启mysqld服务使用 mysql 密码直接登录 mysql
3执行 update user set authentication_stringpassword(密码) where userroot; 命令修改 root 用户的密码
4还原mysql配置文件重启mysqld服务使用 mysql -u 用户名 -p密码 [-h mysql地址 -P mysql端口] 命令来验证登录权限管理
grant 权限1,权限2,.... on 库名.表名 to 用户名源地址 [identified by 密码]; #5.7版本支持创建用户和权限授权8.0版本只能用于权限授权all *.*show grants for 用户名源地址;revoke 权限1,权限2,.... on 库名.表名 from 用户名源地址;all