数据库的简介

数据库:存储数据的仓库

数据库管理系统软件

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

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

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

数据库系统

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

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 ,密码为空

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时,只需要重复上述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的Windows服务,在终端执行此命令:
C:\Users\mamingchen>"E:\mysql-8.0.12-winx64\bin\mysqld" --remove

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

# 启动MySQL服务
net start 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.  -- 创建用户和密码
1)create 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 user、drop 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

第一篇 数据库MySql的更多相关文章

  1. 解剖SQLSERVER 第一篇 数据库恢复软件商的黑幕(有删减版)

    解剖SQLSERVER 第一篇  数据库恢复软件商的黑幕(有删减版) 这一系列,我们一起来解剖SQLSERVER 在系列的第一篇文章里本人可能会得罪某些人,但是作为一位SQLSERVER MVP,在我 ...

  2. oracle系列--第一篇 数据库基础

    第一章 数据库基础 1.1 数据管理概述 1.1.1 什么是数据管理 与我们人类相比,计算机的最大优势就是能够高速.精准地运行,其运行的过程就是执行程序代码和操作指令.处理数据的过程.可以说,数据处理 ...

  3. 第一篇:Mysql操作初级

    Mysql操作初级   Mysql操作初级 本节内容 数据库概述 数据库安装 数据库操作 数据表操作 表内容操作 1.数据库概述 数据库管理系统叫做DBMS 1.什么是数据库 ? 答:数据的仓库,如: ...

  4. Mysql优化(出自官方文档) - 第一篇(SQL优化系列)

    Mysql优化(出自官方文档) - 第一篇 目录 Mysql优化(出自官方文档) - 第一篇 1 WHERE Clause Optimization 2 Range Optimization Skip ...

  5. 第一篇:Win10系统搭建Python+Django+Nginx+MySQL 开发环境详解(完美版)

    Win10+Python+Django+Nginx+MySQL 开发环境搭建详解 PaulTsao 说明:本文由作者原创,仅供内部参考学习与交流,转载引用请注明出处,用于商业目的请联系作者本人. Wi ...

  6. mysql基础篇 - 数据库及表的修改和删除

    基础篇 - 数据库及表的修改和删除         修改和删除 一.实验简介 本节实验中,我们将学习并实践如何对数据库的内容做修改,删除,重命名等操作. 二.实验准备 在正式开始本实验内容之前,需要先 ...

  7. 【转帖】Mysql多维数据仓库指南 第一篇 第1章

     Mysql多维数据仓库指南 第一篇基本原理 章节列表: 第1章:基本组成 第2章:维度历史 第3章:维度可加性 第4章:维度查询 本篇概述 你将运用关系数据库来实施一个维度数据仓库.事实表和维表这两 ...

  8. 小白两篇博客熟练操作MySQL 之 第一篇

    小白两篇博客熟悉操作MySQL  之   第一篇 一.概述 1. 什么是数据库? 答: 储存数据的仓库, 如: 在ATM的事例中创建的一个db 目录, 称为数据库 2. 什么是Mysql, Oracl ...

  9. 数据库MySQL学习笔记高级篇

    数据库MySQL学习笔记高级篇 写在前面 学习链接:数据库 MySQL 视频教程全集 1. mysql的架构介绍 mysql简介 概述 高级Mysql 完整的mysql优化需要很深的功底,大公司甚至有 ...

随机推荐

  1. YourUninstaller注册码(可用)

    Name:Giveawayoftheday Registration code: 000017-2PNBK2-J59U6F-317E09-R5TGJQ-6B1WNA-AZCYNJ-GVP86A-7VP ...

  2. 在hyper-v中安装centos后配置网络

    /etc/sysconfig/network-scripts vi ifcfg-eth0 改为以下配置 TYPE=Ethernet PROXY_METHOD=none BROWSER_ONLY=no ...

  3. 【noip 模拟赛curse,light,maze】 题解

    2018.10.16 总结:考的不好 原因: 1.考的时候没状态,读题读不进去 2.考的时候不仔细,该得分没得到 T1:curse 1.咒语 (curse.pas/c/cpp) [题目描述] 亮亮梦到 ...

  4. 查看mysql中所有表的数据记录

    select table_name,table_rows from tables where TABLE_SCHEMA = 'database name' order by table_rows de ...

  5. 与MySQL的零距离接触

    存储引擎 查看数据表的创建命令:show create table tbl_name

  6. C#泛型约束 (转载)

    六种类型的约束: T:结构 类型参数必须是值类型.可以指定除 Nullable 以外的任何值类型.有关更多信息,请参见使用可空类型(C# 编程指南). T:类 类型参数必须是引用类型,包括任何类.接口 ...

  7. linux--yum源,源码包

    一.企业版 搜狐:http://mirrors.sohu.com/ 网易:http://mirrors.163.com/ 阿里云:http://mirrors.aliyun.com/ 腾讯:http: ...

  8. ES module 实现方式

    随着js社区不断发展,js功能更加强大,细数js的几种 module 方式. 整理了七种模块化方式 1.作为新手,练习小的demo,比较喜欢的方式.不适合大的项目. <!--html--> ...

  9. es6解构赋值的几个用法

    1.解构赋值可以轻松获取对象或者数组中的数据 var jsonData = { data: "111", data2: ["test","test2& ...

  10. 模板——STL队列

    C++ STL queue 容器优先队列&&队列 队列 #include<queue> #include<iostream> using namespace s ...