MySQL数据库的认识及基础命令操作

目录

一、数据库的基本概念

1、数据库定义

(1) 数据

(2)表

(3) 数据库

 2、 数据库管理系统(DBMS)

3、 数据库系统(DBS)

 二、数据库系统发展史

1、 第一代数据库

2、第二代数据库

3、 第三代数据库

三、当今主流数据库介绍

1、 SQL Server (微软公司产品)

 2、 Oracle (甲骨文公司产品)

 3、 DB2 (IBM公司产品)

 4、 MySQL (甲骨文公司收购)

四、关系数据库

五、关系数据库应用

1、关系型数据库

2、 应用举例

六、非关系数据库介绍

七、MySQL数据库介绍

八、编译安装MySQL

 九、MySQL数据库管理

 1 、查看数据库结构

2、查看当前服务器中的数据库

3、 查看数据库中包含的表

4、 查看表的结构(字段)

十、SQL语句

SQL语言分类

 十一、创建及删除数据库和表

1、创建新的数据库(表名库名都区分大小写)

常用的数据类型

2、创建新的表

3、删除指定的数据表

4、删除指定的数据库

 十二、管理表中的数据记录

1、向数据表中插入新的数据记录

 2、查询数据记录

 3、修改、更新数据表中的数据记录

 4、在数据表中删除指定的数据记录

 十三、修改表名和表结构

1、修改表名

 2、扩展表结构(增加字段)

 3、修改字段(列)名,添加唯一键

 4、删除字段

十四、案例扩展 

 十五、数据表高级操作

1、克隆表,将数据表的数据记录生成到新的表中

方法一:

 方法二:

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

 方法一:

 方法二:

 3、创建临时表

4、 MySQL中6种常见的约束

5、创建外键约束,保证数据的完整性和一致性。

 十六、数据库用户管理

1、新建用户

 2、查看用户信息

 3、重命名用户

 4、删除用户

 5、修改当前登录用户密码

 6、修改其他用户密码

 7.忘记root密码的解决办法

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

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

 十七、数据库用户授权

1、授予权限

 2、查看权限

 3、撤销权限

总结


一、数据库的基本概念

1、数据库定义

(1) 数据

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

(2)表

将不同的记录组织在一起
用来存储具体的数据

(3) 数据库

表的集合、时存储数据的仓库
以一定的组织方式存储的相互有关的数据集合

 2、 数据库管理系统(DBMS)

是实现对数据库资源有效组织、管理和存取的系统软件
数据库的建立和维护功能、数据库定义功能、数据操纵功能能、数据库的运行管理功能、通信功能

  • Database:数据库是数据的汇集,它以一定的组织形式存于存储介质上

  • DBMS:是管理数据库的系统软件,它实现数据库系统的各种功能。是**数据库系统的核心**

  • DBA:负责数据库的规划、设计、协调、维护和管理等工作。

  • 应用程序:指以数据库为基础的应用程序。

    DBMS的工作模式:
    1.接收应用程序的数据请求和处理请求
    2.将用户的数据请求(高级指令)转换为复杂机器代码(底层指令)
    3.实现对数据库的操作
    4.从数据库的操作中接受查询结果
    5.对查询结果进行处理(格式转换)
    6.将处理结果返回给用户
    

3、 数据库系统(DBS)

是一个人机系统,有硬件、OS、数据库、DBMS、应用软件和数据库用户组成
用户可以通过DBMS或应用程序操作数据库

 二、数据库系统发展史

1、 第一代数据库

自20世纪60年代起,第一-代数据库系统问世
是层次模型与网状模型的数据库系统
为统一管理和共享数据提供了有力的支撑

2、第二代数据库

20世纪70年代初,第二代数据库——关系数据库开始出现
20世纪80年代初,IBM公司的关系数据库系统DB2问世,开始逐步取代层次与网状模型的数据库,成为行业主流
到目前为止,关系数据库系统仍占领数据库应用的主要地位

3、 第三代数据库

