--查看当前日期
select current_date();
--查看当前时间
select current_time();
--查看当前日期、时间
select now();
--查看当前用户
select user();
--验证当前客户端用户
select current_user();
--查看创建表结构的语法
show create table tab_name;
--删除表
drop table tab_name;
--删除数据库
drop database database_name;
--查看当前数据库里所有的表
show tables; --查询所有数据库
show databases;
--使用某一个数据库
use database_name --改变结束符号
delimiter // --使用储存过程
create procedure numx(x int )
begin

  set @x=0;
  set @sum=0;
    repeat
    set @x=@x+1;
    set @sum=@sum+@x;
    until @x=x end repeat;
  end

  create procedure addx(x int)
  begin
  set @x=0;
  set @sum=1;
    repeat
    set @x=@x+1;
      if @x%3=0 && @x%9!=0 then
      set @sum = @x*@sum;
      end if;
    until @x=x end repeat;
  end

--调用存储过程
call numx(100);
--删除存储过程
drop procedure numx; --创一个表(主键,外键,约束,默认,自增长)
create table demo1(
  demo1_id int auto_increment primary key,
  demo1_name varchar(10) not null
)
create table demo(
  demo_id int auto_increment primary key,--主键、自增长
  demo_name varchar(20) not null,
  demo_price float check ( price >= 0 ),
  publish_at datetime,
  created_at datestamp,
  fk_id int foreign key references demo1(demo1_id)--外键设置
)
上面的语法可以使用,
但是从实际情况去考虑,(主外键的设置)应该这么做 主键建立:
alter table demo
  add constraint pk_demo_id(这里是约束名) primary key demo(demo_id)
如果需要删除的话,语法如下
alert table demo
  drop constraint pk_demo_id(这里是约束名哦)
外键建立
alter table demo
  add constraint demo_fk_id(这里是约束名)
  foreign key(fk_id) references demo1(demo1_id)
如果需要删除的话,语法如下
alert table demo
  drop foreign key demo_fk_id(这里是约束名哦)
  
数据类型:
  大致分为6类:
  1. 整数: bit / bool / tinyint / smallint / mediumint / int / bitint
  2. 浮点数: float / double / decimal
  3. 字符串: char / varchar / tinytext / text / mediumtext / longtext
  4. BLOB(Binary Large Object): tinyblob / blob / mediumblob / longblob
  5. 日期: date(2018-9-6) / time (03:33:49) / datetime(2018-9-6 03:34:08) / timestamp
  6. 其他: binary / varbinary / enum / set / geometry / point / LineString …
小提示:
  char(n) 和 varchar(n)中间的n代表字符的个数,不是字节的个数哦。
  char()是固定长度,varchar()是可变长度,
    比如: 存储 字符 “abc” 对于char(10)就相当存储了三个字符(abc)和7个空格字符,而对于varchar(10)就是存储了三个字符(abc) 它是按照内容的实际长度来存储的。

  varchar最大长度:
    根据字符集,字符类型若为gbk,每一个字符占用2个字节,最大长度不能超过32766
    字符类型若为utf8,每个字符最多占用3个字节,最大长度不能超过21845,
    超过这个限制的话,会自动将类型转得更大一些的字符类型。

  

  主键.primary key 从性能和实际出发,应该遵循下面几点:
  1、尽量短,避免占用太多空间
  2、唯一,不能跟其他行的数据重复
  3、不会改变
  4、代理建
  所谓 -代理建- 是指跟业务无关的字段:
  1、因为和业务无关,所以可以使用int等类型尽量短
  2、因为和业务无关,所以可以避免因为业务变动引起的主键变化
  3、不要相信自已的直觉,因为在直觉上感觉不会变的东西,往往都是经不起实践考验的。


