当前位置:网站首页>SQL Statement Basics

SQL Statement Basics

2022-08-02 19:06:00 SYBH.

        结构化查询语言(Structured Query Language)简称SQL,Structured Query Language is a database query and program 设计语言,用于存放数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名. 结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作.It does not require the user to specify the logarithm data storage method,也不需要用户了解具体的数据存放方式,So different database families with completely different underlying structures 统,可以使用相同的结构化查询语言作为数据输入与管理的接口.结构化查询语言语句可以嵌套,这使 It has great flexibility and powerful functions

目录

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 Constraints on table structure

2.2.6 字段类型

3.DML

3.1 INSERT

3.2 UPDATE

3.3 DELETE


1.SQL分类

1.1 数据定义语言(DDL)

        数据定义语言 (Data Definition Language, DDL) 是SQL语言集中,Responsible for data structure definition and database objects 定义的语言,由CREATE、ALTER与DROP三个语法所组成,最早是由 Codasyl (Conference on Data Systems Languages) 数据模型开始,现在被纳入 SQL 指令中作为其中一个子集. 

 1.2 数据操纵语言(DML)

         数据操纵语言(Data Manipulation Language, DML)是SQL语言中,Responsible for running data against database objects Access the working instruction set,以INSERT、UPDATE、DELETE三种指令为核心,分别代表插入、更新与删除.

1.3 数据查询语言(DQL)

        数据查询语言(Data Query Language, DQL)是SQL语言中,Responsible for making data queries without querying the data itself The statement to make the modification,这是最基本的SQL语句.保留字SELECT是DQL(也是所有SQL)用得最多的动词,其 他DQL常用的保留字有FROM,WHERE,GROUP BY,HAVING和ORDER BY.这些DQLReserved words are often associated with them his typeSQL语句一起使用.

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】It is the carrier of data stored in the database.

 2.2.1 语法结构

        然后我们来看下DDLis how to operate the table【TABLE】的.

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

创建一张用户表

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

2.2.2 添加注释

In order to make it clear to others the meaning of the fields we define,We need to add corresponding comments to the fields we created to explain.

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

Or add it after building the table

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

2.2.3 删除表

Drop table pass 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 Constraints on table structure

非空约束

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

Or specify it when building the table

# 删除表
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='用户表' ;

唯一约束

        The same value cannot appear in this field,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='用户表' ;

After the table is created, set the unique constraint of the field

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

主键

        A field that uniquely identifies a record,不能为空,唯一约束,只能有一个主键.

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='用户表' ;

联合主键:The information of the combination of multiple fields cannot be repeated

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

外键

        A foreign key is one that can be repeated in the primary table,But its value is the primary key of another table,Foreign keys relate two tables,Foreign keys can constrain the table 数据的更新,Foreign key and primary key table relation,The data type should be unified,长度(存储大小)要统一,It will remain one when updating the data 致性

# 删除表
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)

注意:Cascading relationships of foreign key fields,If we want to delete the primary key record corresponding to the foreign key,Then you must delete the corresponding place of the annotation first Some foreign key records,否则删除不成功,In actual development, we use less primary keys.

check

         Fine-grained constraints.

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 类型类似,但它们保存和检索的方式不同.Their maximum length and whether trailing spaces are preserved etc. are also different.在存储或检索过程中不进行大小写转换

3.DML

        数据操纵语言(Data Manipulation Language, DML)是SQL语言中,Responsible for running data against database objects Access the working instruction set,以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 data from other table structures into the table:

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
)

Change all genders in the student table to female

把'张三'gender change'男'

Change the date of birth to the current timenow()

Make the gender female All dates of birth changed2022-01-18

Set values ​​from another table to this table

3.3 DELETE

delete删除:

truncate删除:

原网站

版权声明
本文为[SYBH.]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/214/202208021634337360.html