mariadb基础应用

mariadb基础应用

一、 前言

MariaDB is one of the most popular database servers in the world. It’s made by the original developers of MySQL and guaranteed to stay open source. Notable users include Wikipedia, WordPress.com and Google.

mariadb是mysql的一个分支,由同一个作者开发,mysql是作者大女儿的名字,mariadb是作者三女儿的名字。mysql是甲骨文(oracle)公司的眼中钉,故将其收购。mysql作者担心其会遭遇闭源危机,故有开发了mariadb,知名用户有谷歌,wordpress等等。

二、基本概念

1、mysql主要有两种存储引擎

MyISAM:mysql 5.5之前的默认数据库引擎,拥有较高的插入、查询速度,但不支持事务。

InnoDB:事务型数据库的首选引擎,支持ACID事务,支持行级锁定,mysql5.5之后成为默认的数据库引擎。

事务(Transaction):组织多个操作为一个整体,要么全部都执行,要么全部都不执行。就是转账,自己这边扣掉钱了,对方还没有到账,就要全部回滚。要不就自己掉钱了  对方也没拿到。

2、设计范式基础概念

1、第一范式:无重复的域(列不重复)

2、第二范式:在第一范式的基础上属性完全依赖于主键(行不重复,重复的放在另一张表上,形成一对多,例如统计XX部门的N的人的信息,都是XX部门,在第一张表写一次即可,映射到另外一张表。)

3、第三范式:在第二范式的基础上要求,一个关系不能包含已在其他关系已包含的非主关键字信息。一个关系中的A表现出年龄,B表不能存在。

三、mysql基础应用

常用mysql实用程序

mysqlshow

mysqladmin

mysql

1、mysqlshow 简单应用

(1)显示mysql服务器中的所有数据库:mysqlshow

mariadb基础应用

(2)显示mysql服务器中的表:mysqlshow mysql

mariadb基础应用

2、mysqladmin 简单应用

(1)设置mysql用户root的密码,密码为passwd

mysqladmin -u root password 'passwd'

mariadb基础应用

(2)显示mysql服务器的基本状态信息

mysqladmin  status  或
mysqladmin  -u root  -p  status

3、mysql详解

mysql是mysql命令行工具,相当于一个简单的SQL shell。

客户端命令:本地执行,常用如下

mysql> help
\u db_name:设定哪个库为默认数据库
\q:退出;
\d CHAR:设定新的语句结束符;
\g:语句结束标记;

服务端命令:通过 mysql 连接发往服务器执行并取回结果;

DDL, DML, DCL

注意:每个语句必须有语句结束符,默认为分号(;)

DDL :CREATE ALTER DROP

1、数据库管理:增删查改

创建:
CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db_name;
[DEFAULT] CHARACTER SET [=] charset_name
[DEFAULT] COLLATE [=] collation_name

查看支持的所有字符集:SHOW CHARACTER SET
查看支持的所有排序规则:SHOW COLLATION

修改:
ALTER {DATABASE | SCHEMA} [db_name]
[DEFAULT] CHARACTER SET [=] charset_name
[DEFAULT] COLLATE [=] collation_name

mariadb基础应用

2、表管理:增删查改

创建:
    CREATE TABLE [IF NOT EXISTS] tbl_name (create_defination)
    [table_options]
create_defination:
    字段:col_name data_type
    键:
    PRIMARY KEY (col1, col2, ...)
    UNIQUE KEY (col1, col2,...)
    FOREIGN KEY (column)
    索引:
    KEY|INDEX [index_name] (col1, col2,...)
table_options:
    ENGINE [=] engine_name
查看数据库支持的所有存储引擎类型:
    mysql> SHOW ENGINES;
查看某表的存储引擎类型:
    mysql> SHOW TABLES STATUS [LIKE 'tbl_name']

CREATE TABLE students(id INT UNSIGNED NOT NULL PRIMARYKEY,name CHAR(30) NOT NULL,age TINYINT UNSIGNED,gender ENUM('f','m'));

DESC students ;

mariadb基础应用

DROP TABLE students; 删除表格

修改表格:ALTER TABLE students ADD class VARCHAR(100) NOT NULL AFTER name;

mariadb基础应用

ALTER TABLE students MODIFY class VARCHAR(100) NOT NULL AFTER age;

mariadb基础应用

ALTER TABLE students DROP class; 删除表格中的class

3、索引管理:索引是特殊的数据结构

创建:
    CREATE [UNIQUE|FULLTEXT|SPATIAL] INDEX index_name [BTREE|HASH] ON tbl_name (col1, col2,,...)
删除:
DROP INDEX index_name ON tbl_name

mariadb基础应用

DML :INSERT SELECT DELETE UPDATE

1、INSERT

INSERT INTO:
    INSERT [INTO] tbl_name [(col1,...)] {VALUES|VALUE}
    (val1, ...),(...),...
注意:
字符型:引号;
数值型:不能用引号;

INSERT students(id,name) VALUES(2,'HuangYaoshi'),(3,'ZhouBotong');

SELECT * FROM students;

mariadb基础应用

2、SELECT

(1) SELECT * FROM tbl_name;
(2) SELECT col1, col2, ... FROM tbl_name;
    显示时,字段可以显示为别名;
    col_name AS col_alias
(3) SELECT col1, ... FROM tbl_name WHERE clause;
    WHERE clause:用于指明挑选条件;
    col_name 操作符 value:
    age > 30;


    操作符(1) :
        >, <, >=, <=, ==, !=
        组合条件:
        and
        or
        not
    操作符(2) :
        BETWEEN ... AND ...
        LIKE 'PATTERN'
        通配符:
            %:任意长度的任意字符;
            _:任意单个字符;
        RLIKE 'PATTERN'
            正则表达式对字符串做模式匹配;
        IS NULL
        IS NOT NULL
