MySQL系列之三 基础篇
作者:生生不息.连绵不绝 发布时间:2024-01-25 21:09:28
目录
系列教程
一、MySQL简介
二、MySQL的发展历史
三、MariaDB的基本使用
1、基本安装与配置
2、客户端命令:mysql
3、其他客户端工具
4、安全加强脚本 mysql_secure_installation
系列教程
MySQL系列之开篇 MySQL关系型数据库基础概念
MySQL系列之一 MariaDB-server安装
MySQL系列之二 多实例配置
MySQL系列之四 SQL语法
MySQL系列之五 视图、存储函数、存储过程、触发器
MySQL系列之六 用户与授权
MySQL系列之七 MySQL存储引擎
MySQL系列之八 MySQL服务器变量
MySQL系列之九 mysql查询缓存及索引
MySQL系列之十 MySQL事务隔离实现并发控制
MySQL系列之十一 日志记录
MySQL系列之十二 备份与恢复
MySQL系列之十三 MySQL的复制
MySQL系列之十四 MySQL的高可用实现
MySQL系列之十五 MySQL常用配置和性能压力测试
一、MySQL简介
MySQL原本是一个开放源代码的关系数据库管理系统,原开发者为瑞典的MySQL AB公司,该公司于2008年被Sun公司收购。2009年,Oracle收购sun公司,MySQL成为Oracle旗下产品。
但被甲骨文公司收购后,Oracle大幅调涨MySQL商业版的售价,且甲骨文公司不再支持另一个自由软件项目OpenSolaris的发展,因此导致自由软件社区们对于Oracle是否还会持续支持MySQL社区版(MySQL之中唯一的免费版本)有所隐忧,MySQL的创始人麦克尔·维德纽斯以MySQL为基础,成立分支计划MariaDB。而原先一些使用MySQL的开源软件逐渐转向MariaDB或其它的数据库。
二、MySQL的发展历史
作者:Monty 麦克尔·维德纽斯
1996年:发布MySQL1.0,开始是Solaris版本,后来又发布了Linux版本
1999年:Monty 在瑞典成立了 MySQL AB 公司
2003年:MySQL 5.0版本发布,增加了视图、存储过程等功能
2008年:被 sun公司 收购
2009年:Oracle 收购 sun
2009年:Monty 成立 MariaDB
版本的演变:
MySQL:5.1 --> 5.5 --> 5.6 --> 5.7
MariaDB:5.5 -->10.0--> 10.1 --> 10.2 --> 10.3
三、MariaDB的基本使用
MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。在存储引擎方面,10.0.9版起使用XtraDB(名称代号为Aria)来代替MySQL的InnoDB。
由MySQL的创始人麦克尔·维德纽斯主导开发,他早前曾以10亿美元的价格,将自己创建的公司MySQL AB卖给了SUN,此后,随着SUN被甲骨文收购,MySQL的所有权也落入Oracle的手中。MariaDB名称来自麦克尔·维德纽斯的女儿玛丽亚(英语:Maria)的名字。
插件式存储引擎:也称为“表类型”,存储管理器有多种实现版本,功能和特性可能均略有差别;用户可根据需要灵活选择,Mysql5.5.5开始innoDB引擎是MYSQL默认引擎。MyISAM ==> Aria ,InnoDB ==> XtraDB
1、基本安装与配置
安装:yum install mariadb-server
主配置文件:从上到下检查,如果有重复的配置参数则在后边的配置文件中的参数生效,覆盖检索
/etc/my.cnf
/etc/mysql/my.cnf
/etc/sysconfig/my.cnf
/usr/local/etc/my.cnf
~/.my.cnf
查看默认配置:/usr/libexec/mysqld --print-defaults
默认数据库库文件存放目录:/var/lib/mysql/
套接字文件:/var/lib/mysql/mysql.sock
PID文件:/var/run/mariadb/mariadb.pid
日志文件:/var/log/mariadb/mariadb.log
启动服务:# systemctl start mariadb.service
2、客户端命令:mysql
选项:
-u root 指定用户
-p password 指定密码
-h host 指定连接主机
-A 禁止补全
-P port 指定端口,默认3306
-S socket文件路径 默认:/var/lib/mysql/mysql.sock
-D databasename 指定默认数据库
-C 启用压缩
-e SQL_CMD 执行后退出
-V 查看版本
--print-defaults 查看默认设置
批处理模式
mysql < /path/somefile.sql 将sql脚本导入数据库执行
交互式模式
客户端命令
\d|delimiter 设置语句结束符
\c|clear 提前结束语句
\r|connect 重新连接数据库
\g 直接将语句送服务器执行
\G 直接将语句送服务器执行;结果纵向显示
.|source 读入脚本文件创建数据库
! COMMAND 执行shell命令
\W 语句执行结束后显示警告信息
\w 语句执行结束后不显示警告信息
\s 获取当前系统状态
use database_name 指定操作的数据库
prompt \u@[\D] \r:\m:\s-> 修改提示符,如果需要永久修改则在my.cnf中 [mysql] 下加入 prompt="(\u@\h) [\d]>
\q 退出
服务器命令:需要在命令后加命令结束符,默认结束符为分号";"
help KEYWORD 获取服务器命令的帮助
select version(); 查看数据库版本
show variables; 显示数据库当前工作的环境变量
3、其他客户端工具
mysqldump:备份工具,基于mysql协议向mysqld发起查询请求,并将查得的所有数据转换成insert等写操作语句保存文本文件中
mysqladmin:基于mysql协议管理mysqld
mysqlimport:数据导入工具
myisamchk:检查MyISAM库
myisampack:打包MyISAM表
mysqld_safe:服务二进制程序
mysqld_multi:创建多实例工具
4、安全加强脚本 mysql_secure_installation
这个脚本可以帮助我们做一下基本的安全加强
[root@centos7 mysql]# mysql_secure_installation
Enter current password for root (enter for none): #空密码直接回车
Set root password? [Y/n] Y #设置root密码
New password: ******
Re-enter new password: ******
Remove anonymous users? [Y/n] Y #删除匿名账户
Disallow root login remotely? [Y/n] n #禁用远程连接
Remove test database and access to it? [Y/n] Y #删除test库
Reload privilege tables now? [Y/n] Y #重读授权表使其配置生效
[root@centos7 mysql]# mysql -uroot -p'your_password' #连接数据库命令
来源:https://www.cnblogs.com/L-dongf/p/9138934.html


