当前位置:网站首页>SQL语句基础

SQL语句基础

2022-08-02 16:34:00 SYBH.

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

目录

1.SQL分类

1.1 数据定义语言(DDL)

 1.2 数据操纵语言(DML)

1.3 数据查询语言(DQL)

1.4 数据控制语言(DCL)

2.DDL

2.1 操作数据库

2.2 操作表结构

 2.2.1 语法结构

2.2.2 添加注释

2.2.3 删除表

2.2.4 修改表

2.2.5 表结构的约束

2.2.6 字段类型

3.DML

3.1 INSERT

3.2 UPDATE

3.3 DELETE


1.SQL分类

1.1 数据定义语言(DDL)

        数据定义语言 (Data Definition Language, DDL) 是SQL语言集中,负责数据结构定义与数据库对象 定义的语言,由CREATE、ALTER与DROP三个语法所组成,最早是由 Codasyl (Conference on Data Systems Languages) 数据模型开始,现在被纳入 SQL 指令中作为其中一个子集。 

 1.2 数据操纵语言(DML)

         数据操纵语言(Data Manipulation Language, DML)是SQL语言中,负责对数据库对象运行数据 访问工作的指令集,以INSERT、UPDATE、DELETE三种指令为核心,分别代表插入、更新与删除。

1.3 数据查询语言(DQL)

        数据查询语言(Data Query Language, DQL)是SQL语言中,负责进行数据查询而不会对数据本身 进行修改的语句,这是最基本的SQL语句。保留字SELECT是DQL(也是所有SQL)用得最多的动词,其 他DQL常用的保留字有FROM,WHERE,GROUP BY,HAVING和ORDER BY。这些DQL保留字常与其 他类型的SQL语句一起使用。

1.4 数据控制语言(DCL)

         数据控制语言 (Data Control Language) 在SQL语言中,是一种可对数据访问权进行控制的指令, 它可以控制特定用户账户对数据表、查看表、预存程序、用户自定义函数等数据库对象的控制权。由 GRANT 和 REVOKE 两个指令组成。DCL以控制用户的访问权限为主,GRANT为授权语句,对应的 REVOKE是撤销授权语句。

2.DDL

        数据定义语言 (Data Definition Language, DDL) ,它主要包括三个关键字:create ,alter , drop (数据库关键字不分大小写 ),主要操作对象 有数据库、表、索引、视图等.

2.1 操作数据库

创建数据库

create databases 数据库名称;

使用这个数据库

use 数据库名称;

删除这个数据库

drop database 数据库名称;

注意:执行的SQL语句不区分大小写,一个SQL语句末尾要加上 ;

2.2 操作表结构

        表【TABLE】是数据库中存储数据的载体。

 2.2.1 语法结构

        然后我们来看下DDL是如何来操作表【TABLE】的。

CREATE TABLE 表名称
(
列名称1 数据类型,
列名称2 数据类型,
列名称3 数据类型,
....
)

创建一张用户表

CREATE TABLE T_USER(
id int(3) ,
user_name varchar(30)
)

2.2.2 添加注释

为了让别人能清楚我们定义的字段的含义,我们需要给我们创建的字段添加对应的注释来说明。

CREATE TABLE T_USER(
id int(3) ,
user_name varchar(30) COMMENT '用户名'
)COMMENT='用户表'

或者在建表后添加

ALTER TABLE t_user
MODIFY COLUMN user_name varchar(20) COMMENT 'aaa' ;

2.2.3 删除表

删除表通过 DROP 关键字来实现

DROP TABLE T_USER;

2.2.4 修改表

添加字段

ALTER TABLE T_USER ADD address VARCHAR(2);

修改字段类型

ALTER TABLE T_USER MODIFY address VARCHAR(50);

修改字段名称

ALTER TABLE T_USER RENAME COLUMN address TO address666;

删除字段

ALTER TABLE T_USER DROP COLUMN address666;

2.2.5 表结构的约束

非空约束

ALTER TABLE T_USER
CHANGE id id INT NOT NULL COMMENT '主键';

或者在建表的时候指定

# 删除表
DROP TABLE T_USER;
CREATE TABLE T_USER(
id INT(5) NOT NULL COMMENT '主键',
user_name VARCHAR(20) COMMENT '账号' ,
age INT(2) COMMENT '年龄' DEFAULT 18
)COMMENT='用户表' ;

默认值