自20世纪80年代开始,适应不同领域的新型数据库系统不断涌现
面向对象的数据库系统,实用性强、适应面广
20世纪90年代后期,形成了多种数据库系统共同支撑应用的局面
一些新的元素被添加进主流数据库系统中
例如,Oracle支持的"关系-对象”数据库模型

三、当今主流数据库介绍

1、 SQL Server (微软公司产品)

面向Windows操作系统
简单、易用

 2、 Oracle (甲骨文公司产品)

面向所有主流平台
安全、完善,操作复杂

 3、 DB2 (IBM公司产品)

面向所有主流平台
大型、安全、完善

 4、 MySQL (甲骨文公司收购)

免费、开源、体积小

四、关系数据库

关系数据库系统是基于关系模型的数据库系统
关系模型的数据结构使用简单易懂的二维数据表
关系模型可用简单的“实体-关系”(E-R)图来表示
E-R图中包含了实体(数据对象)、关系和属性三个要素

■实体
也称为实例,对应现实世界中可区别于其他对象的“事件”或“事物”
如银行客户、银行账户等
■属性
实体所具有的某一特性, 一个实体可以有多个属性
如“银行客户”实体集中的每个实体均具有姓名、住址、电话等属性
■联系
实体集之间的对应关系称为联系,也称为关系
如银行客户和银行账户之间存在“储蓄”的关系
■所有实体及实体之间联系的集合构成一个关系数据库

■关系数据库的存储结构是二维表格
■在每个二维表中
每一行称为一条记录,用来描述一个对象的信息
每一列称为一个字段(栏位),用来描述对象的一个属性

五、关系数据库应用

1、关系型数据库

Oracle,MySQL
SQL Server. Sybase
Informix、access
DB2、FoxPRO

2、 应用举例

12306用户信息系统
淘宝账号系统
联通手机号信息系统
银行用户账号系统
网站用户信息系统

六、非关系数据库介绍

■非关系数据库也被称作NoSQL (Not Only SQL)
■存储数据不以关系模型为依据,不需要固定的表格式
■非关系型数据库的优点
数据库可高并发读写
对海量数据高效率存储与访问
数据库具有高扩展性与高可用性
■常用的非关系数据库:Redis、mongoDB等

七、MySQL数据库介绍

■一款深受欢迎的开源关系型数据库
■Oracle旗下的产品
■遵守GPL协议,可以免费使用与修改
■特点
性能卓越、服务稳定
开源、无版权限制、成本低
多线程、多用户
基于C/S (客户端/服务器)架构
安全可靠
 

八、编译安装MySQL

