一、 数据库及对象

1、系统数据库

  • infomation_schema: 存放数据库对象信息,表信息、列信息,权限信息
  • performance_schema: 数据库服务器性能参数
  • mysql: 用户权限信息
  • sys : mysql5.7增加了sys 系统数据库,通过这个库可以快速的了解系统的元数据信息

2、操作

- 创建数据库 :  create database learn;
- 查询数据库 :  show databases;
- 选择数据库 :  use learn;
- 删除数据库 :  drop database learn;

二、 引擎与数据类型

1、引擎

查看引擎:show engines ; -- show engines G

  • Transactions: 是否支持事务
  • XA: YES 分布式是否符合XA规范
  • Savepoints: 是否支持事务处理中的保存点

2、数据类型

- 整数类型 :- tinyint- smallint- mediumint- int,integer- bigint
- 浮点 : - float- double
- 定点数类型 :- decimal->字符串存储- dec
- 日期 :- date 4字节- datetime 8字节- timestamp 4- time 3- year 1
- 字符串:- char 4- varchar 可变0~65535- tinytext -> text -> mediumtext -> longtext- tinyblob -> blob -> mediumblob -> longblob

三、 表操作

CREATE TABLE t_dept (dept_no   INT,dept_name VARCHAR(40),location  VARCHAR(80)
);
##描述表结构
desc t_dept;
## 查看创建语句
show create table t_dept;
##删除表
drop table t_dept;
##修改表名
alter table t_dept rename to t_deptartment;##增加字段
alter table t_deptartment add dept_name_us VARCHAR(40);
##第一个位置增加字段
alter table t_deptartment add first_col VARCHAR(40) first;
## 某列后面添加字段
alter table t_deptartment add after_dept_name VARCHAR(80) after dept_name;
## 删除字段
alter table t_deptartment drop first_col;
##修改字段 数据类型
alter TABLE t_deptartment MODIFY after_dept_name VARCHAR(100);
## 修改字段名字 可以一同修改字段属性
ALTER TABLE t_deptartment CHANGE after_dept_name dept_name_after VARCHAR(10);

四、约束

##创建表的时候直接加入约束
CREATE TABLE t_dept (dept_no   INT(20) PRIMARY KEY NOT NULL, ##  非空约束type      VARCHAR(20) DEFAULT 'Co., Ltd', ##默认值dept_name VARCHAR(100) UNIQUE ##唯一值
);
desc t_dept  ;##创建有名字的约束值
CREATE TABLE t_dept (dept_no   INT(20) AUTO_INCREMENT, ##自增type      VARCHAR(20),dept_name VARCHAR(100), CONSTRAINT uk_dept_name UNIQUE (dept_name), ##唯一值CONSTRAINT pk_dept_no PRIMARY KEY (dept_no) ##一个字段主键
);## 联合主键
CREATE TABLE t_dept1 (dept_no   INT(20) AUTO_INCREMENT, ##自增type      VARCHAR(20),dept_name VARCHAR(100), ##唯一值CONSTRAINT uk_dept_name1 UNIQUE (dept_name), ##唯一值CONSTRAINT pk_dept_no_name1 PRIMARY KEY (dept_no, dept_name) ##联合主键
);#外键
CREATE TABLE t_employee (emp_no int(30) PRIMARY KEY,emp_name VARCHAR(20),dept_no  INT(20),CONSTRAINT fk_dept_no FOREIGN KEY (dept_no) REFERENCES t_dept(dept_no)
);desc t_employee;

五、索引

1.索引类型

普通索引,唯一索引,全文索引,单列索引,多列索引,空间索引

适用: 经常被查询的字段,分组字段,主键或者外键。唯一完整性约束

不适用: 很少查询;拥有许多重复值的字段

2.语句
#普通索引
CREATE TABLE t_dept_2 (dept_no   INT,dept_name VARCHAR(20),loc       VARCHAR(40),INDEX index_dept_no(dept_no)
);SHOW CREATE TABLE t_dept_2;
## 查看解析计划
EXPLAIN SELECT *FROM t_dept_2WHERE dept_no = 1;## 单独创建索引
CREATE INDEX idx_dept_nameON t_dept_2 (dept_name);ALTER TABLE t_dept_2ADD INDEX idx_loc(loc DESC);## 唯一索引
CREATE TABLE t_dept_3 (dept_no INT UNIQUE,UNIQUE INDEX idx_dept_no(dept_no)
);
CREATE UNIQUE INDEX idx_dept_nameON t_dept_2 (dept_name);
ALTER TABLE t_dept_2ADD UNIQUE INDEX idx_loc(loc);##全文索引
####默认不区分大小写,只能在数据类型char,varchar,text上创建
CREATE TABLE t_dept_4 (dept_no   INT,dept_name VARCHAR(20),FULLTEXT INDEX idx_dept_no (dept_name)
);
CREATE FULLTEXT INDEX idx_dept_nameON t_dept_2 (dept_name);
ALTER TABLE t_dept_2ADD FULLTEXT INDEX idx_loc(loc);##多列索引
CREATE TABLE t_dept_5 (dept_no   INT,dept_name VARCHAR(20),INDEX idx_dept_no (dept_no, dept_name)
);
CREATE INDEX idx_dept_nameON t_dept_2 (dept_name);
ALTER TABLE t_dept_2ADD INDEX idx_loc(loc);##删除索引
DROP INDEX idx_loc
ON t_dept_2;

