本文是MySQL的基础知识。

Linux启动MySQL服务命令 :

  service mysql start

Linux关闭MySQL服务命令 :

  service mysql stop

登录MySQL命令:

  mysql -u <用户名>

查看数据库命令:

  show databases;

切换数据库命令:

  use <数据库名>[;]

查看表命令:

  show tables;

退出MySQL命令:

  quit/exit

创建数据库命令:

  create database <数据库名>;

新建数据表命令:

  create table <表名>

  (列名1   数据类型(数据长度),

    …………

   列名n   数据类型(数据长度)

  );

执行sql文件命令:

  source  <sql文件路径>;

MySQL数据类型

数据类型 大小(字节) 用途 格式
int 4 整数  
float 4 单精度浮点数  
double 4 双精度浮点数  
enum   枚举,单选 ENUM('a','b')
set   多选 set('1','2','3')
date 3 日期 yyyy-MM-dd
time 3 时间点或持续时间 yyyy-MM-dd hh:ms:ss
year 1 年份值 yyyy
char 0-255 定长字符串  
varchar 0-255 变长字符串  
text 0-65535 长文本数据  

  除此之外,还有tinyint、smallint、mediumint、bigint.

char与varchar区别:

  char定长,字符不够时补齐;varchar变长,没有补齐的空字符

enum与set区别:

  enum定义时要一一枚举;set是多选的

MySQL约束分类:

约束类型 主键 默认值 唯一 外键 非空
关键字 PRIMARY KEY DEFAULT UNIQUE FOREIGN KEY NOT NULL

主键约束命令:

  <列名>  <数据类型>[数据长度]  PRIMARY KEY

  或者

  CONSTRAINT  <主键名>  PRIMARY KEY (<列名1>,…,<列名n>)

默认值约束命令:

  <列名>  <数据类型>[数据长度]  DEFAULT  <默认值>

唯一约束命令:

  UNIQUE  <(列名)>

外键约束命令:

  CONSTRAINT  <外键>  FOREIGN  KEY  <(列名)>  REFERENCES  <表名><(列名)>

非空约束命令:

  <列名>  <数据类型>[数据长度]  NOT NULL

插入数据命令:

  insert  into  <表名>(<列名1>,…,<列名n>)  values

  (值1,…,值n),

  …………

  (值1,…,值n);

删除库命令:

  drop  database  <库名>;

删除表命令:

  drop  table  <表名>;

查询命令:

  select  <列名n>  from  <表名>  where <限制条件>;

数学符号条件:

  =  <  >  <=  >=  <>  !=

AND  并且

OR   或者

BETWEEN  ......  AND  ......   两者之间

IN 在范围内

NOT  IN  不在范围内

通配符:

  _(下划线) : 代表一个未指定字符,占一位

  % :代表不定个未指定字符

  与 like 配合使用

结果排序:

  order  by  [<关键字>];

    ASC  : 升序(默认)

    DESC  : 降序

内置函数:

count sum avg max min
计数 求和 求平均值 最大值 最小值

  count 可以用于任意数据类型; sum和avg 用于数字类数据类型;max和min 用于数值、字符、日期时间类型

AS : 别名

子查询

  嵌套查询

连接查询命令

  jion … on …

  左连接(影响右表) : left  jion … on …

  右连接(影响左表) : right  jion … on …

  左右都有影响的连接 : inner  jion … on …

表重命名命令

  rename  table  <表原名>  to  <表新名>;

  alter  table  <表原名>  rename  <表新名>;

  alter  table  <表原名>  rename  to  <表新名>;

增加列命令

  alter  table  <表名>  add [column] <列名>  <数据类型>  <约束>;

  或者  alter  table <表名> add <列名> <数据类型> <约束>;

删除列命令

  alter table <表名> drop [column] <列名>;

列重命名命令

  alter table <表名> change <列原名>  <列新名>  <数据类型> <约束>;

修改数据类型命令

  alter table <表名> modify <列名> <新数据类型>;

修改值命令

  update <表名> set 列1=值1,…,列n=值n where <条件>;

删除行记录命令

  delete from <表名> where <条件>;

创建索引命令

  alter  table  <表名>  add  index  <索引名>(<列名>);

  或者 create  index  <索引名>  on  <表名>(列名);

查看索引命令

  show  index  from  <表名>;

创建视图命令

  create  view  <视图名>(列1,…,列n) as select 列1,…,列n from  <表名>;

导入命令

  将一个文件的数据导入到一张数据表里

  load  data  infile  <'文件路径和文件名'>  into  table  <表名>;

导出命令

  把某表中的数据保存到文件中

  select  列1,…,列n  into  outfile  <'文件路径和文件名'>  from  <表名>;

数据库备份命令

  mysqldump  -u  <用户名,如root>  <数据库名> > <文件路径和文件名>;

数据表备份命令

  mysqldump  -u  <用户名,如root>  <数据库名>  <表名> > <文件路径和文件名>;

数据恢复命令

  source  <文件路径和文件名>;

  或者 mysql  -u  <用户名,如root>  <数据库名>  <  <文件路径和文件名>;