一键安装mysql
#!/bin/bash #编译安装Mysql服务 #使用脚本前注意事项: #1、请设置好yum源仓库 #2、请在/opt目录下放入mysql-boost-5.7.20.tar.gz安装包
#编写安装mysql的函数 MySQL() {
#关闭系统防火墙和安全机制 systemctl stop firewalld systemctl disable firewalld setenforce 0
#安装环境依赖包 yum -y install gcc gcc-c++ ncurses ncurses-devel bison cmake
#创建运行用户 useradd -M -s /sbin/nologin mysql
#编译安装 cd /opt tar xzvf mysql-boost-5.7.20.tar.gz
cd /opt/mysql-5.7.20/ cmake \ -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \ -DSYSCONFDIR=/etc \ -DSYSTEMD_PID_DIR=/usr/local/mysql \ -DDEFAULT_CHARSET=utf8 \ -DDEFAULT_COLLATION=utf8_general_ci \ -DWITH_EXTRA_CHARSETS=all \ -DWITH_INNOBASE_STORAGE_ENGINE=1 \ -DWITH_ARCHIVE_STORAGE_ENGINE=1 \ -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \ -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \ -DMYSQL_DATADIR=/usr/local/mysql/data \ -DWITH_BOOST=boost \ -DWITH_SYSTEMD=1
#编译及安装 make && make install
#修改mysql 配置文件 echo '[client] port = 3306 socket=/usr/local/mysql/mysql.sock
[mysqld] user = mysql basedir=/usr/local/mysql datadir=/usr/local/mysql/data port = 3306 character-set-server=utf8 pid-file = /usr/local/mysql/mysqld.pid socket=/usr/local/mysql/mysql.sock bind-address = 0.0.0.0 skip-name-resolve max_connections=2048 default-storage-engine=INNODB max_allowed_packet=16M server-id = 1
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES' > /etc/my.cnf
#更改mysql安装目录和配置文件的属主属组 chown -R mysql:mysql /usr/local/mysql/ chown mysql:mysql /etc/my.cnf
#设置路径环境变量 echo "export PATH=$PATH:/usr/local/mysql/bin:/usr/local/mysql/lib">> /etc/profile source /etc/profile
#初始化数据库 cd /usr/local/mysql/bin/ ./mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
#添加mysqld系统服务 cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/ 
systemctl daemon-reload systemctl start mysqld.service systemctl enable mysqld }
#主体代码 ls /opt | egrep "^mysql-boost-5.7.20.tar.gz$" if [ $? -eq 0 ];then #调用函数安装mysql MySQL echo "数据库安装完毕,请设定root用户密码。" echo "例如:输入“mysqladmin -u root -p password "123456" ” + 回车;回车" ln -s /usr/local/mysql/bin/* /usr/local/bin else echo -e "请将安装包mysql-boost-5.7.20.tar.gz放入/opt目录下" #如果没有就终止 break fi
 rpm -qa | grep mariadb
 yum -y install gcc gcc-c++ ncurses-devel openssl openssl-devel
 tar zxf cmake-3.16.2.tar.gz
 cd cmake-3.16.2
 ./configure
 gmake && gmake install
 tar zxf boost_1_59_0.tar.gz
 mv boost_1_59_0/ /usr/local/boost

具体安装步骤查看以往博客

 

 

 九、MySQL数据库管理

数据库-->数据表-->行(记录):用来描述一个对象的信息
                列(字段):用来描述对象的一一个属性

 1 、查看数据库结构

systemctl status mysqld.service		#查看mysql服务是否安装启动

mysql -u root -p       #进入MySQL

2、查看当前服务器中的数据库

SHOW DATABASES;    #大小写不区分,分号“;"表示结束

3、 查看数据库中包含的表

USE 数据库名;
SHOW TABLES;

4、 查看表的结构(字段)

USE 数据库名;
DESCRIBE [数据库名.]表名;
可缩写成:DESC 表名;

十、SQL语句

SQL语句用于维护管理数据库,包括数据查询、数据更新、访问控制、对象管理等功能。

SQL语言分类

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

 十一、创建及删除数据库和表

1、创建新的数据库(表名库名都区分大小写)

CREATE DATABASE 数据库名;

常用的数据类型

int:整型
float:单精度浮点4字节32位
double:双精度浮点8字节64位
char:固定长度的字符类型
varchar:可变长度的字符类型
text:文本
image:图片
decimal(5,2):5个有效长度数字,小数点后面有2位


#Char如果存入数据的实际长度比指定长度要小,会补空格至指定长度,如果存入的数据的实际长度大于指定长度,低版本会被截取,高版本会报错

 

2、创建新的表

CREATE TABLE 表名(字段1 数据类型,字段2 数据类型[,...][, PRIMARY KEY (主键名)]);
#主键一般选择能代表唯一性的字段不允许取空值(NULL) ,一个表只能有一个主键。

例:

CREATE DATABASE xyw;
USE xyw;
CREATE TABLE zzz (id int NOT NULL,name char(10) NOT NULL,score decimal(5,2),passwd char(48) DEFAULT'', PRIMARY KEY (id));
DESC zzz;

#NOT NULL   不允许为空值
#DEFAULT''  默认值为空

3、删除指定的数据表

use 数据库名
DROP TABLE 表名

