一、通用语法

1、MySQL数据库的SQL语句不区分大小写

2、可以用/**/完成注释

3、常用数据类型

类型 描述
int 整型
double 浮点型
varchar 字符串型
date 日期类型,格式为yyyy-mm-dd,只有年月日没有时分秒

二、数据库操作

1、创建数据库

CREATE DATABASE 数据库名;
e.g
CREATE DATABASE hospital;

2、查看数据库

①查看数据库MySQL服务器中所有数据库

SHOW DATABASES;
/*查看数据库MySQL服务器中所有数据库*/

②查看某个数据库定义的信息

SHOW CREATE DATABASE 数据库名;

e.g
SHOW CREATE DATABASE hospital;

3、删除数据库

DROP DATABASE 数据库名;
e.g
DROP DATABASE hospital;

4、切换数据库

USE 数据库名;
e.g
USE hospital;

三、表操作

1、创建表

CREATE TABLE 表名(
字段名 类型(长度) 约束,
字段名 类型(长度) 约束,
); e.g
CREATE TABLE doctor(
id INT PRIMARY KEY,
name VARCHAR(20) NOT NULL,
);

2、查看表

①查看数据库中的所有表

SHOW TABELS;

②查看表结构

DESC 表名;
e.g
DESC doctor;

3、删除表

DROP TABLE 表名;
e.g
DROP TABLE doctor;

4、修改表

①添加列

ALTER TABLE 表名 ADD 列名 类型(长度) 约束;
e.g
ALTER TABLE doctor ADD title VARCHAR(20);
/*给医生表添加职称字段*/

②修改列类型长度及约束

ALTER TABLE 表名 MODIFY 列名 类型(长度) 约束
e.g
ALTER TABLE doctor MODIFY title VARCHAR(50) NOT NULL;

③修改列名

ALTER TABLE 表名 CHANGE 旧列名 新列名 类型(长度) 约束;
e.g
ALTER TABLE doctor CHANGE title doctitle VARCHAR(30);

④删除列

ALTER TABLE 表名 DROP 列名;
e.g
ALTER TABLE doctor DROP title;

⑤修改表名

RENAME TABLE 表名 to 新表名;
e.g
RENAME TABLE doctor to nurse;

四、数据操作

1、增加数据

INSERT INTO 表名 [(字段列表)] VALUES (值列表);
e.g
INSERT INTO doctor VALUES('001', '张三', '主治医师');

如果遇到主键冲突(即插入数据时,主键对应的值已经存在),可以选择更新或替换。

①更新

INSERT INTO 表名[(字段列表:包含主键)] VALUES(值列表) DUPLICATE KEY UPDATE  字段 = 新值;
e.g
/*假如说表中001已经是张三医生了,我现在要改成李四*/
INSERT INTO doctor VALUES('001', '李四', '实习医生') DUPLICATE KEY UPDATE name = '李四';

②替换

REPLACE INTO 表名 [(字段列表:包含主键)] VALUES(值列表);
e.g
REPLACE INTO doctor VALUES('001', '李四', '实习医生');

2、更新数据

UPDATE 表名 SET 字段 = 值 [WHERE条件][LIMIT更新数量];
e.g
/*把职称是实习医生的前三个人改成主治医师*/
UPDATE doctor SET tilte = '主治医师' WHERE title = '实习医生' LIMIT 3;

3、删除数据

DELETE FROM 表名 [WHERE条件][LIMIT数量];
e.g
/**/
DELETE FROM 表名 WHERE title = '实习医生' LIMIT 10;

4、查询数据

SELECT 字段列表/(*所有字段) FROM 表名 [WHERE条件]

①去重

DISTINCT

②WHERE子句

比较运算符: >, <, >=, <= ,!= ,<>, =, like, between and, in/not in

逻辑运算符: &&(and), ||(or), !(not)

③分组

GROUP BY 字段名

分组即根据某个字段进行分组(相同的放一组,不同的分到别的组,主要是为了统计数据),以下是数据统计函数:

COUNT():统计分组后的记录数,每一组有多少记录
MAX():统计每组的最大值
MIN():统计最小值
AVG():统计平均值
SUM():统计和

分组条件判断需要用:

HAVING

④排序

ORDER BY 字段名 [ADC|DESC];
/*ADC升序(默认),DESC降序*/

⑤限制数量

LIMIT 数据量;
/*只用来限制长度*/ LIMIT 起始位置, 长度;
/*限制起始位置和数量*/

五、连接查询

1、内连接:组合两个表中的记录,返回关联字段相符的记录。

左表 [INNER]JOIN 右表 ON 左表.字段 = 右表.字段;
e.g
dector AS dc INNER JOIN department dp ON dc.id = dp.id;

如果没有ON的话系统会保留所有结果,即两个表的笛卡尔积。

2、左外连接:左表的记录会全部显示出来,右表只会显示符合搜索条件的记录,右表记录不足的地方均为NULL。

左表 LEFT JOIN 右表 ON 左表.字段 = 右表.字段;
e.g
dector AS dc LEFT JOIN department dp ON dc.id = dp.id;

3、右外连接:左表只会显示符合搜索条件的记录,右表的记录将全部显示,左表记录不足的地方均为NULL。

