数据库:存储数据的仓库

数据库管理系统软件

常见的数据库管理软件:甲骨文的oracle,IBM的db2,sql server, Access,Mysql(开源,免费,跨平台). 

关系型数据库:存在磁盘上

非关系型数据库:存在内存上

数据库系统

数据库系统DBS(Data Base System,简称DBS)通常由软件、数据库和数据管理员组成。其软件主要包括操作系统、各种宿主语言、实用程序以及数据库管理系统。数据库由数据库管理系统统一管理,数据的插入、修改和检索均要通过数据库管理系统进行。数据管理员负责创建、监控和维护整个数据库,使数据能被任何有权使用的人有效使用。

                        第二篇 数据库MySql

 

mysql

一.安装

linux版本:

1. 安装
yum install mysql-server

2. 服务端启动

mysql.server start

3. 客户端连接

连接:
    mysql -h host -u user -p
 
    常见错误:
        ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2), it means that the MySQL server daemon (Unix) or service (Windows) is not running.
退出:
    QUIT 或者 Control+D

win版本:

1. 下载zip包

http://dev.mysql.com/downloads/mysql/ 
2. 解压
直接解压到某个目录下,如:E:\mysql-8.0.12-winx64

3、初始化

MySQL解压后的 bin 目录下有一大堆的可执行文件,初始化针对的是服务端mysqld

执行如下命令初始化数据:

C:\Users\mamingchen>E:

E:\>cd E:\mysql-8.0.12-winx64\bin

E:\mysql-8.0.12-winx64\bin>mysqld --initialize-insecure

E:\mysql-8.0.12-winx64\bin>

初始化完成后:
1. 目录下面生成一个data文件夹
2. 创建用户名:root ,密码为空

第二篇 数据库MySql

4、启动MySQL服务

# 进入可执行文件目录
cd E:\mysql-8.0.12-winx64\bin
 
# 执行下面的命令启动MySQL服务
mysqld

就启动了服务,等待客户端去连接

5、启动MySQL客户端并连接MySQL服务

由于初始化时使用的【mysqld --initialize-insecure】命令,其默认未给root账户设置密码

# 所以,另行开个cmd,进入可执行文件目录

cd E:\mysql
-5.7.16-winx64\bin # 连接MySQL服务器 mysql -u root -p # 提示请输入密码,直接回车,因为初始化的时候还没有设置密码
如下:
第二篇 数据库MySql

到此为止,MySQL服务端已经安装成功并且客户端已经可以连接上,以后再操作MySQL时,只需要重复上述4、5步骤即可。但是,在4、5步骤中重复的进入可执行文件目录比较繁琐,如想日后操作简便,可以做如下操作。

a. 添加环境变量

将MySQL可执行文件添加到环境变量中,从而执行执行命令即可
【右键计算机】--》【属性】--》【高级系统设置】--》【高级】--》【环境变量】--》【在第二个内容框中找到 变量名为Path 的一行,双击】 --> 【将MySQL的bin目录路径追加到变值值中,用 ; 分割】

如:
C:\Python\Python36-32\Scripts;C:\Python\Python36-32\;"C:\Users\mamingchen\AppData\Local\Microsoft\WindowsApps;C:\Program Files (x86)\Java\jre1.8.0_151\bin;C:\Program Files (x86)\Java\jre1.8.0_151\jre\bin";E:\Users\mamingchen\AppData\Local\Programs\Fiddler;"%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin";C:\Users\mamingchen\AppData\Roaming\npm;C:\Python\Python36-32\python.exe;E:\MongoDB\Server\4.0\bin;E:\mysql-8.0.12-winx64\bin;
如此一来,以后再启动服务并连接时,仅需:
# 启动MySQL服务,在终端输入
C:\Users\mamingchen>mysqld
 
# 连接MySQL服务,在终端输入:
C:\Users\mamingchen>mysql -u root -p
b. 将MySQL服务制作成windows服务

上一步解决了一些问题,但不够彻底,因为在执行【mysqd】启动MySQL服务器时,当前终端会被hang住,那么做一下设置即可解决此问题:
记住:以管理员身份运行cmd
# 制作MySQL的Windows服务,在终端执行此命令:
C:\Users\mamingchen>"E:\mysql-8.0.12-winx64\bin\mysqld" --install
第二篇 数据库MySql