DROP TABLE [数据库名.] 表名;
#如不用USE进入库中,则需加上数据库名

 

4、删除指定的数据库

DROP DATABASE 数据库名;

 十二、管理表中的数据记录

1、向数据表中插入新的数据记录

INSERT INTO 表名(字段1,字段2[,...]) VALUES (字段1的值,字段2的值,...);

例:

INSERT INTO zzz (id,name,score,passwd) values(1,'zhangsan',70.5,PASSWORD('123456'));
#PASSWORD('123456'):查询数据记录时,密码字串以加密形式显示:若不使用PASSWORD(),查询时以明文显示。标题  处解释

INSERT INTO zzz VALUES(2,'lisi',90.5,654321) ;
SELECT * FROM zzz ;      #查询表的数据记录

 

 2、查询数据记录

SELECT 字段名1,字段名2[,...] FROM 表名[WHERE 条件表达式];

例:

SELECT * FROM zzz;
SELECT id,name,score FROM zzz WHERE id=2;
select name from zzz\G  		 #以列表方式竖向显示
select * from xyw limit 2;   	 #只显示头2行
select * from xyw limit 2,3;     #显示第2行后的前3行

 

 3、修改、更新数据表中的数据记录

UPDATE 表名 SET 字段名1=字段值1[,字段名2=字段值2] [WHERE 条件表达式];

 例:

UPDATE zzz SET passwd=PASSWORD('') WHERE name='zhangsan';
UPDATE zzz SET name='wangxiaoer',passwd='' WHERE id=3;

 

 4、在数据表中删除指定的数据记录

DELETE FROM 表名 [WHERE 条件表达式];

 例:

DELETE FROM zzz WHERE id=4;

 十三、修改表名和表结构

1、修改表名

ALTER TABLE 旧表名 RENAME 新表名;

例:

ALTER TABLE zzz RENAME yyy;
ALTER TABLE yyy RENAME zzz;

 2、扩展表结构(增加字段)

ALTER TABLE 表名 ADD address varchar(50) default '地址不详';
#default '地址不详':表示此字段设置默认值为地址不详,可与NOT NULL配合使用

例:

ALTER TABLE yyy ADD address varchar(50) NOT NULL default '地址不详';

 3、修改字段(列)名,添加唯一键

ALTER TABLE 表名 CHANGE 旧列名 新列名 数据类型 [unique key];

例:

ALTER TABLE yyy CHANGE name user_name varchar(10) unique key;
#CHANGE可修改字段名、数据类型、约束等所有项。

 

 4、删除字段

ALTER TABLE 表名 DROP 字段名;

 例:

ALTER TABLE yyy DROP passwd;

十四、案例扩展 