MariaDB基本命令的更多相关文章

  1. Linux下python3、virtualenv、Mysql、redis安装配置

    一.在Linux安装python解释器 1.下载python3源码包 cd /opt/ wget https://www.python.org/ftp/python/3.6.2/Python-3.6. ...

  2. mysql/mariadb学习记录——创建删除数据库、表的基本命令

    查看已有的数据库: mysql> show databases; +--------------------+ | Database | +--------------------+ | inf ...

  3. Mysql的基础使用之MariaDB安装

    初学mysql的小白,首次写博客,为了能让自己记得更加深刻,也是以一种小白的角度交代初学者的经历和困难,也算是记录自己成长的步伐吧 我首次用mysql是在ubuntu上 ,现在用的是linux 中的R ...

  4. 关于数据库管理系统DBMS--关系型数据库(MySQL/MariaDB)

    数据库的结构(3种):层次,网状,关系型(用的最多): DBMS的三层模型: 视图层:面向最终用户: 逻辑层:面向程序员或DBA: 物理层:面向系统管理员: 关系型数据库管理系统——RDBMS: 主要 ...

  5. Linux-基础学习(五)-mariadb主从复制以及redis学习

    开始今日份整理 1.mariadb的主从复制 主从复制大致图示: 1.1 mysql基本命令复习 linux下的操作 .启动mysql systemctl start mariadb .linux客户 ...

  6. Mariadb主从复制

    前戏: mysql的基本命令复习 .启动mysql systemctl start mariadb .linux客户端连接自己 mysql -uroot -p -h 127.0.0.1 .远程链接my ...

  7. linux --mariadb/redis数据库篇

    mariadb ---磁盘型数据库 基础安装 配置好yum源后,软件就可以通过配置的yum源进行安装,按理来讲安装mysql直接通过   yum install mariadb  -y  便可安装,但 ...

  8. Linux(5)- MariaDB、mysql主从复制、初识redis

    一.MYSQL(mariadb) MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可. 开发这个分支的原因之一是:甲骨文公司收购了MySQL后,有将MySQL ...

  9. Linux--5 mariadb和redis的安装

    一.MYSQL(mariadb) MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可. 开发这个分支的原因之一是:甲骨文公司收购了MySQL后,有将MySQL ...

随机推荐

  1. 第五周课程总结&实验报告(四)

    第五周课程总结 本周主要学习了 1.抽象类 抽象类的定义格式 abstract class抽象类名称{ 属性; 访问权限返回值类型方法名称(参数){ //普通方法 [return返回值]; } 访问权 ...

  2. Design HashMap

    Design a HashMap without using any built-in hash table libraries. To be specific, your design should ...

  3. 【Python】【demo实验28】【练习实例】【递归函数练习】

    原题: 有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁.问第4个人岁数,他说比第3个人大2岁.问第三个人,又说比第2人大两岁.问第2个人,说比第一个人大两岁.最后问第一个人,他说是10岁.请 ...

  4. (5.3.2)数据库迁移——SSIS包批量导出

    SSIS连接出错 原因 :    ssms 工具 不是 admin 权限 打开的  SSIS包批量导出代码 use msdb go IF OBJECT_ID('msdb.dbo.usp_ExportS ...

  5. vue 简易学习

    好记性不如烂笔头 最近公司新出一个框架,采用的是前后端分离的开发方式,后端用的是springboot+mybatis(还有额外的zk.缓存.日志等待),前端采用的是vue+es6,由于以前对vue只知 ...

  6. ubuntu上安装及使用docker

    关于Docker: Docker 是一个开源项目,为开发者和系统管理员提供了一个开放的平台,在任何地方通过打包和运行应用程序作为一个轻量级的容器.Docker 在软件容器内自动部署应用程序.Docke ...

  7. php 取post数据的三种方式

    $_POST.$GLOBALS['HTTP_RAW_POST_DATA'].file_get_contents("php://input") 都有用来取post数据,用下来感觉大致 ...

  8. 随便----js参考书

    一.Javascript方面的书籍: 1 JavaScript权威指南(第6版):号称javascript圣经,前端必备:前端程序员学习核心JavaScript语言和由Web浏览器定义的JavaScr ...

  9. 谁是嫌疑犯问题Python枚举法

    原文:https://blog.csdn.net/yunzifengqing/article/details/81941592 问题描述:有6名犯罪嫌疑人A.B.C.D.E.F,已知如下事实: A.B ...

  10. Oracle学习笔记:一个简单的行转列例子

    一个简单的行列转换例子,原始数据. create table temp_cwh_student ( name ), subject ), score ) ) select * from temp_cw ...