MySQL是一个关系型数据库管理系统关系数据库,将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性,所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。

mysql分为关系型数据库和非关系型数据库

关系型:

库中的数据二维表的方式存储

概念:
关系:存储数据的表的表名
元组:表中的一条记录(一行是一条记录)
属性:表中的一个字段(一列是一个字段)                          

域:字段的取值范围
关键字:可以唯一标识一条记录的字段(一个或多个字段)     
关系模型:表和表之间的关系

关系性数据库遵循ACID
A:原子性
C:一致性
I:隔离性
D:持久性

原子性

原子性任务是一个独立的操作单元,是一种要么全部是,要么全部不是的原子单位性的操作。

一致性

一个事务可以封装状态改变(除非它是一个只读的)。事务必须始终保持系统处于一致的状态,不管在任何给定的时间并发事务有多少。

隔离性

多个事务并发访问时,事务之间是隔离的,一个事物不应该影响其它事务运行效果。在并发环境中,当不同的事务同时操纵相同数据时,每个事务都有各自的完整数据空间,由并发事务所做的修改必须与其它并发事务所做的修改隔离。

并行是可能出行的问题:

.脏读

脏读发生在:当一个事务允许读取一个被其他事务改变但是未提交的状态时,这是因为并没有锁阻止读取,如上图,你看到第二个事务读取了一个并不一致的值,不一致的意思是,这个值是无效的,因为修改这个值的第一个事务已经回滚,也就是说,第一个事务修改了这个值,但是未提交确认,却被第二个事务读取,第一个事务又放弃修改,悔棋了,而第二个事务就得到一个脏数据。

.不可重复读

在同一事务中,对于同一分数据读到的结果不一致。比如:事务B在事务A提交前读到的结果,和提交后读到的结果可能不同。

持久性

一个成功的事务将永久性地改变系统的状态,所以在它结束之前,所有导致状态的变化都记录在一个持久的事务日志中。如果我们的系统突然受到系统崩溃或断电,那么所有未完成已提交的事务可能会重演。

关系型优点:                             缺点:

1. 容易理解                        1. 事务一致性(数据一致性),为了保证数据的完整,会带来额外的开销,导致性能降低

2. 可以借助于sql语句来进行数据的读写            2. 关系型数据库在高并发的读写请求下,会程序系统的性能瓶颈            

3. 便于维护表中的数据(主要用于保证数据完整、数据一致)              3. 可扩展性  4. 读写的时效性      5. 需要写复杂的SQL,甚至需要用多表联合查询

非关系型数据库(NoSQL)

通常NoSQL是以key-value的方式存储

特点:
性能相比关系型数据库更好,更易于扩展。

常用的关系和非关系数据库

1. oracle
支持众多平台,收费
应用场景:非互联网行业
特点:稳定,安全,重量级,收费

2. sql server
仅仅支持windows平台

3. mysql
应用场景:互联网企业
特点:体积小、运行速度块、稳定、开源

4. MariaDB
mysql的分支,完全兼容mysql

5. Redis
key-value
内存+磁盘
因为磁盘的限制,导致在处理海量数据的时候不好
适用场景:局部高并发的场景

8. memcached
key-value
内存
逐渐被redis取代

存储引擎

MYISAMMySQL 5.0 之前的默认数据库引擎,最为常用。拥有较高的插入,查询速度,但不支持事务
InnoDB事务型数据库的首选引擎,支持ACID事务,支持行级锁定, MySQL 5.5 起成为默认数据库引擎
 

MyISAM存储的数据格式,包括三部分
MYD:保存表中的数据
frm:保存表结构
MYI:保存的索引信息

安装mysql(通用二进制格式)

(centos7下安装)

1.准备mysql的配置文件(不再提供配置文件模版)

[root@localhost ~]# mv /root/my.cnf /etc/  <<<此my.cnf模板是自定义的

