数据库的概念

1. 数据库的英文单词: DataBase 简称 DB

2. 什么数据库?

用于存储和管理数据的仓库

3. 数据库的特点:

1. 持久化存储数据,数据库就是一个文件系统

2. 方便存储和管理数据

3. 使用了统一的方式操作数据库  --- SQL

4. 常见的数据库软件

Oracle

MySQL

Microsoft SQL Server

SQL

SQL通用语法

1. SQL 语句可以单行或多行书写,以分号结尾

2. 可使用空格和锁紧来增强语句的句读性

3. MySQL 数据库 的 SQL 语句不区分大小写,关键字建议使用大写

4. 3 种注释

单行注释: -- 注释内容  或 # 注释内容 (mysql 特有)

多行注释:/注释内容/

SQL 分类

SQL 分类

图形理解

DDL : 操作数据库、表

1. 操作数据库: CRUD

C (Create):创建

* 创建数据库:

create database 数据库名称;

* 创建数据库,判断不存在,再创建:

create  database if not exists 数据库名称;

* 创建数据库,并制定字符集:

create database 数据库名称 character set 字符集名称;

*练习:创建db4数据库,判断是否存在,并制定字符集为gbk

create database if not exists db4 character set gbk;

R (Retrieve):查询

* 查询所有数据库的名称

show databases;

* 查询某个数据库的字符集:查询某个数据库的创建语句

show create database 数据库名称;

U (Update):修改

* 修改数据库的字符集

alter database 数据库名称 character set 字符集名称;

D (Delete):删除

* 删除数据库:

drop database 数据库名称;

* 判断数据库存在,再删除:

drop database if exists 数据库名称;

使用数据库

* 查询当前正在使用的数据库名称:

select database();

* 使用数据库:

use 数据库名称;

2. 操作表

C (Create):创建

* 语法:

create table 表名(

列名1 数据类型1,

列名2 数据类型2,

...

);

* 注意:最后一列,不需要加,

* 数据库类型:

1. int 整数类型

age int,

2. double 小数类型

score double(5,2)

3. date 日期 只包含年月日

4. datetime 日期 包含年月日时分秒

5. timestamp 时间戳类型 包含年月日时分秒

如果将来不给这个字段赋值,或赋值为null,则默认使用当前的系统时间来自动赋值

6. varchar 字符串

name varchar(20):姓名最大20个字符

* 创建表:

>create tablestudent(idint,namevarchar(32),scoredouble(4,1),birthday date,insert_time timestamp);

* 复制表:

create table 表名 like 被复制的表名;

R (Retrieve):查询

* 查询某个数据库中所有的表名称

show tables;

* 查询表结构

desc 表名;

U (Update):修改

* 修改表名

alter table 表名 rename to 新的表名;

* 修改表的字符集

alter table 表名 character set 字符集类型;

* 添加一列

alter table 表名 add 列名 数据类型;

* 修改表某列的数据类型

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

* 修改表的列名及数据类型

alter table 表名 change 列名 新的列名 新的数据类型;

* 删除列

alter table 表名 drop 列名;

D (Delete):删除

* 删除表:

drop table 表名;

* 判断表存在,再删除:

drop table if exists 表名;

DML : 增删改表中数据

1. 添加数据:

* 语法:

insert into 表名(列名1,列名2,...,列名n) values (值1,值1,...,值n)

注意事项

1. 列名和值要一一对应。

2. 如果表名后,补丁已列名,则默认给所有列添加值

insert into 表名 values (值1,值1,...,值n);

3. 除了数字类型,其他类型需要使用引号(单双都可以)引起来

2. 删除数据:

* 语法:

delete  from 表名 where 条件;

注意事项

1. 如果不加条件,则删除表中所有记录。

2. 如果要删除所有记录

delete  from 表名;-- 不推荐使用。有多少条记录就会执行多少次删除操作。

truncate table 表名;-- 推荐使用,效率更高,先删除表,然后再创建一张一模一样的表。

3. 修改数据:

* 语法:

update 表名 set 列名1 = 值1,...,列名n = 值n where 条件;

注意事项

1. 如果不加条件,则修改表中所有记录。

DQL : 查询表中的记录

select * from 表名;

1. 语法:

select 字段列表

from 表名列表

where 条件列表

group by 分组列表

order by 排序列表

limit 分页列表

2. 基础查询:

1. 多个字段查询

select 字段名1,...from 表名;

(注意:如果查询所有字段,可以使用来替代字段列表)

2. 去除重复

distinct

3. 计算列

一般可以使用size运算计算一些列的值(一般只会进行数值型的计算)

ifnull(表达式1,表达式2):null参与的运算,计算你结果都为null

表达式1:哪个字段需要判断是否为null

* 表达式2:如果该字段为null后的替换值

4. 起别名:

as:as也可以省略

3. 条件查询:

1. where 子句后跟条件

2. 运算符

* >、<、<=、 >=、 =、'<>==!='

* BETWEEN...AND

* IN(集合)

* LIKE

_ :单个任意字符

% :多个任意字符

* IS NULL

* and 或 &&

* or 或 ||

* not 或 |

1. 排序查询

* 语法:

order by 排序字段1 排序方式1,排序字段2 排序方式2,...

* 排序方式:

ASC:升序,默认的。

DESC:降序。

注意:

* 如果有多个排序条件,则当前边的条件值一样时,才会判断第二条件。

2. 聚合函数:将一列数据作为一个整体,进行纵向计算。