use xyw;
create table if not exists info (
id int(4) zerofill primary key auto_increment,     #指定主键的第二种方式
name varchar(10) not null,
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:表示此字段不允许为NULL

 十五、数据表高级操作

1、克隆表,将数据表的数据记录生成到新的表中

方法一:

create table yyy2 like yyy;    #复制格式,通过LIKE方法,复制KY08表结构生成test01表
insert into yyy2 select * from yyy;      #备份内容

 方法二:

CREATE TABLE test02 (SELECT * from xyw);

show create table test02\G    #获取数据表的表结构、索引等信息
SELECT * from test02;

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

 方法一:

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

 方法二:

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

 3、创建临时表

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

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

例:

create temporary table xxx (
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 xxx values (1,'zhangsan',123456,'running') ;
select * from test03;
show tables;
quit
select * from test03;

 

4、 MySQL中6种常见的约束

主键约束(primary key)                字段的值不能重复,不能为null,一个表只能有一个主键
外键约束(foreign key)                保证相关联表数据的完整性和一致性
非空约束(not null)                   字段的值不能为null
唯一性约束(unique [key|index])       字段的值不能重读,能为null,一个表可有多个唯一键
默认值约束(default)                  字段的值如果没有设置则使用默认值自动填充
自增约束(auto_increment)             字段的值如果没有设置,默认会从1开始递增1,要求自增字段必须为主键字段

5、创建外键约束,保证数据的完整性和一致性。

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

主键表和外键表的理解
(1)以公共关键字作主键的表为主键表(父表、主表)
(2)以公共关键字作外键的表为外键表(从表、外表)
注意:与外键关联的主表的字段必须设置为主键。要求从表不能是临时表,主表外键字段和从表的字段具备相同的数据类型、字符长度和约束。

#创建主表test04
create table test04 (hobid int(4),hobname varchar(50));

#创建从表test05
create table test05 (id int(4) primary key auto_increment,name varchar(10),age int(3),hobid int(4)) ;

#为主表test04添加一个主键约束。主键名建议以"PK_”开头。
alter table test04 add constraint PK_hobid primary key (hobid);

#为从表test05表添加外键,并将test05表的hobid字段和test04表的hobid字段建立外键关联。外键名建议以"FK_”开头。
alter table test05 add constraint FK_hob foreign key (hobid) references test04 (hobid);

desc test04;
desc test05;

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

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

#查看和删除外键约束
#如果要删除外键约束字段先删除外键约束,再删除外键名
show create table test05;
alter table test05 drop foreign key FK_hob;
alter table test05 drop key FK_hob;
desc test05;

 

 十六、数据库用户管理

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('abc123T);

 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服务。

 十七、数据库用户授权

1、授予权限

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

GRANT 权限列表 ON 数据库名.表名 TO '用户名'@'来源地址' [IDENTIFIED BY '密码'];
#权限列表:用于列出授权使用的各种数据库操作,以逗号进行分隔,如“select, insert, update”。使用"all"表示所有权限,可授权执行任何操作。
#数据库名.表名:用于指定授权操作的数据库和表的名称,其中可以使用通配符"*"。例如,使用“kgc.*"表示授权操作的对象为xyw数据库中的所有表。
#'用户名@来源地址':用于指定用户名称和允许访问的客户机地址,即谁能连接、能从哪里连接。来源地址可以是域名、IP地址,还可以使用“%”通配符,表示某个区域或网段内的所有地址,如“%.xyw.com"、“192. 168.80.%”等。
#IDENTIFIED BY:用于设置用户连接数据库时所使用的密码字符串。在新建用户时,若省略“IDENTIFIED BY"部分,则用户的密码将为空。
权限   权限说明   权限级别
CREATE    创建数据库、表或索引的权限    数据库、表或索引
DROP   删除数据库或表的权限    数据库或表
权限   权限说明   权限级别
CREATE    创建数据库、表或索引的权限    数据库、表或索引
DROP   删除数据库或表的权限    数据库或表
DELETE     删除表数据的权限  数据表
INDEX     操作索引的权限   数据表
INSERT    添加表数据的权限   数据表
SELECT   查询表数据的权限   数据表
UPDATE   更新表数据的权限   数据表
CREATE VIEW      创建视图的权限 视图
SHOW VIEW      查看视图的权限 视图
ALTER ROUTINE    更改存储过程的权限   存储过程
CREATE ROUTINE   创建存储过程的权限    存储过程
EXECUTE    执行存储过程权限   存储过程
FILE     服务器主机文件的访问权限  文件管理
CREATE TEMPORARY TABLES      创建临时表的权限 服务器管理
EXECUTE    执行存储过程权限   存储过程
FILE     服务器主机文件的访问权限  文件管理
CREATE TEMPORARY TABLES      创建临时表的权限 服务器管理
EXECUTE    执行存储过程权限   存储过程
FILE     服务器主机文件的访问权限  文件管理
CREATE TEMPORARY TABLES      创建临时表的权限 服务器管理
EXECUTE    执行存储过程权限   存储过程
FILE     服务器主机文件的访问权限  文件管理
CREATE TEMPORARY TABLES      创建临时表的权限 服务器管理
LL [PRIVILEGES]    所有权限
USAGE       没有任何权限    
#允许用户zhangsan在本地查询xyw数据库中所有表的数据记录,但禁止查询其他数据库中的表的记录。
GRANT select ON xyw.* TO 'zhangsan'@'localhost' IDENTIFIED BY 'abc123';

 #允许用户lisi在所有终端远程连接mysql,并拥有所有权限。

GRANT ALL [PRIVILEGES] ON *.* TO 'lisi'@'%' IDENTIFIED BY '123456';

flush privileges;    #刷新权限
quit

mysql -u zhangsan -pabc123
use xyw;
show tables; .
select * from yyy;

 

 

 2、查看权限

mysql -u root -pabc123
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;   #立即生效

总结

QL语句    DDL  DML  DQL  DCL
DDL 用于管理数据库对象: 库 表 索引
 创建数据库:create database 库名;
进入数据库:use 库名;
创建表: create table 表名 (字段1 数据类型, 字段2 数据类型, ... [,primary key (字段)]);

删除表、库: drop table 表名;            drop database 库名;

查看数据库: show databases;
查看表:show tables [from 库名];         desc [库名.]表名;

DML 用于管理表数据
给表中添加数据:

insert into 表名 values (字段1的值, 字段2的值, ....);    #要按照表结构的字段顺序设置值
insert into 表名 (字段1, 字段2, ...) values (字段1的值, 字段2的值, ...);

修改表中数据:update 表名 set 字段=值, ... 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行)

修改表结构
改表名   alter table 旧表名 rename 新表名;
增加字段   alter table 表名 add 新字段 数据类型 [字段属性];
修改字段   alter table 表名 change 旧字段 新字段 数据类型 [字段属性];
删除字段   alter table 表名 drop 字段;


Mysql 常用的6大约束
primary key     主键约束   字段的值不能重复,不能为null,一个表只能有一个主键
unique key      唯一性约束 字段的值不能重读,能为null,一个表可有多个唯一键
not null        非空约束   字段的值不能为null
default         默认值约束 字段的值如果没有设置则使用默认值自动填充
auto_increment  自增约束   字段的值如果没有设置,默认会从1开始递增1,要求自增字段必须为主键字段
foreign key     外键约束   保证相关联表数据的完整性和一致性

int(N) zerofill  若数值不满N位数,则前面用"0"填充


克隆表

方法一:
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 用于管理用户与权限
用户管理
创建用户:create user '用户名'@'源地址'     identified by '密码';
                                      localhost %表示任意用户
更改用户名:rename user '旧用户名'@'源地址'  to  '新用户名'@'源地址';

删除用户:drop user '用户名'@'源地址';

查询用户信息:

select user();

select user,host,authentication_string from mysql.user;

修改用户密码:set password [for '用户名'@'源地址'] = password('密码');

找回root密码?
1)修改mysql配置文件/etc/my.cnf,在 [mysqld] 下面添加 skip-grant-tables
2)重启mysqld服务。使用 mysql 命令直接登录mysql
3)执行 update mysql.user set authentication_string=password('密码') where user='root' and host='localhost';
4)还原配置文件,重启mysqld服务,使用 mysql -u 用户 -p[密码] -h 地址 -P 端口  来验证登录