说明:
安装位置:/usr/local/mysql
数据位置: /data/mysql/mysql3306/data
临时文件位置:/data/mysql/mysql3306/tmp
日志文件位置:/data/mysql/mysql3306/logs/mysql-bin
socket文件位置:/tmp/mysql3306.sock

[root@localhost ~]# groupadd mysql
[root@localhost ~]# useradd -r -g mysql -s /sbin/nologin mysql
[root@localhost ~]# tar xf /root/mysql-5.7.-linux-glibc2.-x86_64.tar.gz 安装包可在官网直接下载
[root@localhost ~]# mv mysql-5.7.-linux-glibc2.-x86_64 /usr/local/
[root@localhost ~]# cd /usr/local
[root@localhost local]# ln -sv mysql-5.7.-linux-glibc2.-x86_64/ mysql
chown mysql.mysql mysql -R

 创建相关目录

[root@localhost local]# mkdir /data/mysql/mysql3306/{data,tmp,logs} -pv
chown -R mysql.mysql /data

初始化

[root@localhost local]# /usr/local/mysql/bin/mysqld --initialize --user=mysql
说明:1. --user是用于指定以哪个用户的身份完成初始化工作(默认从配置文件中读取) 2. 数据目录下如果有文件,会导致初始化失败

初始化完成后,会在数据目录下生成一系列文件

[root@localhost local]# cd /data/mysql/mysql3306/data/

[root@localhost data]# ls
abc ib_logfile2
a.sh ibtmp1
auto.cnf innodb_status.1656
bak innodb_status.1657
db innodb_status.1665
db4 innodb_status.16762
dbq innodb_status.16895
error.log innodb_status.4740
gyf innodb_status.5819
hh mysql
ib_buffer_pool mysql.pid
ibdata1 performance_schema
ib_logfile0 slow.log
ib_logfile1 sys  <<<<说明初始化成功

说明:
error.log中保存了安装、启动、运行mysql过程中所出现的错误信息出,初始root密码也在其中

导出二进制

[root@localhost ~]# vim /etc/profile.d/mysql.sh
PATH=$PATH:/usr/local/mysql/bin/
export PATH
[root@localhost ~]# source /etc/profile

生成服务管理脚本

[root@localhost ~]# cd /usr/lib/systemd/system/
[root@localhost system]# vim mysql3306.service

[Unit]
  Description=mysql 3306 service

[Service]
  Type=forking
  ExecStart=/bin/bash /usr/local/mysql/support-files/mysql.server start
  ExecStop=/bin/bash /usr/local/mysql/support-files/mysql.server stop
  ExecRestart=/bin/bash /usr/local/mysql/support-files/mysql.server restart

[Install]
  WantedBy=multi-user.target

启动mysql

[root@localhost system]# systemctl start mysql3306.service 
[root@localhost system]# ss -tnl | grep 3306
LISTEN 0 70 ::: :::* <<<mysql启动端口为3306

 