猜你喜欢
- 场景:主库DB:utf8字符集备库DB:gbk字符集需求:校验主备数据是否一致,并且修复校验过程:设置主库连接为utf8,设置备库连接为gb
- 0. 前言机器学习是人工智能的子集,它为计算机以及其它具有计算能力的系统提供自动预测或决策的能力,诸如虚拟助理、车牌识别系统、智能推荐系统等
- 对于比较长的数字组成的字符串,我们一般会用逗号(,)隔开来格式化数字,从右往左每三个数字用一个逗号分组隔开。为什么要用逗号隔开数字呢?因为当
- mybatis通过将sql配置xml文件中,通过解析xml动态标签来实现动态sql如下样例 xml文件<?xml version =
- /* * zoomCheck */jQuery(function($){ var dCheck = $(&q
- 数据添加函数实例//数据添加 public function newData($strName="") &n
- <%@ page language="java" contentType="text/html; cha
- 前言Golang中当程序发生致命异常时(比如数组下标越界,注意这里的异常并不是error),Golang程序会panic(运行时恐慌)。当程
- 这个验证类的完成有很长时间了,一直没有分享给大家使用了这么长时间之后感觉挺顺手,用于一些不需要特殊效果的表单验证个人认为已经足够了,还是挺好
- demo用了点extjs的东西,主要是为了打印json数组出来。 js code(XmlUtils.js): /**/ function X
- logging模块logging模块用于输出运行日志,可以设置不同的日志等级,保存信息到日志文件中等。 相比print,logging可以设
- 一、在webpack-dev-conf.js文件中:1、在const portfinder = require(‘portfinder
- 描述sorted() 函数对所有可迭代的对象进行排序操作。语法sorted(iterable, key=None, reverse=Fals
- 1.join函数的语法及用法(1)语法:'sep'.join(sep_object)参数说明sep:分割符,可为&l
- #!/usr/bin/env python# name IsOpen.pyimport osimport socketdef IsOpen(
- 前言该脚本的代码大部分是参考自阿里云的官方帮助文档。1, 脚本语言使用的是python, 我个人只是了解python,没有太深入的知识功底2
- 一、变量相关1.变量声明C# : int a;Go : var a int; 需要在前面加一个var关键字,后面定义类型可以使用 var(
- 不过,如果您需要查找文档中的一个特定的元素,最有效的方法是 getElementById()。 不过要注意的是使用getElementByI
- 1.简要概述为什么要开通MySQL这个学习板块呢?因为这是一名数据分析师必要的一项技能。分析数据什么最重要?当然是数据,既然如此!在数据呈现
- Flask或者其他框架都是封装的比较完善,我们可以不去关注路由、SESSION等到底是怎么实现的,现在我们使用socket来实现一个带有注册