MySQL数据库SQL简介

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

  好程序员大数据培训分享之MySQL数据库SQL简介、语法格式:一、SQL的简介,结构化查询语言(Structured Query Language),简称SQL。它是专门用来访问数据库的标准编程语言。它可以用于存储数据,查询数据,更新数据以及管理关系型数据库等操作。同时,数据库脚本文件的扩展名也是sql。
  SQL是高级的非过程化编程语言,允许用户在高层数据结构上工作。同时,SQL语句可以嵌套,因此拥有极大的灵活性和强大的功能。但是,数据库厂商都对SQL标准语言做了某些改编和扩充,因此,不同的数据库的SQL语言,用法、格式等不完全一致。
  SQL语言可以分成五个部分,分别为DDL,DML,TCL,DCL,DQL。
1、数据定义语言(Data Definition Language ),简称DDL。
用于建立,删除,修改数据库对象的语言。包含如下关键字
create:用于创建表或者其他对象的结构
drop:用于删除表或者其他对象的结构
alter:用于修改表或者其他对象的结构
truncate:用于清空表数据,保留表结构
2、数据操纵语言(Data Manipulation Language),简称DML。
用于改变数据表的数据。通常与事务控制语言一起使用,要经过事务控制语言的提交操作,才会真正的将数据持久到数据库中。包含如下关键字:
insert:将数据插入到数据表中。
update:更新数据表中已存在的数据。
delete:删除数据表中的数据。
3、数据查询语言(Data Query Language),简称DQL。
用于查询数据表中的数据。或者用于科学计算。关键字如下:
select:选择要显示的数据。
4、事务控制语言(Transaction Control Language),简称TCL。
用于保证数据的完整性和一致性。只有数据表正在进行DML操作时,才会涉及到事务。关键字如下:
commit:提交,确任。将已经进行的DML操作的数据持久化。
rollback:回滚,回退。用于取消已经进行的DML操作。
savepoint:保存点。可以将当前的DML操作回退到指定的保存点,便于取消部分改变。
5、数据控制语言(Data Control Language),简称DCL。
用于执行关于权限的授予和撤销操作。关键字如下:
grant:授权。用于给用户或者角色授予权限.
revoke:撤销。用于回收用户或者角色的权限。
create user:创建用户。
drop user :删除用户。
二、MySql的常用SQL语法
市场上流通的数据库虽然都遵守了SQL语言的标准规范,但是用法也不完全相同。下面我将MySQL数据库的各个部分的使用语法整理一下,方便大家记忆。PS:下面会用到"[]"中括号,表示可选。
1、关于数据库的创建,删除等操作语法
在实际开发中,任何一个项目的数据存储与管理都对应一个数据库(数据存储空间),避免与其他项目的数据混在同一个数据库中,因此,会涉及到数据库的创建等操作。
(1)创建数据库:create database [if not exists] dbName [default character set utf8] [collate utf8_general_ci | utf8_general_cs];

解析> 此语句指定数据库的字符集为utf8。utf8_general_ci表示字母大小写不敏感;utf8_general_cs表示大小写敏感

(2)查看数据库:show databases;

(3)选择数据库:use dbName;

(4)删除数据库:drop database dbName;

(5)查看数据库字符集:show variables like "%character%";

(6)修改数据库字符集:alter database dbName character set cName;

(7)修改命令提示符界面显示字符集(当前窗口有效):set name cName;
2、DDL语言的操作语法
(1)创建表结构:
create table tName (colName1 type1,...,colNameN typeN) engine=innodb[collate utf8_general_ci]
(2)显示表结构:desc tName 或者 show columns from tName;

(3)添加表字段:alter table tName add colName Type;

(4)删除表字段:alter table tName drop colName;

(5)修改表字段类型/表字段名称
alter table tName modify colName newType;
alter table tName change colName newColName newType;

(6)修改表名:alter table oldName rename newName;

(7)清空表数据,保留表结构:truncate table tName;

(8)删除表结构:drop table tName;

(9)复制表结构:create table newName like oldName;
3、DML语言的操作语法
(1)插入数据到表中:
方法1: insert into tName (colName1,....,colNameN)values (value1,.....,valueN);
方法2: insert into tName values ( value1,.....,valueN); /按照建表字段顺序赋值/

(2)修改表中数据:
update tName set colName1=value1,.....colNameN=valueN [ where 条件 ];

(3)删除表中数据:delete from tName [ where 条件 ];
4、DQL语言的操作语法
select colName1,......,colNameN from tName [where 子句] [ group by 子句] [ having 子句] [order by子句]select有选择的意思,即选择哪些字段进行查询,显示。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8天前
|
SQL 人工智能 算法
【SQL server】玩转SQL server数据库:第二章 关系数据库
【SQL server】玩转SQL server数据库:第二章 关系数据库
51 10
|
8天前
|
SQL 算法 数据库
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
68 6
|
1天前
|
SQL 监控 druid
Druid数据库连接池简介及应用推广(老项目翻出来做下记录)
Druid数据库连接池简介及应用推广(老项目翻出来做下记录)
|
2天前
|
SQL 关系型数据库 MySQL
MySQL环境搭建——“MySQL数据库”
MySQL环境搭建——“MySQL数据库”
|
2天前
|
SQL NoSQL 关系型数据库
初识MySQL数据库——“MySQL数据库”
初识MySQL数据库——“MySQL数据库”
|
4天前
|
关系型数据库 MySQL 数据库
数据库基础(mysql)
数据库基础(mysql)
|
4天前
|
SQL 数据库
数据库SQL语言实战(二)
数据库SQL语言实战(二)
|
5天前
|
SQL 关系型数据库 数据库
【后端面经】【数据库与MySQL】SQL优化:如何发现SQL中的问题?
【4月更文挑战第12天】数据库优化涉及硬件升级、操作系统调整、服务器/引擎优化和SQL优化。SQL优化目标是减少磁盘IO和内存/CPU消耗。`EXPLAIN`命令用于检查SQL执行计划,关注`type`、`possible_keys`、`key`、`rows`和`filtered`字段。设计索引时考虑外键、频繁出现在`where`、`order by`和关联查询中的列,以及区分度高的列。大数据表改结构需谨慎,可能需要停机、低峰期变更或新建表。面试中应准备SQL优化案例,如覆盖索引、优化`order by`、`count`和索引提示。优化分页查询时避免大偏移量,可利用上一批的最大ID进行限制。
32 3
|
5天前
|
存储 关系型数据库 MySQL
【后端面经】【数据库与MySQL】为什么MySQL用B+树而不用B树?-02
【4月更文挑战第11天】数据库索引使用规则:`AND`用`OR`不用,正用反不用,范围中断。索引带来空间和内存代价,包括额外磁盘空间、内存占用和数据修改时的维护成本。面试中可能涉及B+树、聚簇索引、覆盖索引等知识点。MySQL采用B+树,因其利于范围查询和内存效率。数据库不使用索引可能因`!=`、`LIKE`、字段区分度低、特殊表达式或全表扫描更快。索引与NULL值处理在不同数据库中有差异,MySQL允许NULL在索引中的使用。
10 3
|
7天前
|
关系型数据库 MySQL 数据库连接
Django(四):Django项目部署数据库及服务器配置详解(MySQL)
Django(四):Django项目部署数据库及服务器配置详解(MySQL)
29 11