MySQL or MariaDB 简介

  • DBMS:数据库管理系统

  • RDBMS:关系型数据库管理系统

   总之:他们都是一个数据管理程序;大多都是CS架构,都有专门的通信协议进行数据交换

  • 关系模型:

              表(行或者列):二维关系

  • 设计范式:

                第一范式、第二范式、第三范式

                关系运算:选择(选择行);投影(选择咧)

  •  数据库—–》表——》索引—》视图(虚表)

                 SQL(结构化查询语言):

                                DDL(数据定义语言)

                                DML(数据操作语言)

                                编程接口:支持判断,选择,循环。。。

                                                   可以定义存储过程;存储函数;触发器;事件调度器;过程式编程(选择,循环)

  • 数据的三层模型:

    • 物理层视图:RAID。。。

    • 逻辑层视图:设计表结构,数据的恢复,导入导出

    • 视图层:用户视图:增删改查数据

  • 关系型数据库解决方案:

    • 商业版:oracle,sybase,infomix(IBM),DB2

    • 开源版:MySQL,MariaDB,PostgreSQL,SQLite

  • 两条路线

    • mysql常见版本:5.1—–>5.5——>5.6——->5.7

    • mariadb

            总结:mysql&mariadb选用的是插件式数据存储引擎

                       mariadb的单进程多线程

                                            连接线程    

                                            守护线程

  • mysql的配置文件内容简介:

    • 采用的是集中式的配置,能够为mysql的各种应用程序提供配置信息

    • [mysqld]:用于mysqld这个应用程序配置

    • [mysqld_safe]:线程安全的mysqld程序配置

    • [mysqld_multi]:多实例的mysql程序配置

    • [server]:服务端程序

    • [mysql]:客户端程序

    • [mysqldump]:mysql的备份还原程序

    • [client]:表示上述配置对客户端都有效

  • 参数定义

            parameter = value

            skip-name-resolve:跳过域名解析

  • 查找配置文件的路径:

    • /etc/my.cnf—->/etc/mysql/my.cnf—–>$MYSQL_HOME/my.cnf—> –default-extra-file=/path/to/somedir/my.cnf—–> ~/.my.cnf        #按此顺序找。后找的会覆盖之前找到的

安装方法

  • os vendor:rpm安装

  • MySQL:

    • rpm

    • 展开可用

    • 源码编译安装

  • 安装之后的设定

    • 为所有root用户设定密码:

mysql>set password mysql>update mysql.user set password=PASSWORD('password') where clausse;mysql>flush privileges;#mysqladmin ...
  • 删除所有的匿名用户

mysql>drop user ''@'localhost';同样也可以通过mysql_sequre_installation来实现用户加密和删除
  • 关闭主机名反解功能

          **元数据库:mysql

                                user,host

  • mysql的客户端程序:

    • mysql:交互式CLI工具

    • mysqldump:备份工具;基于mysql协议向mysqld发起查询请求,,并将查到的数据转换城INSERT等写操作语句保存到文本文件中

    • mysqladmin:这是mysql的客户端专用管理工具

    • mysqlimport :数据导入工具

  • mysql的非客户端类的管理工具

    • myisamchk:myisam引擎检查工具

    • myisampack:myisam打包工具(只读),节约空间

      • 客户端类的应用程序的可用选项:

        • -u;–user=

        • -h;–host=

        • -p;–password=

        • -P;–port=

        • –protocol={tcp|sock}

        • -S;–socket=

        • -D;–database=         #默认数据库

        • -C;–compress          #压缩

      • mysql -e "SQL"       #非交互格式执行sql

  • 获取程序的默认配置:

    • mysql –print-defaults         #不详细

    • mysqld –print-defaults       #详细

  • mysql的使用模式:

    • 交互式模式

      • 可运行的命令有两类:

        • 客户端命令:\h,help

        • 服务器端命令:需要语句结束符

    • 脚本模式

      • mysql -uUSERNAME -pPASSWORD < /path/from/somefile.sql

      • mysql>source /path/from/somefile.sql

  • mysql的服务器端(mysqld):工作特性有多重定义方式

    • 命令行选项

    • 配置文件参数

