MySQL学习——基础
本文是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学习——基础的更多相关文章
- MySQL学习基础 之 起航篇
MySQL 学习来自慕课网<与MySQL的零距离接触> MySQL是一个开源的关系型数据库管理系统 MySQL分为社区版和企业版 MySQL登录和退出相关的命令 参数 描述 -D,--da ...
- MySQL学习基础
MySQL是被Sun公司收购了,所以也有热咖啡图标,不过MySQL的作者后来又做了一个MariaDB,小海豚图标,也很好用. MySQL学习: <MySQL网络数据库设计与开发>(电子工业 ...
- MySQL学习基础知识1
什么是数据库? 数据库就是存储数据的仓库. 存储方式: 变量 无法永久存储 文件处理,可以永久存储,弊端:文件只能在自己的计算机读写,无法被分享(局域网除外) 数据库分类: 1.关系型数据库 提供某种 ...
- MySQL学习基础知识2
1.基础语句 查 select(* | 字段名 | 四则运算 | 聚合函数) from 表名称; 加上as取别名 as可省略 如:select name, (math+english)/2 total ...
- Mysql学习---基础操作学习2
基本数据类型 Mysql基本数据类型:二进制,数值[整数,小数].字符串[定长,变长]. 二进制数据.时间和枚举集合 bit[(M)] 二进制位(101001),m表示二进制位的长度(1-64),默认 ...
- Mysql学习基础语法
-- Mysql 数 据 库 语 法 创建数据库 create database 数据库名; 创建表 ) ); 复制表和数据 create table 复制后新的表名 select * from 旧表 ...
- mysql学习基础知识3
1.视图 简化sql语句的编写,限制可以查看的数据 一张虚拟的表,不占任何内存,查视图时都是临时从所查的表中拿数据 特点: 对于视图的增删改查 都会同步到原始表 对原始表的修改,会同步到视图内可查看的 ...
- Mysql学习---基础操作学习
1.1. 基本操作 数据库引擎 Inodb:支持事务[原子性操作,完成一些列操作后才算完成操作,否则rollback] MyISAM: 支持全文索引,强调了快速读取操作,主要用于高负载的select ...
- 借助node.js + mysql 学习基础ajax~
很多小白不知道ajax怎么学,所以就弄了个node后台模拟下基本的ajax请求. 环境要求是安装node~ 先上linkMysql.js var mysql = require('mysql') va ...
随机推荐
- Apache服务配置
Apache 1.安装Apache服务 第1步:把光盘设备中的系统镜像挂载到/media/cdrom目录. [root@zhangjh ~]# mkdir -p /media/cdrom/ [root ...
- Hive LanguageManual DDL
hive语法规则LanguageManual DDL SQL DML 和 DDL 数据操作语言 (DML) 和 数据定义语言 (DDL) 一.数据库 增删改都在文档里说得也很明白,不重复造车轮 二.表 ...
- 关于学习less后一些感悟
学习了一天的less发现,自己被自己弄的晕头转向,好在是学明白了! 一.写自己的第一个less css样式编程: 网址:http://www.1024i.com/demo/less/document. ...
- python lamba表达式
lambda函数也叫匿名函数,即,函数没有具体的名称. g=lambda x:x**2 def f(x): return x**2 lambda语句中,冒号前是参数,可以有多个,用逗号隔开,冒号右边是 ...
- 《Cracking the Coding Interview》——第16章:线程与锁——题目2
2014-04-27 19:14 题目:如何测量上下文切换的时间? 解法:首先,上下文切换是什么,一搜就知道.对于这么一个极短的时间,要测量的话,可以通过放大N倍的方法.比如:有A和B两件事,并且经常 ...
- 【NOIP 2017 提高组】列队
题目 有一个 \(n\times m\) 的方阵,每次出来一个人后向左看齐,向前看齐,询问每次出来的人的编号. \(n\le 3\times 10^5\) 分析 我们考虑离队本质上只有两种操作: 删除 ...
- centos6系列问题
一.NetworkManager启动问题 1.由于以后要支持e1000版虚拟化网卡,所有centos6镜像均按照NetworkManager服务,并设置开机自启动 2.虚机启动时,默认是Network ...
- 剑指offer-重建二叉树04
题目描述 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7, ...
- Python-map、filter、reduce方法
介绍 1.map()函数,会让列表中每一个元素都执行一某个函数(传递1个参数), 并且将执行函数返回的结果(无论是什么结果)放在结果列表中 2.filter()函数,会让列表中的每一个元素都执行一次某 ...
- Linux大小端模式转换函数
转自 http://www.cnblogs.com/kungfupanda/archive/2013/04/24/3040785.html 不同机器内部对变量的字节存储顺序不同,有的采用大端模式(bi ...