# 移除MySQL的Windows服务,在终端执行此命令:
C:\Users\mamingchen>"E:\mysql-8.0.12-winx64\bin\mysqld" --remove

注册成服务之后,以后再启动和关闭MySQL服务时,仅需执行如下命令:

# 启动MySQL服务
net start mysql
第二篇 数据库MySql
# 关闭MySQL服务
net stop mysql

记住:
如果是zip包,可以自己制作Windows服务;
如果是可执行文件直接点击安装的, 系统会自己给你安装Windows服务的

这里插入一个如何删除Windows服务

1. 运行
services.msc

2. 找到要删除的服务 -- 属性-- 服务名称 

3. 复制服务名称

4. 以管理员身份启动cmd

5. 执行下面的命令
sc delete 服务名称

[SC] DeleteService 成功

 二.创建用户

1. mysql

2. mysql -uroot -p

3. show databases; -- 看有哪些表

4. use mysql;  -- 进入mysql表

5. use user;

6.  -- 创建用户和密码
1create user 'mmc'@'ip地址' identified by 'mmc123'; 

--解析:
1) 'mmc':表示登陆数据库的用户名
2) @'ip地址'
    ip地址有一下规则:
-- 表示这个用户只能在ip为192.168.1.1的机器上用
a.create user 'mmc'@'192.168.1.1' identified by 'mmc123'; 

-- 表示只要ip前缀为192.168.1.的都可以使用
b.create user 'mmc'@'192.168.1.%' identified by 'mmc123'; 

-- 表示只要ip前缀为 192.168的都可以使用
c.create user 'mmc'@'192.168.%.%' identified by 'mmc123'; 

-- 表示所有IP都可以使用
d.create user 'mmc'@'%' identified by 'mmc123'; 

三. 授权

1. 授予什么权限给谁
-- 将db1库下面的t1表的 查询,插入,更新的权限授予 mmc
-- 下面的意思就是mmc用户在所有机器上都能对db1库下面的t1表进行查询,插入和更新操作
grant select,insert,update on db1.t1 to 'mmc'@'%';

-- 给mmc所有权限,除了grant之外
grant all privileges on db1.t1 to 'mmc'@'%';

-- 表示mmc只能看db1库下面的所有表
grant all privileges on db1.*  to 'mmc'@'%';

四.用户管理

创建用户
    create user '用户名'@'IP地址' identified by '密码';
删除用户
    drop user '用户名'@'IP地址';
修改用户
    rename user '用户名'@'IP地址'; to '新用户名'@'IP地址';;
修改密码
    set password for '用户名'@'IP地址' = Password('新密码')
  
PS:用户权限相关数据保存在mysql数据库的user表中,所以也可以直接对其进行操作(不建议)

五.授权管理

show grants for '用户'@'IP地址'                  -- 查看权限
grant  权限 on 数据库.表 to   '用户'@'IP地址'      -- 授权
revoke 权限 on 数据库.表 from '用户'@'IP地址'      -- 取消权限
all privileges          除grant外的所有权限
select                  仅查权限
select,insert           查和插入权限
...
usage                   无访问权限
alter                   使用alter table
alter routine           使用alter procedure和drop procedure
create                  使用create table
create routine          使用create procedure
create temporary tables 使用create temporary tables
create user             使用create userdrop user、rename user和revoke  all privileges
create view             使用create view
delete                  使用delete
drop                    使用drop table
execute                 使用call和存储过程
file                    使用select into outfile 和 load data infile
grant option            使用grant 和 revoke
index                   使用index
insert                  使用insert
lock tables             使用lock table
process                 使用show full processlist
select                  使用select
show databases          使用show databases
show view               使用show view
update                  使用update
reload                  使用flush
shutdown                使用mysqladmin shutdown(关闭MySQL)
super                   ??使用change master、kill、logs、purge、master和set global。还允许mysqladmin????调试登陆
replication client      服务器位置的访问
replication slave       由复制从属使用
对于目标数据库以及内部其他:
            数据库名.*              数据库中的所有
            数据库名.表             指定数据库中的某张表
            数据库名.存储过程     指定数据库中的存储过程
            *.*                        所有数据库
