第三章 SQL

一、SQL概念

结构化查询语言(Structured Query Language)简称SQL,是一种特殊目的的编程语言,作为数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统。即操作关系型数据库的编程语言,定义了一套操作关系型数据库统一标准
结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作。它不要求用户指定对数据的存放方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统, 可以使用相同的结构化查询语言作为数据输入与管理的接口。结构化查询语言语句可以嵌套,这使它具有极大的灵活性和强大的功能。

二、SQL****通用语法

在学习具体的SQL语句之前,先来了解一下SQL语言的同于语法。

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

2). SQL语句可以使用空格/缩进来增强语句的可读性。

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

4). 注释:

单行注释:-- 注释内容 或 # 注释内容

多行注释:/* 注释内容 */

三、SQL****分类

SQL语句,根据其功能,主要分为四类:DDL、DML、DQL、DCL。

四、DDL

Data Definition Language,数据定义语言,用来定义数据库对象(数据库,表,字段) 。

4.1. 数据库操作

1). 查询所有数据库

sql 复制代码
show databases;

**2).**查询当前数据库

sql 复制代码
select database() ;

**3).**创建数据库

sql 复制代码
create database [ if not exists ] 数据库名 [ default charset 字符集 ] [ collate 排序
规则 ] ;

4.2. 示例

**1).**创建一个itcast数据库, 使用数据库默认的字符集。

sql 复制代码
create database itcast;

在同一个数据库服务器中,不能创建两个名称相同的数据库,否则将会报错。

可以通过if not exists 参数来解决这个问题,数据库不存在, 则创建该数据库,如果存在,则不创建。

sql 复制代码
create database if not extists itcast;

**2).**创建一个 wzx 数据库,并且指定字符集

sql 复制代码
create database wzx default charset utf8mb4;

**3).**删除数据库

sql 复制代码
drop database [ if exists ] 数据库名 ;

如果删除一个不存在的数据库,将会报错。此时,可以加上参数 if exists ,如果数据库存在,再

执行删除,否则不执行删除。

**4).**切换数据库
use 数据库名 ;

我们要操作某一个数据库下的表时,就需要通过该指令,切换到对应的数据库下,否则是不能操作的。比如,切换到 linus 数据库,执行如下SQL:

sql 复制代码
use linus;

4.3. 表操作

1). 查询当前数据库所有表

sql 复制代码
show tables;

比如,我们可以切换到sys这个系统数据库,并查看系统数据库中的所有表结构。

sql 复制代码
use sys;
show tables;

**2).**查看指定表结构

sql 复制代码
desc 表名 ;

通过这条指令,我们可以查看到指定表的字段,字段的类型、是否可以为NULL,是否存在默认值等信息。


**3).**查询指定表的建表语句

sql 复制代码
show create table 表名;

通过这条指令,主要是用来查看建表语句的,而有部分参数我们在创建表的时候,并未指定也会查询到,因为这部分是数据库的默认值,如:存储引擎、字符集等。

**4).**创建表结构

sql 复制代码
CREATE TABLE 表名(
字段1 字段1类型 [ COMMENT 字段1注释 ],
字段2 字段2类型 [COMMENT 字段2注释 ],
字段3 字段3类型 [COMMENT 字段3注释 ],
......
字段n 字段n类型 [COMMENT 字段n注释 ]
) [ COMMENT 表注释 ] ;

注意: [...] 内为可选参数,最后一个字段后面没有逗号

比如,我们创建一张表 tb_user ,对应的结构如下,那么建表语句为:

sql 复制代码
create table tb_user(
id int comment '编号',
name varchar(50) comment '姓名',
age int comment '年龄',
gender varchar(1) comment '性别'
) comment '用户表';

4.4. 数据类型

在上述的建表语句中,我们在指定字段的数据类型时,用到了int ,varchar,那么在MySQL中除了 以上的数据类型,还有哪些常见的数据类型呢? 接下来,我们就来详细介绍一下MySQL的数据类型。MySQL中的数据类型有很多,主要分为三类:数值类型、字符串类型、日期时间类型。

1). 数值类型

sql 复制代码
如:
1). 年龄字段 -- 不会出现负数, 而且人的年龄不会太大
age tinyint unsigned
2). 分数 -- 总分100分, 最多出现一位小数
score double(4,1)

2). 字符串类型

char 与 varchar 都可以描述字符串,char是定长字符串,指定长度多长,就占用多少个字符,和

字段值的长度无关 。而varchar是变长字符串,指定的长度为最大占用长度 。相对来说,char的性

能会更高些。

sql 复制代码
如:
1). 用户名 username ------> 长度不定, 最长不会超过50
username varchar(50)
2). 性别 gender ---------> 存储值, 不是男,就是女
gender char(1)
3). 手机号 phone --------> 固定长度为11
phone char(11)

未完待续,今明日更新中

相关推荐
村口蹲点的阿三2 小时前
Spark SQL 中对 Map 类型的操作函数
javascript·数据库·hive·sql·spark
暮湫3 小时前
MySQL(1)概述
数据库·mysql
唯余木叶下弦声3 小时前
PySpark之金融数据分析(Spark RDD、SQL练习题)
大数据·python·sql·数据分析·spark·pyspark
fajianchen3 小时前
记一次线上SQL死锁事故:如何避免死锁?
数据库·sql
chengpei1473 小时前
实现一个自己的spring-boot-starter,基于SQL生成HTTP接口
java·数据库·spring boot·sql·http
中东大鹅5 小时前
MongoDB的索引与聚合
数据库·hadoop·分布式·mongodb
天天向上杰6 小时前
简识Redis 持久化相关的 “Everysec“ 策略
数据库·redis·缓存
Leaf吧6 小时前
springboot 配置多数据源以及动态切换数据源
java·数据库·spring boot·后端
狮歌~资深攻城狮7 小时前
TiDB出现后,大数据技术的未来方向
数据库·数据仓库·分布式·数据分析·tidb
狮歌~资深攻城狮7 小时前
TiDB 和信创:如何推动国产化数据库的发展?
数据库·数据仓库·分布式·数据分析·tidb