[root@localhost ~]# mysql --verbos --help      #查看所有帮助信息
  • 获取运行中的mysql进程使用各参数及其值:

MariaDB [(none)]> show variables;

          注意:其中有些参数支持运行时修改,会立即生效;有些参数不支持,切只支持修改配置文件然后重启服务才能生效

                      有些参数的作用域是全局的,切不可修改;有些可以为每个用户提供单独的设置

  • 修改服务器参数的值:

MariaDB [(none)]> help set;      #查看set的帮助信息Name: 'SET'
Description:
Syntax:
SET variable_assignment [, variable_assignment] ...

variable_assignment:
      user_var_name = expr
    | [GLOBAL | SESSION] system_var_name = expr
    | [@@global. | @@session. | @@]system_var_name = expr
  • 全局变量的修改:

MariaDB [(none)]> set global system_var_name = value;MariaDB [(none)]> set @@global.system_var_name=value;
  • 会话变量的修改:

MariaDB [(none)]> set [session] system_var_name=value;MariaDB [(none)]> set @@[session.]system_var_name=value;
  • 状态变量(不能修改的):

MariaDB [(none)]> set global status;MariaDB [(none)]> set [session] global status;

原创文章,作者:wanghui,如若转载,请注明出处:http://www.178linux.com/66454

(0)
wanghuiwanghui
上一篇 2017-01-11 19:32
下一篇 2017-01-12 17:34

相关推荐

  • Linux网络属性配置的几个命令

    Linux网络属性配置命令 ifcfg命令家族:ifconfig,route,netstat ifconfig命令:接口及地址查看和管理 ifconfig [INTERFACE] #ifconfig -a : 显示所有接口,包括inactive状态的接口 ifconfig interface [aftype] options | address … #i…

    Linux干货 2017-05-09
  • tcp通讯的服务器和客户端解析

    服务器端编程步骤, 1.创建Socket对象,下文中的socket都表示一个socket对象 2.绑定IP地址和端口,服务器的IP和端口 3.开始监听,将在指定的端口上监听,listen() 如果对方申请连接这个IP和端口,将被听到,这个过程 4.获取用于传输数据的Socket对象 socket.accept() ->(socket object,ad…

    Linux干货 2018-01-01
  • 第五周作业

    查看链接:http://note.youdao.com/noteshare?id=1ed7b36aa41cbdc1154e3e5b54e43fce

    Linux干货 2016-09-19
  • linux 系统启动流程

    假设以个人架设的linux主机为例:当你按下电源键之后,计算机硬件会主动读取BIOS来加载硬件信息及进行硬件系统的自我测试,之后系统会主动读取系统第一个可启动的设备,此时就可以读入引导装载程序了。 引导程序可以指定使用哪个内核文件来启动,并实际加载内核到内存中解压缩与执行,此时内核就能够开始在内存内活动,并检测所有硬件信息,与加载适当的驱动程序来使这部主机开…

    Linux干货 2016-09-12
  • 详解Ntbackup的五种备份方式(下)

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://jeffyyko.blog.51cto.com/28563/145644 继续上文。   四、差异备份(Differental Backup)     差异备份是…

    Linux干货 2015-03-26
  • 网络分层基础概念与TCP,IP协议解析

    网络分层基础概念:   与ISO的OSI网络分层模型不同。网络分层事实上的标准为TCP/IP 的网络分层模型。   下图是他们是他们之间的对应关系。   左边为OSI网络分层模型。右边为TCP/IP的网络分层模型。 网络分层,是将一个大而复杂的网络,拆分为多个层次,每个层次单独完成自己的任务,多个层次再结合起来,完成一个复杂的通…

    2017-05-04

评论列表(1条)

  • luoweiro
    luoweiro 2017-02-23 07:48

    看样子整理的只是笔记,希望有自己的理解过程和实验步骤。