六、视图

###创建视图
CREATE VIEW view_dept_no ASSELECT dept_noFROM t_dept;select * from t_dept;
insert into t_dept (dept_no, dept_name) VALUES (1,'ccdata');select * from view_dept_no ;#查看view
show tables;
show table status from learn like 'view_dept_no';
use information_schema;
select * from views where table_name = 'view_dept_no' \G;##删除view
drop view view_dept_no;##修改视图
CREATE OR REPLACE VIEW view_dept_nameASSELECT dept_nameFROM t_dept;ALTER VIEW view_dept_name ASSELECTdept_no,dept_nameFROM t_dept;select * from   view_dept_name;
SELECT *
FROM t_dept;##对视图的操作
insert into view_dept_name VALUES (2,'apple');
UPDATE view_dept_name set dept_name = 'Google' WHERE dept_no = 2;
delete from view_dept_name WHERE dept_no = 1;

七、触发器

## 语句
CREATE TRIGGER TRIGGER_NAMEBEFORE | AFTER TRIGGER_EVENTON TABLE_NAME FOR EACH ROW TRIGGER_STMT## before|after 制定触发器触发的时间
## trigger_event 触发的事件(条件)
## for each row 每行改变都触发
## trigger_stmt 触发的语句##准备
CREATE TABLE department (no       INT(12),name     VARCHAR(40),location VARCHAR(60)
);CREATE TABLE diary (diary_no   INT(12) AUTO_INCREMENT PRIMARY KEY,table_name VARCHAR(50),diary_time DATETIME
);## 创建触发器
CREATE TRIGGER trigger_diary_time
BEFORE INSERT ON department
FOR EACH ROWINSERT INTO diary (table_name, diary_time) VALUES ('department', now());## 测试
INSERT INTO department VALUES (1, 'apple', 'Peking');
SELECT * FROM diary;## 触发器中包含多个语句
CREATE TRIGGER trigger_diary_time
BEFORE INSERT ON department
FOR EACH ROWBEGININSERT INTO diary (table_name, diary_time) VALUES ('department', now());INSERT INTO diary (table_name, diary_time) VALUES ('department2', now());END;## 创建多个语句时候,书上说;可能被当做结束符?(没碰到这种情况)
DELIMITER $$
CREATE TRIGGER trigger_diary_time
BEFORE INSERT ON department
FOR EACH ROWBEGININSERT INTO diary (table_name, diary_time) VALUES ('department', now());INSERT INTO diary (table_name, diary_time) VALUES ('department2', now());END;
$$
DELIMITER ;## 查看
SHOW TRIGGERS;USE information_schema;
SELECT * FROM TRIGGERS;##删除
DROP TRIGGER trigger_diary_time;

八、数据操作

##插入数据
INSERT INTO t_dept_2 (dept_no, dept_name, loc) VALUES ('1', 'apple', 'Peking');
INSERT INTO t_dept_2 (dept_no, dept_name) VALUES ('2', 'Google');
INSERT INTO t_dept_2 VALUES ('3', 'Amazon', 'USA');## 插入多个值
INSERT INTO t_dept_2 VALUES('4', 'Tencent', 'Guangzhou'),('5', '网易', '杭州'),('6', '饿了吗', '北京');## 别的表转移
INSERT INTO t_dept_2 (dept_name)SELECT dept_nameFROM t_deptartment;##### 更新
UPDATE T_DEPT_2 SET LOC= '美国' WHERE DEPT_NAME = 'GOOGLE';##### 删除
delete from t_dept_2 WHERE dept_no = 6;

九、记录查询

## 去重复
SELECT DISTINCTDEPT_NAME,LOC
FROM T_DEPT_2;## 数学运算
CREATE TABLE employee (no     INT(10),name   VARCHAR(20),salary DOUBLE(10, 2)
);INSERT INTO employee VALUES(1, 'a', 1234),(2, 'b', 2500),(3, 'c', 3600),(4, 'd', 4500),(5, 'e', 7800);SELECTname,salary + 100,salary - 200,salary * 1.2,salary / 1000,salary % 1000
FROM employee;
关系运算符