权限管理
grant 权限1,权限2,....  on  库名.表名  to  '用户名'@'源地址'  [identified by '密码'];
         all [privileges]          *.*表示所有库表

查看用户权限:show grants for '用户名'@'源地址';

去除用户权限:revoke 权限1,权限2,....  on  库名.表名  from  '用户名'@'源地址';
                                      all [privileges]     all表示所有权限

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/28657.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

编程必备:JAVA多线程详解

目录 前言 1.入门多线程 1.1. 线程、进程、多线程、线程池 1.2.并发、串行、并行 1.3. 线程的实现方式 1.3.1. 继承 Thread 类 1.3.2. 实现 Runnable 接口 1.3.3. 使用 Callable 和 Future 1.3.4. 使用线程池 1.4.线程的状态 1.5. 线程常用方法 1.5.1 sleep() 1.4…

docker 网络理论知识点 - CNM 和命名空间

Network 目录 1 network namespace1.1 动手小实验 2 回到 docker2.1 driver and docker02.2 network2.3 网桥 docker0 3 总结 1 network namespace 1.1 动手小实验 网络命名空间。linux kernel 提供的网络虚拟化的功能。创建多个隔离的网络空间。每个空间内 firewall, ether …

【taro react】---- 解决H5接入uni-app版本的IM