* count:计算个数

1. 一般选择非空的列:主键

2. count( * )

* max:计算最大值

* min:计算最小值

* sum:计算和

* avg:计算平均值

注意:

* 聚合函数的计算排除null值

* 选择不包含非空的列

* IFNULL函数

3. 分组查询:

* 语法:group by 分组字段;

注意:

* 分组之后查询的字段,分组字段,聚合函数

* where 和 having 的区别?

☆ where 在分组之前进行限定,如果不满足条件,则不参与分组。

☆ having 在分组之后进行限定,如果不满足结果,则不会被查询出来。

★ where 后不可以跟聚合函数

★ having 可以进行聚合函数的判断

3. 分页查询:

* 语法:limit 开始的索引,每页查询的条数

* 公式:-- 公式:开始的索引 = (当前的页码 - 1) * 每页显示的条数

* limit 是一个MySQL“方言”

USEdb1;SELECTDATABASE();DROPTABLEIFEXISTSstudent;CREATETABLEstudent(id INT,NAMEVARCHAR(32),age INT,sexVARCHAR(32),addressVARCHAR(32),math DOUBLE,english DOUBLE);ALTERTABLEstudentMODIFYmath INT;ALTERTABLEstudentMODIFYenglish INT;INSERTINTOstudent(id,NAME,age,sex,address,math,english)VALUES(1,"马云",55,'男','杭州',66,78);INSERTINTOstudentVALUES(2,'马化腾',45,'女','深圳',98,87);INSERTINTOstudentVALUES(3,'马景涛',55,'男','香港',56,77);INSERTINTOstudentVALUES(4,'柳岩',20,'女','湖南',76,65);INSERTINTOstudentVALUES(5,'柳青',20,'男','湖南',86,NULL);INSERTINTOstudentVALUES(6,'刘德华',57,'男','香港',99,99);INSERTINTOstudentVALUES(7,'马德',22,'女','香港',99,99);INSERTINTOstudentVALUES(8,'德玛西亚',18,'男','南京',56,65);--查询 姓名 和 年龄SELECTNAME,ageFROMstudent;--去除重复的结果集SELECTDISTINCTaddressFROMstudent;SELECTDISTINCTNAME,addressFROMstudent;--计算math 和 english 分数之和SELECTNAME,math,english,math+englishFROMstudent;--如果有null参与的运算,计算结果都为nullSELECTNAME,math,english,math+IFNULL(english,0)FROMstudent;SELECTNAME,math,english,math+IFNULL(english,0)AS 总分FROMstudent;SELECTNAME,math 数学,english 英语,math+IFNULL(english,0)总分FROMstudent;--查询年龄不等于20岁SELECT*FROMstudentWHEREage!=20;SELECT*FROMstudentWHEREage<>20;--查询年龄大于等于20,小于等于30SELECT*FROMstudentWHEREage>=20&&age<=30;SELECT*FROMstudentWHEREage>=20ANDage<=30;SELECT*FROMstudentWHEREageBETWEEN20AND30;--查询年龄22岁,18岁,25岁信息SELECT*FROMstudentWHEREage=20ORage=18ORage=25;SELECT*FROMstudentWHEREageIN(20,18,25);--查询英语成绩为nullSELECT*FROMstudentWHEREenglish=NULL;--null值不能使用=!=判断SELECT*FROMstudentWHEREenglishISNULL;--查询英语成绩不为nullSELECT*FROMstudentWHEREenglishISNOTNULL;--查询姓马的有哪些?  likeSELECT*FROMstudentWHERENAMELIKE'马%';--查询第二个字是化的有哪些?  likeSELECT*FROMstudentWHERENAMELIKE'_化%';--查询姓名有三个字的人  likeSELECT*FROMstudentWHERENAMELIKE'___';--查询姓名中包含德的人SELECT*FROMstudentWHERENAMELIKE'%德%';SELECT*FROMstudent;SELECT*FROMstudentORDERBYmath;SELECT*FROMstudentORDERBYmath ASC,english DESC;SELECT*FROMstudentORDERBYmath DESC;SELECTCOUNT(IFNULL(english,0))FROMstudent;SELECTMAX(math)FROMstudent;SELECTMIN(math)FROMstudent;SELECTSUM(math)FROMstudent;SELECTAVG(IFNULL(english,0))FROMstudent;SELECT*FROMstudent;--按照性别分组,分别查询男、女同学的平均分SELECTsex,AVG(math)FROMstudentGROUPBYsex;--按照性别分组,分别查询男、女同学的平均分,人数SELECTsex,AVG(math),COUNT(id)FROMstudentGROUPBYsex;--按照性别分组,分别查询男、女同学的平均分,人数,要求,分数低于70分的人,不参与分组。SELECTsex,AVG(math),COUNT(id)FROMstudentWHEREmath>70GROUPBYsex;--按照性别分组,分别查询男、女同学的平均分,人数,要求,分数低于70分的人,不参与分组,分组之后,人数要大于两个人。SELECTsex,AVG(math),COUNT(id)FROMstudentWHEREmath>70GROUPBYsexHAVINGCOUNT(id)>2;SELECTsex,AVG(math),COUNT(id)人数FROMstudentWHEREmath>70GROUPBYsex HAVING 人数>2;--第一页SELECT*FROMstudentLIMIT0,3;--第二页SELECT*FROMstudentLIMIT3,3;--公式:开始的索引=(当前的页码-1)*每页显示的条数

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352

推荐阅读更多精彩内容