| 大于
< | 小于
= | 等于
!=(<>) | 不等于
= | 大于等于
<= | 小于等于

逻辑运算符
运算符 描述
AND (&&)
OR (` `)
XOR 异或
NOT(!)
## 两侧都包括
select * from employee WHERE salary BETWEEN 2500 and 4500;
## 空值判断
select * from employee where salary is null;
## in 语句
select * from employee WHERE name in ('a','b');## like 语句select * from  employee WHERE salary like '4%';
select * from  employee WHERE salary like '4%00';
## 这样查不出来 why? (double 不太一样?)
select * from  employee WHERE salary like '4_00';
select * from  employee WHERE name like '_bc';## 排序
select * from employee order by salary ;
select * from employee order by salary DESC;
SELECT * FROM EMPLOYEE ORDER BY SALARY DESC ,NO;## 限制查询条数
select * from employee LIMIT 2;
## 指定初始位置 ,显示条猪
select * from employee LIMIT 2,4;

统计函数

select count(*) from employee;
select count(1) from employee;
select count(salary) from employee; -- 将忽略null值,不参与计数## 平均值,null值既不计入和值也不计入 个数
select avg(salary) from employee;select sum(salary) from employee;
select max(salary) from employee;
select min(salary) from employee;## 分组
SELECTsubstr(salary, 1, 1),count(*)
FROM employee
GROUP BY substr(salary, 1, 1);SELECTsubstr(salary, 1, 1),count(*)
FROM employee
GROUP BY substr(salary, 1, 1)
HAVING count(*) > 1;

十、多表查询


## 内连接
SELECTa.name,b.name,a.salary
FROM employee aJOIN employee b ON a.salary = b.salary AND a.name != b.name;SELECTa.name,b.name,a.salary
FROM employee a, employee b
WHERE a.salary = b.salaryAND a.name != b.name;## 外链接
### 左外联结 left join on
### 右外联结 right join on
### 全外联结 full join on
select * from employee;
select * from t_dept_2 ;select * from t_dept_2 a LEFT JOIN employee b on a.dept_no = b.dept_no;
select * from t_dept_2 a RIGHT JOIN employee b on a.dept_no = b.dept_no;
#####  mysql 不支持。。。 select * from t_dept_2 a FULL JOIN  ## 合并
#### union 合并重复记录
SELECT DEPT_NO FROM T_DEPT_2
UNION
SELECT NO FROM EMPLOYEE;SELECT DEPT_NO FROM T_DEPT_2
UNION ALL
SELECT NO FROM EMPLOYEE;## 子查询SELECT *
FROM employee
WHERE (no, dept_no) IN (SELECTno,dept_noFROM employeeWHERE salary > 4000);##any
## 类似于 in
select * from employee WHERE salary = ANY (select salary from employee WHERE dept_no = 2);
## 大于最小值
select * from employee WHERE salary > ANY (select salary from employee WHERE dept_no = 2);
## 小于最大值
select * from employee WHERE salary < ANY (select salary from employee WHERE dept_no = 2);##all
## 大于最大值
select * from employee WHERE salary > ALL (select salary from employee WHERE dept_no = 2);
## 小于最小值
select * from employee WHERE salary < ALL (select salary from employee WHERE dept_no = 2);## exists
SELECT *
FROM employee a
WHERE exists(SELECT *FROM t_dept_2 bWHERE a.dept_no = b.dept_no
);##  not exists
SELECT *
FROM employee a
WHERE NOT exists(SELECT *FROM t_dept_2 bWHERE a.dept_no = b.dept_no
);

十一、运算符

## 算数运算符
SELECT6 + 4,6 - 4,6 / 2,6 DIV 2,6 % 4,6 MOD 4;## 结果: 10,2,3.0000,3,2,2## Why?###  The MySQL DIV function is used for integer division where n is divided by m and an integer value is returned.