1. 问题 由于项目开发比较紧张,腾讯 IM 的接入就使用了 TUIKit 含UI集成方案,遇到的问题,uni-app的UI本来就是一个单独的项目,需要集成到现有的 Taro React 中,就只能作为一个独立的项目,不跳转时不影响原有…

在十四届蓝桥杯开赛前一星期开始复习

文章目录 十三届蓝桥杯国赛原题1.20222.钟表3卡牌4最大数字4.5 Dijkstra算法5出差 十三届蓝桥杯国赛原题 1.2022 #include<iostream> using namespace std;long long int f[2023][11][2023]; //表示前2022个物品选择10个物品&#xff0c;体积总和为2022的方案个数 ,,数…

入门编程其实也简单

随着信息技术的快速发展&#xff0c;编程已经成为一个越来越重要的技能。那么&#xff0c;我们该如何入门编程呢&#xff1f; 编程是指使用计算机语言编写计算机程序的过程。计算机程序是一系列指令的集合&#xff0c;这些指令告诉计算机要执行的操作。编程的目的是创建计算机…

Unity编辑器扩展-第二集-按钮排序/分组/放入右键菜单

第一集链接&#xff1a;Unity编辑器扩展-第一集-在菜单栏加入自己的按钮_菌菌巧乐兹的博客-CSDN博客 一、本节目标效果展示 1.按钮排序 变成 2.按钮分组 仔细看&#xff0c;有个灰色的杠杠 3.放入右键菜单 4.皮一下 二、按钮排序具体流程 第一集讲&#xff0c;如果想放入…

阿里云PAIx达摩院GraphScope开源基于PyTorch的GPU加速分布式GNN框架

作者&#xff1a;艾宝乐 导读 近期阿里云机器学习平台 PAI 团队和达摩院 GraphScope 团队联合推出了面向 PyTorch 的 GPU 加速分布式 GNN 框架 GraphLearn-for-PyTorch(GLT) 。GLT 利用 GPU 的强大并行计算性能来加速图采样&#xff0c;并利用 UVA 来减少顶点和边特征的转换和…

4.4.2 译码器

1. 学习基础知识&#xff1a;首先&#xff0c;我会了解译码器的基本概念、原理和应用。通过阅读教科书、参考资料或在线资源&#xff0c;我会学习译码器的工作原理、不同类型的译码器以及它们在电子系统中的应用场景。 2. 研究示例和练习题&#xff1a;为了更好地理解译码器的…

【Spring】透过Spring源码查看Bean的命名转换规则

近期在写Spring项目的时候&#xff0c;需要通过注解的形式去替代之前直接将Bean存放在Spring容器这种方式&#xff0c;以此来简化对于Bean对象的操作&#xff0c;但是这样无法通过准确的Id去获取到相应的Bean对象了 测试观察 首先&#xff0c;如果要将指定的对象存放到Spring中…

Unity入门6——光源组件

一、参数面板 二、参数介绍 Type&#xff1a;光源类型 Spot&#xff1a;聚光灯 Range&#xff1a;发光距离Spot Angle&#xff1a;光锥角度Directional&#xff1a;方向光Point&#xff1a;点光源Area&#xff08;Baked Only&#xff09;&#xff1a;面光源 仅烘焙。预先算好&…

操作教程:如何正确配置让EasyNVR级联至EasyNVS平台?