mysql简单介绍及安装的更多相关文章

  1. Mysql数据库介绍、安装和配置文件

    Mysql数据库介绍.安装和配置文件 MySQL数据库介绍 mysql是开源关系型数据库,遵循GPL协议. mysql的特点是性能卓越且服务稳定,开源,无版本限制,成本低,单进程多线程,多用户,基于C ...

  2. openresty开发系列10--openresty的简单介绍及安装

    openresty开发系列10--openresty的简单介绍及安装 一.Nginx优点 十几年前,互联网没有这么火,软件外包开发,信息化建设,帮助企业做无纸化办公,收银系统,工厂erp,c/s架构偏 ...

  3. Linux系统Vi/Vim编辑器的简单介绍、安装/卸载、常用命令

    Linux系统Vi/Vim编辑器的简单介绍.安装/卸载.常用命令 1.介绍 vi(Visual Interface)编辑器是Linux和Unix上最基本的文本编辑器,工作在字符模式下.由于不需要图形界 ...

  4. CocoaPods的简单介绍及安装和使用

    CocoaPods的简单介绍及安装和使用   一.CocoaPods是什么? 当你开发iOS应用时,会常常使用到非常多第三方开源类库.比方JSONKit.AFNetWorking等等. 可能某个类库又 ...

  5. Nessus简单介绍与安装

    1.Nessus简单介绍与安装 1.Nessus简介 Nessus号称是世界上最流行的漏洞扫描程序,全世界有超过75000个组织在使用它.该工具提供完整的电脑漏洞扫描服务,并随时更新其漏洞数据库.Ne ...

  6. Cloudera impala简单介绍及安装具体解释

    一.Impala简单介绍 Cloudera Impala对你存储在Apache Hadoop在HDFS,HBase的数据提供直接查询互动的SQL.除了像Hive使用同样的统一存储平台,Impala也使 ...

  7. 数据库---mysql的介绍和安装

    MySQL数据库 一.简介: mysql是数据库管理软件:套接字:服务端,客户端 支持并发:操作得是共享得数据 处理锁,数据安全,性能 用别人得软件,得照着别人得规范,组织自己得语法规则 二.概述: ...

  8. 【Hadoop离线基础总结】Hue的简单介绍和安装部署

    目录 Hue的简单介绍 概述 核心功能 安装部署 下载Hue的压缩包并上传到linux解压 编译安装启动 启动Hue进程 hue与其他框架的集成 Hue与Hadoop集成 Hue与Hive集成 Hue ...

  9. 【Hadoop离线基础总结】impala简单介绍及安装部署

    目录 impala的简单介绍 概述 优点 缺点 impala和Hive的关系 impala如何和CDH一起工作 impala的架构及查询计划 impala/hive/spark 对比 impala的安 ...

随机推荐

  1. js实现table表格相同内容按需合并

    uniteTdCells(tableId) { var table = document.getElementById(tableId); for (let i = 0; i < table.r ...

  2. MySQL常用内置函数

    本篇博客源自以下博客地址: http://www.mamicode.com/info-detail-250393.html

  3. es6学习日记4

    数组的扩展 扩展运算符是三个点(...).它好比 rest 参数的逆运算,将一个数组转为用逗号分隔的参数序列. console.log(...[1, 2, 3]) // 1 2 3 console.l ...

  4. CCF-再卖菜-20180904

    可以说这道题出的不错,我是用动态规划做的 ( 严谨点说应该是记忆化搜索,我是递归版本,非递归我不会啊... 题意分析: x1  x2  x3 已知 x1+x2=t1或t1+1 x1+x2+x3=t2 ...

  5. Linux下使用Nginx代理访问json文件报404错误

    在网上看了很多,都说是IIS的问题,关键是使用servlet就可以正常访问,使用Nginx就不行,最后发现是其他问题,解决方案如下: 1.确认配置的路径是否正确,Nginx代理的路径和你访问的路径. ...

  6. https原理及其中所包含的对称加密、非对称加密、数字证书、数字签名

    声明:本文章已授权公众号Hollis转载,如需转载请标明转载自https://www.cnblogs.com/wutianqi/p/10654245.html(安静的boy) 一.为什么要使用http ...

  7. Hello2 分析

    一.打开GreetingServlet.java文件以查看它 hello2应用程序是一个web模块,hello2应用程序的行为几乎与hello1应用程序相同,但是它是使用Java Servlet技术实 ...

  8. github与github网站push神器

    GitBook.Editor(全英文,无汉化) 链接: http://pan.baidu.com/s/1slIZ5jJ 密码: q9mw source tree (汉化中文) 本地需要安装git客户端 ...

  9. oData 排序字段生成

    跟踪SQL 发现生成的SQL中所有的字段都进行了排序,查看OData原代码,发现如果实体有Key,就按照Key asc 加上指定字段进行排序 属性 EnsureStableOrdering可以控制是否 ...

  10. js延迟

    function sleep(numberMillis) { var now = new Date(); var exitTime = now.getTime() + numberMillis; wh ...