(4) SELECT col1, ... FROM tbl_name [WHERE clause] ORDER BY col_name, col_name2, ... [ASC|DESC];
    ASC: 升序;
    DESC: 降序;

mariadb基础应用

mariadb基础应用

3、DELETE:删除一整行,很危险,不加条件,整张表就没了,每一个回合都要确认N遍

DELETE FROM tbl_name [WHERE where_condition] [ORDER BY ...][LIMIT row_count]
(1) DELETE FROM tbl_name WHERE where_condition
(2) DELETE FROM tbl_name [ORDER BY ...] [LIMIT row_count]

4、UPDATE:

UPDATE [LOW_PRIORITY] [IGNORE] table_reference SET
col_name1=value1 [, col_name2=value2] ... [WHERE where_condition] [ORDER BY ...]
[LIMIT row_count]

UPDATA students SET age=age-5 ORDER BY id DESC;

UPDATA students SET age=age-15 WHERE name NOT LIKE 'stu%';

用户账户及权限管理:

1、创建用户账号

CREATE USER 'testuser'@'192.168.%.%' IDENTIFIED BY 'testpass'; 只有查看的权限,没有写权限

mariadb基础应用

禁止检查主机名:my.cnf

[mysqld]

skipnameresolve = ON

2、删除用户账号

DROP USER ’user‘@’host' [, user@host] …

3、授权

GRANT priv_type,... ON [object_type] db_name.tbl_name TO 'user'@'host' [IDENTIFIED BY 'password'];

CREATE USER 'testuser'@'192.168.%.%' IDENTIFIED BY 'testpass';

GRANT SELECT ON mydb.students TO 'testuser'@'192.168.%.%';

FLUSH PRIVILEGES;

mysql -utestuser -h192.168.1.120 -ptestpass

mariadb基础应用

查看指定用户所获得的授权:
SHOW GRANTS FOR 'user'@'host'
SHOW GRANTS FOR CURRENT_USER;

4、回收权限

REVOKE priv_type, ... ON db_name.tbl_name FROM
'user'@'host';
注意:MariaDB 服务进程启动时,会读取 mysql 库的所有授权表至内存中;
(1) GRANT 或 REVOKE 命令等执行的权限操作会保存于表中,MariaDB 此时一
般会自动重读授权表,权限修改会立即生效;
(2) 其它方式实现的权限修改,要想生效,必须手动运行 FLUSH PRIVILEGES
命令方可;

5、加固mysql服务器

加固 mysql 服务器,在安装完成后,运行 mysqlsecureinstallation 命令;

6、图形管理组件phpMyAdmin见上一个博客。

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

(0)
N24_yeziN24_yezi
上一篇 2016-12-16 12:29
下一篇 2016-12-16 15:02

相关推荐

  • 第十七周 作业–结合图形描述lvs原理

        LVS是Linux Virtual Server的简写,意即Linux虚拟服务器,是一个虚拟的服务器集群系统。本项目在1998年5月由章文嵩博士成立,是中国国内最早出现的自由软件项目之一。   Lvs有三种模式分别是lvs-nat、lvs-dr、lvs-tun。下面分别介绍lvs-nat、lvs-dr…

    Linux干货 2016-12-07
  • RAID( Blob3 )

    RAID各级别特性及使用

    2017-11-27
  • Gdevops 2017全球敏捷运维峰会【北京站】限时免费!

    Introduction 全球敏捷运维峰会 打造敏捷与运维领域标杆峰会! 2017年全球敏捷运维峰会(Gdevops, Global Devops Summit)将于2017年在成都、上海、北京、广州四城全面启动,本次Gdevops 2017全球敏捷运维峰会【北京站】由上海市经济和信息化委员会指导,上海市云计算产业促进中心、DBAplus社群主办,数十家媒体…

    Linux干货 2017-08-02
  • 初步了解计算机组成及Linux系统

    一、计算机的组成及其功能: 计算机主要由三部分组成: 输入单元:包括键盘、鼠标、卡片阅读器、扫描仪、手写板等。 输出单元使我们能够将一些数据输入到主机里,然后再由主机的功能处理成为图表或文章等信息后,将结果传输到输出设备,如屏幕或打印机上面。 中央处理器(CPU):其中包含算数逻辑、控制、记忆等单元。 CPU作为一个具有特定功能的芯片,里面含有微指令集,如果…

    Linux干货 2017-09-24
  • Linux下软链接与硬链接

    Linux下软链接与硬链接的区别 Linux中的文件都文件名和数据,在linux上面被分为两个部分:元数据与数据。用户数据,即文件数据块(data block),数据块是记录文件真实内容的地方,而元数据是文件的附加属性,如大小,创建时间,所有者等信息。在Linux中,元数据中的inode号(inode是文件的元数据的一部分,但其不包含文件名,inode号即索…

    Linux干货 2016-10-20
  • 第一周作业

    # 1.计算机的基本组成和功能: – **存储器**:  实现记忆功能的部件用来存放计算程序及参与运算的各种数据 – **运算器**:  负责数据的算术运算和逻辑运算即数据的加工处理 – **控制器**:  负责对程序规定的控制信息进行分析,控制并协调输入,输出操作或内存访问 – **输入设备**: 实现计算程…

    Linux干货 2016-12-04

评论列表(1条)

  • 马哥教育
    马哥教育 2016-12-23 12:19

    赞~详细描述mysql一些常用的操作~~建议补充下备份、恢复相关的内容,会更好点~~继续加油~