EasyNVS是EasyNVR的云管理平台&#xff0c;可实现内网监控上云&#xff0c;视频汇聚等功能。近期经常有用户咨询EasyNVR如何级联至EasyNVS平台进行云端统计和管理&#xff0c;在今天的文章中&#xff0c;我们来详细介绍一下。 1、配置EasyNVS 1&#xff09;运行EasyNVS之前&a…

回归预测 | MATLAB实现基于GRU-AdaBoost门控循环单元结合AdaBoost多输入单输出回归预测

回归预测 | MATLAB实现基于GRU-AdaBoost门控循环单元结合AdaBoost多输入单输出回归预测 目录 回归预测 | MATLAB实现基于GRU-AdaBoost门控循环单元结合AdaBoost多输入单输出回归预测预测效果基本介绍模型描述程序设计参考资料 预测效果 基本介绍 1.MATLAB实现基于GRU-AdaBoost门…

C++【STL】之vector的使用

文章目录&#xff1a; vector介绍vector使用1. 默认成员函数1.1 默认构造1.2 拷贝构造1.3 析构函数1.4 赋值重载 2. 迭代器2.1 正向迭代器2.2 反向迭代器 3. 容量操作3.1 获取空间数据3.2 空间扩容3.3 大小调整3.4 空间缩容 4. 数据访问4.1 下标随机访问4.2 获取首尾元素 5. 数…

基于Java新生报到系统设计与实现(源码+lw+部署文档+讲解等)

博主介绍&#xff1a; ✌全网粉丝30W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战 ✌ &#x1f345; 文末获取源码联系 &#x1f345; &#x1f447;&#x1f3fb; 精…

Spring源码解密--事务篇

文章目录 一、事务的实现方式1、JDBC2、Spring基于xml配置编程式事务声明式事务 二、源码设计1、TransactionManager1&#xff09;TransactionManager2&#xff09;PlatformTransactionManager3&#xff09;ReactiveTransactionManager 2、TransactionDefinition3、Transaction…

Qt编写onvif工具(搜索/云台/预置位/OSD/录像存储)

一、前言 从最初编写这个工具开始的时间算起来&#xff0c;至少5年多&#xff0c;一直持续完善到今天&#xff0c;这个工具看起来小也不小大也不大&#xff0c;但是也是经历过无数个现场的洗礼&#xff0c;毫不夸张的说&#xff0c;市面上能够遇到的主流的厂商的设备&#xff…

攻防世界-Crypto-easychallenge

题目描述&#xff1a;将文件下载下来&#xff0c;只有一个pyc文件 1. 思路分析 先向chatgpt问下什么是pyc文件&#xff1a; OK&#xff0c;这里简单总结下&#xff1a; 1. pyc文件是python源码编译后的生成的二进制文件 2. 通过一些库可以逆向出pyc的源代码 那么我们需要做…

科一容易忘、容易混的点(二)

注意落石 高速应急车道用途&#xff1a;主要用于发生事故或故障时停车&#xff0c;以及专为救险所用的车道&#xff0c;被誉为高速公路的“生命通道” 注意 注意 扣9份场景&#xff1a; 城市快速路上 违法停车&#xff1b; 注意 交通事故逃逸&#xff0c; 不一定吊销驾驶证&a…

简单的一批的DockerFile构建(内附超详细docker学习笔记)

目录 介绍 DockerFile常用保留字指令 演示自定义构建java8版本centos docker专用学习笔记 超全 介绍 总结: 从应用软件的角度来看&#xff0c;Dockerfile、Docker镜像与Docker容器分别代表软件的三个不同阶段&#xff0c; * Dockerfile是软件的原材料 * Docker镜像是软件…

华为组播实验pim-dm

组播源配置&#xff1a; R1: [r1]dis current-configuration [V200R003C00] sysname r1 snmp-agent local-engineid 800007DB03000000000000 snmp-agent clock timezone China-Standard-Time minus 08:00:00 portal local-server load flash:/portalpage.zip drop illegal-mac…