用户名@IP地址         用户只能在改IP下才能访问
用户名@192.168.1.%   用户只能在改IP段下才能访问(通配符%表示任意)
用户名@%             用户可以再任意IP下访问(默认IP地址为%)
grant all privileges on db1.tb1 TO '用户名'@'IP'

grant select on db1.* TO '用户名'@'IP'

grant select,insert on *.* TO '用户名'@'IP'

revoke select on db1.tb1 from '用户名'@'IP'
示例

特殊的:

flush privileges,将数据读取到内存中,从而立即生效。
# 启动免授权服务端
mysqld --skip-grant-tables

# 客户端
mysql -u root -p

# 修改用户名密码
update mysql.user set authentication_string=password('666') where user='root';
flush privileges;

忘记密码
忘记密码

 

启动

service mysqld start  #开启
chkconfig mysqld on   #设置开机自启

OR

systemctl start mariadb
systemctl enable mariadb

查看

-- ps aux |grep mysqld    #查看进程
-- netstat -an |grep 3306 #查看端口

设置密码

-- mysqladmin -uroot password '123'   #设置初始密码,初始密码为空因此-p选项没有用
-- mysqladmin -u root -p123 password '1234' #修改root用户密码

登录

-- mysql               #本地登录,默认用户root,空密码,用户为root@127.0.0.1
-- mysql -uroot -p1234 #本地登录,指定用户名和密码,用户为root@127.0.0.1
-- mysql -uroot -p1234 -h 192.168.31.95 #远程登录,用户为root@192.168.31.95

mysql的常用命令

-- 
-- 启动mysql服务与停止mysql服务命令:
-- 
-- net start mysql
-- net stop  mysql
-- 
-- 
-- 登陆与退出命令:
-- 
--    mysql -h 服务器IP -P 端口号 -u  用户名 -p 密码 --prompt 命令提示符  --delimiter 指定分隔符
--    mysql -h 127.0.0.1 -P 3306 -uroot -p123
--    quit------exit----\q;
-- 
-- 
-- \s;   ------my.ini文件:[mysql] default-character-set=gbk [mysqld] character-set-server=gbk
-- 
-- prompt 命令提示符(\D:当前日期 \d:当前数据库  \u:当前用户)
-- 
-- \T(开始日志) \t(结束日志)
-- 
-- show warnings;
-- 
-- help() ? \h
-- 
-- \G;
-- 
-- select now();
-- select version();
-- select user;
-- 
-- \c 取消命令
-- 
-- delimiter 指定分隔符

忘记密码怎么办?

方法1:启动mysql时,跳过授权表

[root@controller ~]# service mysqld stop
[root@controller ~]# mysqld_safe --skip-grant-table &
[root@controller ~]# mysql
mysql> select user,host,password from mysql.user;
+----------+-----------------------+-------------------------------------------+
| user     | host                  | password                                  |
+----------+-----------------------+-------------------------------------------+
| root     | localhost             | *A4B6157319038724E3560894F7F932C8886EBFCF |
| root     | localhost.localdomain |                                           |
| root     | 127.0.0.1             |                                           |
| root     | ::1                   |                                           |
|          | localhost             |                                           |
|          | localhost.localdomain |                                           |
| root     | %                     | *23AE809DDACAF96AF0FD78ED04B6A265E05AA257 |
+----------+-----------------------+-------------------------------------------+
mysql> update mysql.user set password=password("123") where user="root" and host="localhost";
mysql> flush privileges;
mysql> exit
[root@controller ~]# service mysqld restart
[root@controller ~]# mysql -uroot -p123

方法2(删库):

删除与权限相关的库mysql,所有的授权信息都丢失,主要用于测试数据库或者刚刚建库不久没有授权数据的情况(从删库到跑路)
[root@controller ~]# rm -rf /var/lib/mysql/mysql
[root@controller ~]# service mysqld restart
[root@controller ~]# mysql

 

sql及其规范

相关文章:

  • 2021-04-27
  • 2021-12-10
  • 2021-04-26
  • 2022-01-01
  • 2021-12-24
  • 2022-02-02
  • 2021-07-25
  • 2021-08-20
猜你喜欢
  • 2022-01-07
  • 2022-12-23
  • 2022-12-23
  • 2022-02-09
  • 2022-01-28
相关资源
相似解决方案