mariadb介绍
事务(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介绍的更多相关文章
- 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 ...
- Linux centos7 LAMP架构介绍、 MySQL、MariaDB介绍、MySQL安装
一.LAMP架构介绍 为Linux+Apache(httpd)+MySQL+PHP简写,把后三者安装在Linux Apache是最常用的的web服务软件,MySQL为小型的数据库存储软件,PHP为脚本 ...
- Mariadb 介绍 1 (安装)
引言: mariadb是是由开源社区维护,在这我会从安装到实战都会介绍到.后期所有用到mysql数据库的项目我会全用mariaDB来替换,实际使用中的区别我会标出,请大家注意 MariaDB: Mar ...
- LAMP架构介绍MySQL、MariaDB介绍 MySQL安装
- Linux下MySQL/MariaDB Galera集群搭建过程
MariaDB介绍 MariaDB是开源社区维护的一个MySQL分支,由MySQL的创始人Michael Widenius主导开发,采用GPL授权许可证. MariaDB的目的是完全兼容MySQL,包 ...
- MariaDB 数据库
1. MariaDB 介绍 MariaDB数据库管理系统是 MySQL 的一个分支,主要由开源社区在维护,采用GPL授权许可 MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成 ...
- MariaDB学习记录
MariaDB的学习 MariaDB的学习 关于MariaDB的历史,不再概述 下面是mariadb的官网:https://mariadb.com/ 同样的,MariaDB一样有连接java的jar包 ...
- Linux下MySQL/MariaDB Galera集群搭建过程【转】
MariaDB介绍 MariaDB是开源社区维护的一个MySQL分支,由MySQL的创始人Michael Widenius主导开发,采用GPL授权许可证. MariaDB的目的是完全兼容MySQL,包 ...
- mysql高级用法(1)- mariadb的主从搭建
Mariadb介绍: mariadb是mysql的一个分支,需要进一步了解的参考:https://mariadb.org/ 安装参考教程:window版安装:Mariadb 介绍 1 (安装) lin ...
随机推荐
- 全新安装Mac OSX 开发者环境 同时使用homebrew搭建 PHP,Nginx ,MySQL,Redis,Memcache ... ... (LNMP开发环境)
https://segmentfault.com/a/1190000000606752
- mac下配置eclipse的hadoop环境
下载eclipse-jee-mars-1-macosx-cocoa-x86_64.tar 右键显示包内容,将hadoop-eclipse-plugin-2.6.0.jar拷入到刚显示的包的plugin ...
- Fragments | Android Developer
Definition A Fragment represents a behavior or a potion of user interface in an Activity. You can co ...
- IIS安全工具UrlScan介绍 ASP.NET 两种超强SQL 注入免费解决方案( 基于IIS,使用免费工具) 批改或隐藏IIS7.5的Server头信息 移除X-Powered-By,MVC,ASP.NET_SessionId 的 HTTP头或者cookie名称
微软给了我们一个很好的工具用来使IIS安全的运行-------UrlScan,下面是它的配置文件介绍 [options]UseAllowVerbs=1 ; 若为1,则使用 ...
- VB 读取csv文件数据
Public adoConn As New ADODB.Connection Private Sub csv() adoConn.ConnectionString = "Driver={Mi ...
- LICEcap GIF 屏幕录制工具
LICEcap 是一款屏幕录制工具,支持导出git动画图片格式,简单好用.大小只有几百KB 运行之后,可以随意调整大小,右下角有开始/停止按钮. 压缩包:http://files.cnb ...
- USACO Section 3.3 商店购物 Shopping Offers
题目背景 在商店中,每一种商品都有一个价格(用整数表示).例如,一朵花的价格是 2 zorkmids (z),而一个花瓶的价格是 5z .为了吸引更多的顾客,商店举行了促销活动. 题目描述 促销活动把 ...
- 华为OJ平台——24点游戏
题目描述: 给出4个1-10的数字,通过加减乘除,得到数字为24就算胜利 输入: 4个1-10的数字.[数字允许重复,测试用例保证无异常数字]输出: true or false 思路:
- java基础回顾(六)——WeakReference、SoftReference
在Java里, 当一个对象o被创建时, 它被放在Heap里. 当GC运行的时候, 如果发现没有任何引用指向o, o就会被回收以腾出内存空间. 或者换句话说, 一个对象被回收, 必须满足两个条件: 1) ...
- openstack4j
Identity // V2 authentication OSClientV2 os = OSFactory.builderV2() .endpoint("http://127.0.0.1 ...