左表 RIGHT JOIN 右表 ON 左表.字段 = 右表.字段;
e.g
dector AS dc RIGHT JOIN department dp ON dc.id = dp.id;

六、视图

视图是一种有结构(有行有列)但没有结果(结构中不真实存放数据)的虚拟表,虚拟表的结构来源不是自己定义,而是从对应的基表中产生(视图的数据来源)。使用视图主要为了查询,所以把视图当做表一样查询即可。

CREATE VIEW 视图名字 AS SELECT语句

1、查看视图

DESC 视图名字;

2、使用视图

直接把视图当做表一样查询即可

3、修改视图

视图本身不可修改,但视图的来源可以修改。

ALTER VIEW 视图名 AS 新的SELECT语句

4、删除视图

DROP VIEW 视图名

MySQL语法基础的更多相关文章

  1. 学习mysql语法--基础篇(一)

      前  言  mysql  mysql语法--本篇学习都是通过使用Navicat Premium(数据库管理工具),连接mysql数据. 本篇学习主要有两个部分:    一.创建用户,创建数据库,给 ...

  2. 学习mysql语法--基础篇(二)

      前  言  mysql  mysql语法--本篇学习都是通过使用Navicat Premium(数据库管理工具),连接mysql数据. 本篇学习主要有两个部分: [SQL语句的组成]   DML ...

  3. 2019-10-10:渗透测试,基础学习,mysql语法基础,笔记

    mysql常用命令mysql -u用户名 -p,登录方式也称为,二进制方式exit 退出mysql 查看mysql版本select version(); 查看mysql所有数据库show dateba ...

  4. MySQL:基础语法-4

    MySQL:基础语法-4 记录一下 MySQL 基础的一些语法,便于查询,该部分内容主要是参考:bilibili 上 黑马程序员 的课程而做的笔记,由于时间有点久了,课程地址忘记了 上文MySQL:基 ...

  5. MySQL:基础语法-3

    MySQL:基础语法-3 记录一下 MySQL 基础的一些语法,便于查询,该部分内容主要是参考:bilibili 上 黑马程序员 的课程而做的笔记,由于时间有点久了,课程地址忘记了 上文MySQL:基 ...

  6. MySQL:基础语法-2

    MySQL:基础语法-2 记录一下 MySQL 基础的一些语法,便于查询,该部分内容主要是参考:bilibili 上 黑马程序员 的课程而做的笔记,由于时间有点久了,课程地址忘记了 上文MySQL:基 ...

  7. MySQL:基础语法-1

    MySQL:基础语法-1 记录一下 MySQL 基础的一些语法,便于查询,该部分内容主要是参考:bilibili 上 黑马程序员 的课程而做的笔记,由于时间有点久了,课程地址忘记了 关于数据库的安装操 ...

  8. mongodb linux基本启动 基础增删改 mysql语法的对比

    一.主流数据源类型 还存在自定义数据源以及REST接口数据,共6中数据源. 二.linux下启动连接数据库 进去mongodb的目录启动服务:mongo --host 192.168.320.826 ...

  9. MySQL数据库基础

    MySQL数据库基础 本文的所有操作是基于CMD环境,MySQL通过在命令行中输入SQL语句对数据库进行操作.配置问题可参考<打通MySQL的操作权限>中的内容,该文算是针对前期的环境配置 ...

随机推荐

  1. 洛谷p1725 露琪诺 单调队列优化的DP

    #include <iostream> #include <cstdio> #include <cstring> using namespace std; int ...

  2. MDK5生成BIn文件的方法

    配置MDK5 生成bin文件的 第一步:方法打开option for Target 第二步:选择 user 第三步:找到After Build/Rebuild 第四步:勾选run,点击文件选择小图标选 ...

  3. NoSQL 数据库案例实战 -- MongoDB数据备份、恢复

    MySQL数据迁移到MongoDB数据库中 前言 一.数据备份 二.数据恢复 前言 本环境是基于 Centos 7.8 系统构建mongodb-enterprise-4.2.8学习环境具体构建,请参考 ...

  4. Monorepo All In One

    Monorepo All In One monorepos 只是一种思想,或设计模式,架构风格 https://trunkbaseddevelopment.com/monorepos/ Lerna h ...

  5. 字节跳动-前端面试题 Multi Promise Order

    字节跳动-前端面试题 Multi Promise Order Promise Order Async/Await async function async1 () { console.log('asy ...

  6. user tracker with ETag

    user tracker with ETag 用户追踪, without cookies clear cache bug 实现原理 HTTP cache hidden iframe 1px image ...

  7. eyes protect app

    eyes protect app https://awaremac.com/

  8. Electron in Action

    Electron in Action $ yarn add -D electron@latest # OR $ npm i -D electron@latest https://www.electro ...

  9. taro external-class

    taro external-class https://nervjs.github.io/taro/docs/component-style.html externalClasses child co ...

  10. 伦尼斯酒庄(Chateau Renice)再次赞助亚洲50大餐厅赛事

    连续几年来,伦尼斯酒庄(Chateau Renice)一直是亚洲50大最佳餐厅评选赛(Asia's 50 Best Restaurant Awards)的赞助商.2020年伦尼斯酒庄酒庄(Chatea ...