DROP TABLE T_USER;
CREATE TABLE T_USER(
id INT(5) NOT NULL COMMENT '主键',
user_name VARCHAR(20) COMMENT '账号' ,
age INT(2) COMMENT '年龄' DEFAULT 18
)COMMENT='用户表' ;

唯一约束

        该字段中不能出现相同的值,null除外

DROP TABLE T_USER;
CREATE TABLE T_USER(
id INT(5) UNIQUE COMMENT '主键',
user_name VARCHAR(20) COMMENT '账号' ,
age INT(2) COMMENT '年龄' DEFAULT 18
)COMMENT='用户表' ;

建表后设置字段的唯一约束条件

ALTER TABLE t_user add CONSTRAINT unique_name UNIQUE(user_name);
alter table t_user add unique (user_name);

主键

        能唯一标识一条记录的字段,不能为空,唯一约束,只能有一个主键。

DROP TABLE T_USER;
CREATE TABLE T_USER(
id INT(5) PRIMARY KEY COMMENT '主键',
user_name VARCHAR(20) COMMENT '账号' ,
age INT(2) COMMENT '年龄' DEFAULT 18
)COMMENT='用户表' ;

联合主键:多个字段组合的信息是不能出现重复的

ALTER TABLE t_user
ADD PRIMARY KEY (id, user_name);

外键

        外键就是在主表中可以重复出现,但是它的值是另一个表的主键,外键使两个表相关,外键可约束表的 数据的更新,外键和主键表联系,数据类型要统一,长度(存储大小)要统一,在更新数据的时候会保持一 致性

# 删除表
DROP TABLE T_USER;
CREATE TABLE T_USER(
id INT(5) PRIMARY KEY COMMENT '主键',
user_name VARCHAR(20) COMMENT '账号' ,
age INT(2) COMMENT '年龄' DEFAULT 18,
deptid INT(30) ,
CONSTRAINT FK_DEPT_ID FOREIGN KEY(deptid) REFERENCES T_DEPT(dept_id)
)COMMENT='用户表' ;
ALTER TABLE T_USER ADD
CONSTRAINT FK_DEPT_ID FOREIGN KEY(deptid) REFERENCES T_DEPT(dept_id)

注意:外键字段的级联关系,如果我们要删除外键对应的主键记录,那么必须要先删除该注解对应的所 有的外键记录,否则删除不成功,实际开发中我们对主键的使用比较少。

check

         粒度更细的约束。

DROP TABLE T_USER;
CREATE TABLE T_USER(
id INT(5) PRIMARY KEY COMMENT '主键',
user_name VARCHAR(20) COMMENT '账号' ,
age INT(3) COMMENT '年龄' ,
CHECK (age > 0 AND age < 40)
)COMMENT='用户表' ;

2.2.6 字段类型

MySQL 中定义数据字段的类型对你数据库的优化是非常重要的。

MySQL 支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。

数值类型

 

日期和时间类型

字符串类型

  

        char(n) 和 varchar(n) 中括号中 n 代表字符的个数,并不代表字节个数,比如 CHAR(30) 就可以存储 30 个字符。

         CHAR 和 VARCHAR 类型类似,但它们保存和检索的方式不同。它们的最大长度和是否尾部空格被保留 等方面也不同。在存储或检索过程中不进行大小写转换

3.DML

        数据操纵语言(Data Manipulation Language, DML)是SQL语言中,负责对数据库对象运行数据 访问工作的指令集,以INSERT、UPDATE、DELETE三种指令为核心,分别代表插入、更新与删除。

3.1 INSERT

插入单行记录

INSERT into 列名(列名,。。)values(,)

插入多行记录

复制表结构和数据

create table t_student_beifen as select * from t_student

复制表结构

create table t_student_beifen as select * from t_student where 1 <> 1

把其他表结构中的数据插入到表中:

insert into t_student(id,stuname) select id,stuname from t_student01

3.2 UPDATE

语法结构

update 表名 set 字段名=值,字段名=值。。 where 。。。

案例:

创建一张学生表

CREATE TABLE t_student
(
    id int(3) primary key,
    stuname varchar(30) not null,
    sex char(3) ,
    birthday date
)

把学生表中的性别全部改成女

把'张三'的性别改成'男'

把出生日期改成当前时间now()

把性别为女的 所有的出生日期改成2022-01-18

从别的表把值设置到本表中

3.3 DELETE

delete删除:

truncate删除:

原网站

版权声明
本文为[SYBH.]所创,转载请带上原文链接,感谢
https://blog.csdn.net/m0_68036862/article/details/126120798