本文是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. 笔记-scrapy-Request/Response

    笔记-scrapy-Request/Response 1.     简介 Scrapy使用Request和Response来爬取网站. 2.     request class scrapy.http ...

  2. linpack_2

    Run linpack in server 1.Get computer nodal information lscpu dmidecode -t memory | head -45 | tail - ...

  3. Android Config通用类来记录信息

    1.整体分析 1.1.源代码,可以直接Copy. public class Config { private static int M = 1024 * 1024; private volatile ...

  4. PHP.TP框架下商品项目的优化2-图片优化

    图片存储.上传.显示优化 1.图片路径写进配置文件,当路径有变动时[因业务扩大,服务器存储图片空间不足等],只需修改配置文件,而不用修改代码 2.封装显示.上传.删除函数,实现代码重用 [可类比其他类 ...

  5. unity2D技术学习与整理

    目前有关unity2D的教程以及原理几乎都是国外的.我在这方面也是新手,看了一些例子有很多不懂的地方. 这个网站提供的教程很有参考价值 http://brackeys.com/ 还有这个 http:/ ...

  6. 了解JavaScript核心精髓(四)

    ES6 1.import与require区别 import 是同步导入js模块. require 是异步导入js模块. 2.使用let与const let con1 = 3 //与var作用相似,le ...

  7. sweetalert : 一个比较好看的弹出框

    1.引入 <script src="https://unpkg.com/sweetalert/dist/sweetalert.min.js"> </script& ...

  8. 2.0 python+appium环境搭建

    Python下载地址:链接:https://pan.baidu.com/s/1Z3H8tw8AiBVwpxdcABC7XQ 密码:z66t Pycharm下载地址: 链接:https://pan.ba ...

  9. Linux认知之旅【04 进一步了解目录】!

    一.目录是什么? 二.不得不提的文件系统! 三.绝对路经,相对路径

  10. create vm

    #!/bin/sh echo $# [ $# < ] && { echo "error" exit } instance_name=$ instance_ip ...