事务(Transaction):组织多个操作为一个整体,要么全部执行,要么全部不执行    “回滚” ,rollback

SQL接口:sql语句分析器和优化器

表:为了满足范式设计要求,将一个数据集分拆为多个

约束:constraint,向数据表插入的数据要遵守的限制规则

  主键:一个或多个字段的组合,填入主键中的数据,必须不同于已存在的数据;不能为空

  外键:一个表中某字段中能插入的数据,取决于另外一张表的主键中的数据

  惟一键:一个或多个字段的组合,填入惟一键中的数据,必须不同于已存在的数据;可以为空

  检查性约束:取决于表达式的要求

索引:将表中的某一个或某些字段抽取出来,单独将其组织到一个独特的数据结构中

    常用的索引类型:  树型  hash(只有使用MEMORY引擎的表才能使用)    

    实现级别在存储引擎,应该创建在经常用作查询条件的字段上

    索引有助于读请求,但不利于写请求

MariaDB的特性:插件式存储引擎:存储管理器有多种实现版本,彼此间的功能和特性可能略有区别;用户可根据需要灵活选择

         存储引擎也称为“表类型”

MariaDB与MySQL的比较:

        (1) 支持更多的存储引擎

        (2) MyISAM-->Aria (改进版)不支持事务

        (3) InnoDB --> XtraDB(改进版) 支持事务

        (4) 诸多扩展和新特性 

        (5) 提供了较多的测试组件

        (6) 完全的开源软件

centos7上直接安装:yum -y install mariadb-server    启动服务:systemctl start mariadb

    数据目录:/var/lib/mysql/           命令行输入mysql就可以直接登陆了     配置文件:/etc/my.cnf.d/server.cnf

使用mysql --help查看读取配置文件的位置及读取顺序,后面读的会把前面的覆盖掉

DDL(Data Definition Language): CREATE, ALTER, DROP

DML(Data Manipulation Language): INSERT, DELETE, UPDATE, SELECT

DCL(Data Control Language): GRANT, REVOKE

三类套接字地址:IPv4,IPv6 3306/tcp  

        Unix Sock:/var/lib/mysql/mysql.sock(rpm安装) /tmp/mysql.sock(源码安装)  通过127.0.0.1地址通信

客户端:

    mysql:CLI交互式客户端程序

    mysqldump:备份工具

    mysqladmin:管理工具,例如:[root@localhost ~]# mysqladmin extended-status

    mysqlbinlog:二进制日志文件查看工具

命令行交互式客户端程序:mysql

    -uUSERNAME:用户名,默认为root

    -hHOST:远程主机(即mysql服务器)地址,默认为localhost

    -p[PASSWORD]:用户的密码; 默认为空

注意:mysql的用户账号由两部分组成:'USERNAME'@'HOST',其中HOST用于限制此用户可通过哪些远程主机连接当前的mysql服

务,HOST的表示方式,支持使用通配符,%:匹配任意长度的任意字符,_:匹配任意单个字符

mysql -D mysql  直接登录到mysql数据库       mysql -e ‘show databases’ 在命令行取得show databases命令的执行结果

客户端命令:本地执行   获取帮助:MariaDB [(none)]> help   例如:获取状态信息:\s

服务端的获取命令帮助:help COMMAND

  查看mariadb支持哪些字符集:show character set;

  创建一个数据库:create database nihao character set ustf8;

  删除一个数据库:drop database nihao;  注意数据库删除了就找不回了

  查看: show database like '';

创建表的格式:create table  [if not exits]  tbl_name  (create_defination)  [table_options]

    create_defination:

      字段:col_name  data_type

      键:PRIMARY KEY (col1, col2, ...)  UNIQUE KEY  (col1, col2,...)  FOREIGN KEY (column)

    table_options:engine=egine name

例如:create table students(id int unsigned not null primary key, name char(10) not null, age tinyint unsigned, gender

enum('m','f' ));

    字符类型char比varchar对mariadb的性能更好,使用desc tablename查看表结构

定义多个主键:create table students(id int unsigned not null, name char(10) not null, age tinyint unsigned, gender

enum('m','f' ),primary key(id,name));

    注意unsigned只能紧跟在数值类型后面,否则会报错

显示MariaDB支持的所有存储引擎:show engines;  查看表使用存储引擎:show table status\G   查看具体哪张表:show

table status like 'tablename';  注意:同一个库中表要使用同一种存储引擎类型

修改:

  增加一个字段:alter table students add class varchar(10) not null after name;

  after表示放在哪个字段后面

  删除一个字段:alter table students drop class;

  不修改名字,只对某一列的属性进行修改:alter table students modify class varchar(99) after age;

  

  删除主键:alter table students drop primary key;

  添加一个唯一键:alter table students add unique key (name);    如果唯一键为not null自动转换此primary key

  查看表的索引:show indexes from tablename\G (注意键可以是索引,但索引不一定是键)

  删除一个索引:alter table students drop index name;   (name为索引的名字)

  添加一个索引:alter table students add index class (class); 【(class)代表的是字段的名字,class表示索引名】

  

  