MySQL学习——基础的更多相关文章

  1. MySQL学习基础 之 起航篇

    MySQL 学习来自慕课网<与MySQL的零距离接触> MySQL是一个开源的关系型数据库管理系统 MySQL分为社区版和企业版 MySQL登录和退出相关的命令 参数 描述 -D,--da ...

  2. MySQL学习基础

    MySQL是被Sun公司收购了,所以也有热咖啡图标,不过MySQL的作者后来又做了一个MariaDB,小海豚图标,也很好用. MySQL学习: <MySQL网络数据库设计与开发>(电子工业 ...

  3. MySQL学习基础知识1

    什么是数据库? 数据库就是存储数据的仓库. 存储方式: 变量 无法永久存储 文件处理,可以永久存储,弊端:文件只能在自己的计算机读写,无法被分享(局域网除外) 数据库分类: 1.关系型数据库 提供某种 ...

  4. MySQL学习基础知识2

    1.基础语句 查 select(* | 字段名 | 四则运算 | 聚合函数) from 表名称; 加上as取别名 as可省略 如:select name, (math+english)/2 total ...

  5. Mysql学习---基础操作学习2

    基本数据类型 Mysql基本数据类型:二进制,数值[整数,小数].字符串[定长,变长]. 二进制数据.时间和枚举集合 bit[(M)] 二进制位(101001),m表示二进制位的长度(1-64),默认 ...

  6. Mysql学习基础语法

    -- Mysql 数 据 库 语 法 创建数据库 create database 数据库名; 创建表 ) ); 复制表和数据 create table 复制后新的表名 select * from 旧表 ...

  7. mysql学习基础知识3

    1.视图 简化sql语句的编写,限制可以查看的数据 一张虚拟的表,不占任何内存,查视图时都是临时从所查的表中拿数据 特点: 对于视图的增删改查 都会同步到原始表 对原始表的修改,会同步到视图内可查看的 ...

  8. Mysql学习---基础操作学习

    1.1. 基本操作 数据库引擎 Inodb:支持事务[原子性操作,完成一些列操作后才算完成操作,否则rollback] MyISAM: 支持全文索引,强调了快速读取操作,主要用于高负载的select ...

  9. 借助node.js + mysql 学习基础ajax~

    很多小白不知道ajax怎么学,所以就弄了个node后台模拟下基本的ajax请求. 环境要求是安装node~ 先上linkMysql.js var mysql = require('mysql') va ...

随机推荐

  1. SAP(ABAP):STOP,EXIT,CHECK,RETURN,REJECT,CONTINUE

    Stop 命令使用该命令的程序位置INITIALIZATION, AT SELECTION-SCREEN, START-OF-SELECTION和GET 事件中处理说明1. 当在INITIALIZAT ...

  2. Hibernate---实体类注释简介

    1.类级别注解 @Entity:映射实体类 @Entity(name="tableName") - 必须,注解将一个类声明为一个实体bean. 属性: name - 可选,对应数据 ...

  3. 虚拟机中如何挂载物理磁盘(VMware操作)

    测试的时候难免会遇到,从真是机器拷贝东西到虚拟机中,虽说安装了VMware tools(Vm→Install VMware tools...),就可以将文件直接拖到虚拟机里面去,但是这样拷贝总是需要花 ...

  4. [转]多多“亦”善:把大量内容放到一页PPT的5个技巧

    技巧一:利用灰色“隐蔽”内容 灰色有个好处:自动成为“备胎”,在“现任”被浏览后才会被注意到.所以使用灰色能够让页面内容看起来没那么多. 技巧二:对齐和亲密 这是排版的两个原则. 对齐是指对页面上的元 ...

  5. 如何创造财富?硅谷创业之父 Paul Graham 《黑客与画家》思维导图

    先送上亚马逊传送门:<黑客与画家>:硅谷创业之父 Paul Graham 文集 再送上一个思维导图: 下载大图:http://caifujianghu.com/article/ruhe-c ...

  6. [译]12-spring依赖注入

    每个java应用程序都是由多个类协作才最终生成了终端用户所使用的系统.当编写复杂java应用程序的时,类之间应尽 可能保持独立,因为这样更容易做到代码的重用,也有利于单元测试的开展.spring的依赖 ...

  7. windows auto activate

    目前所支持的windows镜像都是未激活状态,未激活状态下很多功能无法使用. 以后将要实现的功能是,windows虚机启动后,网络正常后能与KMS服务器通信,自动激活key 目前想到两种办法: 1.b ...

  8. python作业:购物车(第二周)

    一.作业需求: 1.启动程序后,输入用户名密码后,如果是第一次登录,让用户输入工资,然后打印商品列表 2.允许用户根据商品编号购买商品 3.用户选择商品后,检测余额是否够,够就直接扣款,不够就提醒 4 ...

  9. 【操作系统】关于C语言设计程序退出自动关闭窗口的问题

    有些同学在做实验一 命令解释程序的编写的时候,输入quit命令退出程序,窗口并没有关闭,如下图所示需要Press any key to continue(按任意键)之后才关闭. 出现这个结果的原因是在 ...

  10. 学习go语言第一天

    今天先下载了go语言,FQ去下载的,一开始想用eclipse,然后下载了go插件,结果出现错误,我英语水平有限,就换了liteIDE,感觉还不错,go语言环境变量因为我是msi安装的,好像可以不用自己 ...