mysql 基本操作相关推荐

  1. MySQL中定义fk语句_MySQL基础篇/第3篇:MySQL基本操作语句.md · qwqoo/MySQL-Review - Gitee.com...

    ### 第3篇:MySQL基本操作语句 - MySQL基础操作 #### 排序检索数据 - 之前的数据没有进行排序,其是按照默认在数据表中的数据返回的 - SELECT语句的ORDER BY 子句进行 ...

  2. 20分钟学会mysql_5分钟学会mysql基本操作

    mysql视频教程栏目介绍如何快速学会mysql基本操作 相关免费学习推荐:mysql视频教程 文章目录一.SQL是什么? 分类: 二.关于数据库CRUD操作 1.操作表list: 2.对表内数据进行 ...

  3. mysql键1键2_详解mysql基本操作详细(二)

    前言 本文类容 1.数据库的几大约束 2.表与表之间的关系 约束: 主键约束: 作用:为了保证数据的有效性和完整性 mysql中常用的约束:主键约束(primary key) 唯一约束(unique) ...

  4. linux mysql etc inid_Linux下mysql基本操作

    Linux下mysql基本操作 作者:浩浩哥来了 对mysql进行初始密码的添加 方法(一) mysqladmin -uroot password 123 方法(二) 如果在添加初始密码是报错了可以进 ...

  5. ci mysql操作_MySQL基础篇/第3篇:MySQL基本操作语句.md · icanci/MySQL-Review - Gitee.com...

    ### 第3篇:MySQL基本操作语句 - MySQL基础操作 #### 排序检索数据 - 之前的数据没有进行排序,其是按照默认在数据表中的数据返回的 - SELECT语句的ORDER BY 子句进行 ...

  6. MySQL基本操作,个人总结。(WampServer小补充)

    原文链接    https://blog.csdn.net/Edogawa_Konan/article/details/80259838 WampServer就是Windows Apache Mysq ...

  7. 【MySQL基础】MySQL基本操作详解

    系列文章目录 第1篇:[MySQL基础]MySQL介绍及安装 第2篇:[MySQL基础]MySQL基本操作详解 文章目录 ✍1,数据库操作     

  8. C++ Mysql基本操作

    C++ Mysql基本操作 连接Mysql MYSQL *mysql_init(MYSQL *mysql) 如果mysql是NULL指针,该函数将分配.初始化.并返回新对象.否则,将初始化对象,并返回 ...

  9. 史上最全MySQL基本操作(这一篇就够用了!!!)

    基础知识请移步:数据库.MySQL基本知识 欢迎学习交流!!! 持续更新中- 文章目录 MySQL基本操作 一.SQL语法规则 二.SQL库操作 1.创建数据库 2.显示数据库 3.使用数据库 4.修 ...

  10. MySQL基本操作(命令行方式)

    MySQL基本操作(命令行方式) 1.登录MySQL 2.MySQL 创建数据库 3.MySQL 删除数据库 4.MySQL选择数据库 5.MySQL 创建数据表 6. MySQL 删除数据表 7.M ...

最新文章

  1. 探测Windows2K/XP/2003本机系统信息
  2. linux自动挂起什么意思,Linux中进行挂起(待机)的命令说明
  3. android中弹出窗口,如何在Android中创建弹出窗口(PopupWindow)
  4. Redis:16---常用功能之(慢查询日志)
  5. MNIST机器学习入门(二)
  6. 基金学习201907301
  7. logstash grok切分nginx日志
  8. 基于【CentOS-7+ Ambari 2.7.0 + HDP 3.0】搭建HAWQ数据仓库04 —— 安装HAWQ插件PXF3.3.0.0...
  9. linux远程控制本地用户登录,linux 本地无法登录 远程可以登陆的解决办法
  10. Windows编程系列(前言)
  11. 写失败数据写入成功_马克·吐温写小说有多成功,做生意就有多失败,创业亏的就剩烟囱...
  12. 用Spotlight实时监控Windows Server 08
  13. 不要在意FIl短期,FIl未来价值可期
  14. A+B 输入输出练习VIII
  15. 将React Native 集成进现有OC项目中(过程记录) 、jsCodeLocation 生成方式总结
  16. 2021日照市地区高考成绩排名查询,日照高中高考成绩排名,2021年日照各高中高考成绩排行榜...
  17. 气动阀门定位器工作原理
  18. 黎明杀机一直无法连接在线服务器,黎明杀机无法连接-崩坏3IOS无法连接服务器...
  19. Creo 钣金设计视频教程
  20. python自动视频剪辑_一个Python写的视频剪辑软件,好用!

热门文章

  1. caffe学习笔记--跑个SampleCode
  2. 使用heroku进行免费分布式运算.Vs.AWS
  3. PCL:PCL可视化显示点云
  4. kaptcha配置java_kaptcha 配置
  5. 16进制的两位数转换不了 matlab_【大学生计算机基础】进制那些问题。小数或整数转换,各种进制间转换.........
  6. js Blob对象介绍
  7. Linux的前世今生
  8. 周末,说声php的settergetter(魔术)方法,你们辛苦了
  9. Python的可变类型与不可变类型
  10. (转)Linux下apache限速和限制同一IP连接数的实现