mariadb介绍的更多相关文章

  1. LAMP架构介绍、MySQL、MariaDB介绍、MySQL安装

    5月23日任务 课程内容: 11.1 LAMP架构介绍11.2 MySQL.MariaDB介绍11.3/11.4/11.5 MySQL安装扩展mysql5.5源码编译安装 http://www.ami ...

  2. Linux centos7 LAMP架构介绍、 MySQL、MariaDB介绍、MySQL安装

    一.LAMP架构介绍 为Linux+Apache(httpd)+MySQL+PHP简写,把后三者安装在Linux Apache是最常用的的web服务软件,MySQL为小型的数据库存储软件,PHP为脚本 ...

  3. Mariadb 介绍 1 (安装)

    引言: mariadb是是由开源社区维护,在这我会从安装到实战都会介绍到.后期所有用到mysql数据库的项目我会全用mariaDB来替换,实际使用中的区别我会标出,请大家注意 MariaDB: Mar ...

  4. LAMP架构介绍MySQL、MariaDB介绍 MySQL安装

  5. Linux下MySQL/MariaDB Galera集群搭建过程

    MariaDB介绍 MariaDB是开源社区维护的一个MySQL分支,由MySQL的创始人Michael Widenius主导开发,采用GPL授权许可证. MariaDB的目的是完全兼容MySQL,包 ...

  6. MariaDB 数据库

    1. MariaDB 介绍 MariaDB数据库管理系统是 MySQL 的一个分支,主要由开源社区在维护,采用GPL授权许可 MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成 ...

  7. MariaDB学习记录

    MariaDB的学习 MariaDB的学习 关于MariaDB的历史,不再概述 下面是mariadb的官网:https://mariadb.com/ 同样的,MariaDB一样有连接java的jar包 ...

  8. Linux下MySQL/MariaDB Galera集群搭建过程【转】

    MariaDB介绍 MariaDB是开源社区维护的一个MySQL分支,由MySQL的创始人Michael Widenius主导开发,采用GPL授权许可证. MariaDB的目的是完全兼容MySQL,包 ...

  9. mysql高级用法(1)- mariadb的主从搭建

    Mariadb介绍: mariadb是mysql的一个分支,需要进一步了解的参考:https://mariadb.org/ 安装参考教程:window版安装:Mariadb 介绍 1 (安装) lin ...

随机推荐

  1. delphi TServerSocket阻塞线程单元 实例

    TServerSocket阻塞线程单元,希望对你有所帮助.需要注意的是:1.如果你使用TServerSocket的stNonBlocking模式,重写TServerClientThread线程时要重载 ...

  2. Android--创建进度框ProgressDialog

    1.布局文件progress_dialog_activity.xml <?xml version="1.0" encoding="utf-8"?> ...

  3. Oracle数据库——常用命令(用户管理、数据库导入导出)

    --==cmd控制台==-- --==日常用户管理SQL==-- --连接到SQLPLUS >sqlplus /nolog --以dba身份连接 sql>conn / as sysdba ...

  4. 【转】交叉编译faac共享库

    转自:http://blog.csdn.net/cjj198561/article/details/38382889 编译准备 1.代码下载 在mac下面执行:wget http://download ...

  5. Codeforces Round #219 (Div. 1) C. Watching Fireworks is Fun

    C. Watching Fireworks is Fun time limit per test 4 seconds memory limit per test 256 megabytes input ...

  6. Bootstrap 3 How-To #3 布局

    对于 Web 开发来说,一个永远的话题是如何创建一个跨浏览器兼容的布局.许多年来,各种框架使用各种技术来解决这个问题.Bootstrap 使用了一个不同的方式来解决这个问题.基于 960 像素的布局 ...

  7. win8 C 盘 突然少了 十几G 空间 原因,解决方法

    原因: win8 默认最大虚拟内存为 16G多,但现在电脑本身内存就大,所以应该不用了.我现在电脑本身内存是16G. 如果C盘空间大,这个无所谓了,如果C盘空间小可以按以下操作,拿回16G空间: 解决 ...

  8. 如何实现从Android第三方平台推送微信公众号

    最近心血来潮,想要尝试写写有关实现Android平台第三方应用软件去跳转到微信平台的代码.我只是先暂时写写我的思路,如后期实现,便将主要代码附上. 微信公众平台官方宣布微信沟通接口正式上线,用户可以在 ...

  9. 慧自文档:代替 Everything 来快速查找文件的,实现文件显示在文件夹的层次结构中

    1. 搜索功能和Everything一样快和强大 具有 Everything 搜索快.搜索功能强等优点, 解决了不能方便选择搜索哪个文件夹, 解决了不能同一个画面进行预览等问题 2.文件直接显示到文件 ...

  10. Spring Cloud 开门见山

    Spring Cloud简介 Spring Cloud是一个基于Spring Boot实现的云应用开发工具,为开发者提供了在分布式系统(配置管理,服务发现,熔断,路由,微代理,控制总线,一次性toke ...