2023年6月21日发(作者:)

SQL数据库基础语法SQL语句的概述SQL语⾔的分类  数据定义语⾔(Data Definition Language)主要⽤于修改、创建和删除数据库对象,其中包括CREATE ALTER DROP语句。  数据查询语⾔(Data Query Language)主要⽤于查询数据库中的数据,其主要是SELECT语句,SELECT语句包括五个⼦句,分别是FROM WHERE HAVING GROUP BY和WITH语句。  数据操作语⾔(Data Manipulation Language)主要⽤于更新数据库⾥数据表中的数据,包括INSERT UODATE DELETE语句。  数据控制语⾔(Data Control Language)主要⽤于授予和回收访问数据库的某种权限。包括GRANT REVOKE等语句。  事物控制语⾔,主要⽤于数据库对事物的控制,保证数据库中数据的⼀致性,包括COMMIT ROLLBACK语句。  常⽤的数据类型    MYSQL:      

  SQL语句的书写规范    SQL语句中不区分关键字的⼤⼩写    SQL语句中不区分列名和对象名的⼤⼩写    SQL语句对数据库中数据的⼤⼩写敏感    SQL语句中使⽤--注释时,--后⾯⾄少有⼀个空格,多⾏注释⽤/* */  数据库的创建与删除  (1)数据库的创建:    CREATE DATABASE database_name;    在中书写SQL语句时,在SQL语句后⾯都要加上分号  (2)数据库的删除    DROP DATABASE database_name;数据表的创建与更新  数据库中的表  (1)数据记录:在数据表中的每⼀⾏被称为数据记录  (2)字段:数据表中的每⼀列被称为字段  (3)主键(PRIMARY KEY):作为数据表中唯⼀的表⽰,保证了每⼀天数记录的唯⼀性。逐渐在关系数据库中约束实体完整性。所谓实体完整性,是指对数据表⾏的约束。  (4)外键(FOREIGN KEY):外键⽤来定义表与表之间的关系。在数据表中,如果属性列F是关系B中的⼀个属性(并不是关系B的主键),并且属性列F是关系A的主键,则F就是B的外键。外键在关系数据库中的约束参照完整性。所谓参照完整性是指表与表之间的约束。  (5)索引:索引是指向数据表中的⼀个指针,指向索引字段在数据表中的物理位置。⼀般可以在如下⼏种情况下建⽴索引  在主键列中创建索引    多表连接时,在经常使⽤的连接列上创建索引     在经常使⽤WHERE⼦句查询的列上创建索引    在经常进⾏分组GROUP BY及排序ORDER BY的列上创建索引  (6)约束:为了保证数据的完整性需要使⽤约束    唯⼀约束(UNIQUE)使⽤唯⼀约束的某⼀列或者某⼀组中没有相同的值,即保证了值的唯⼀性。但是唯⼀约束中可以插⼊NULL值。    主键约束(PRIMARY KEY)保证使⽤主键约束的列中只能有唯⼀的值,并且不能包含NULL值,数据表中每⼀列只能定义⼀个PRIMARY KEY    外键约束(FOREIGN KEY)保证表参照完整性,确保对⼀个数据表的数据操作不会对与之关联的表造成不利的影响    检查约束(CHECK)限制列的取值范围或者取值条件,可以为⼀个列定义多个CHECK约束    ⾮空约束(NOT NULL)⽤于对列的约束  创建数据表:    CREATE TABLE table_name(    column_name1 datatype [constraint_condition1]    [,column name2 datatype [constraint_condition2]    ...)  使⽤约束  (1)唯⼀约束(UNIQUE)⽤来保证某⼀列中没有相同的值列或者某⼀组列中没有相同的值,⼀般为列创建了⼀个约束后,数据库会⾃动为该列建⽴⼀个唯⼀索引,其索引名与约束名相同  例如:CREATE TABLE T_dept(      dept_ID VARCHAR(15) UNIQUE,      dept_Name VARCHAR(10)  (2)主键约束    CREATE TABLE T_result(    stuID VARCHAR(15),    cruID VARCHAR(15),    result DOUBLE,    PRIMARY KEY(stuID,curID)    )  (3)外键约束    FOREIGN KEY[表名1](列名1)REFERENCE 表名2 (列名2)    [ON UPDATE [CASCADE]|[SET NULL]|[RESTRICT]]    [ON DELETE [CASCADE]|[SET NULL]|[RESTRICT]]  其中,FOREIGN KEY是关键字,表名1是可选的,列名1是指定数据表中⽤于外键约束的外键,表名2表⽰主表的名字,列名2主表中与从表中列名1相对应列的名字,后⾯的ON UPDATE  ON DELETE表⽰对表中的数据的修改或者删除,从主表之间采取什么样的操作⽅式,是可选的    CASCADE:级联删除,如果主表中⼀条数据记录被删除,从表中的数据也将删除    SET NULL:置空删除,如果主表中的⼀条数据记录南北删除,从表中与之相连的数据也将置空    RESTRICE:受限删除,如果主表中的⼀条数据被删除,则在执⾏DELETE语句时系统会报错,通知⽤户与主表相对应的数据在从表中依然存在,但是与主表相对应的数据在从表中不被删除,它是默认的⽅式  CREATE TABLE T_result(   stuID VARCHAR(15),   curID VARCHAR(15),   result DOUBLE,   FOREIGN KEY (stuID) REFERCES T_student (stuID) ON DELETE CASCADE,   PRIMARY KEY (stuID,curID)  )  (4)检查约束CHECK  CREATE TABLE T_curriculum(  curID VARCHAR(15) PRIMARY KEY  curName VARCHAR(10),  credit INT,  CHECK(credit BETWEEN 3 AND 8)  )  (5)⾮空约束NOT NULL  使⽤索引  (1)唯⼀索引:在数据表中使⽤UNIQUE可以为⼀个数据列定义⼀个唯⼀索引,唯⼀索引中的每⼀个索引值只对应数据表中的⼀条记录,保证了数据列中记录的唯⼀性  (2)主索引:在数据表中使⽤PRIMARY KEY可以为⼀个数据列定义⼀个主索引,所谓的主索引就是在主键列中建⽴索引  (3)单列索引:定义在数据表中⼀个数据列上的索引就是单列索引,⼀般在数据查询时,如果WHERE⼦句中经常⽤到的数据表中的某⼀列作为查询条件,就可以把该列创建为单列索引  (4)复合索引:索引可以定义在⼀个数据表的多个数据列上,像这样的索引被称为复合索引  (5)聚簇索引:创建与删除索引      CREATE [UNIQUE]|[CLUSTER] INDEX index_name      ON table_name(column_name排S序⽅式...)A  排序:关键字ASC表⽰升序排列,关键字DESC表⽰降序排列  

  数据的查询操作  查询全部列的数据记录    SELECT *FROM table_name or view_name[,table_name1 or view_name1]  查询表中指定的列  SELECT ⽬标列[,⽬标列...]  FROM 表名或者视图名[,表名或者视图名...]    在SELECT语句中查询数据表或者视图指定的列时,在SELECT语句中指定的列名必须是指定的数据表或者视图中存在的列查询表中不重复的记录    SELECT DISTINCT⽬标列[,⽬标列...]    FROM表名或者视图名[,表名或者视图名...]  使⽤列别名查询    SELECT⽬标列[AS]列别名[,⽬标列 [AS] 列别名...]    FROM表名或者视图名[,表名或者视图名...]    在SELECT语句中使⽤别列名的形式对数据表或者视图查询时,可以在查询的列名后⾯使⽤⼀个空格键来代替AS,空格后⾯再跟上列别名的名字。如果列别名对字母⼤⼩写敏感,或者在使⽤包含有空格或者特殊字符的列别名,则必须使⽤单引号或者双引号将其引起来,否则系统将报错。  对查询的记录进⾏运算    SELECT语句还可以使⽤算术符对指定的列进⾏运算,其中算术运算符包括加减乘除以及模除,在SELECT语句中对指定的列进⾏算术符进⾏运算时,只会改变显⽰的结果,并不会改变显⽰的结果,并不会改变数据表中列的原有值  使⽤连接符(||)连接字段    在ORACLE中,可以使⽤||连接符连接多个字段,在使⽤连接符时,连接的数据类型应该是相同的,如果不同系统将会报错,如果需要在连接的字段加⼊字符或者⽇期类型的值,需要将该字符值或者⽇期类型的值使⽤单引号引起来。注意,在MYSQL和MYSQLSERVER中并不⽀持连接符||,在MYSQL中可以使⽤CONCAT函数,在MS SQL SERVER中可以使⽤+来连接  关于NULL 值    在数据库中,如果没有为该类赋值,⽽且该列也没有默认值,此时查询的结果就为空,即NULL使⽤WHERE⼦句查询表中满⾜条件的记录  ⽐较查询    ⽐较运算符分为三类,算数⽐较运算符,BETWEEN AND,IN  算术⽐较运算符    SQL语句中的算术⽐较运算符主要包括 = >= <= > < != <>(不等于) !>(不⼤于) !<(不⼩于),在SELECT语句的WHERE⼦句中可以使⽤算术⽐较运算符对指定的列进⾏⽐较,应指出的是,在MS SQL SERVER 中,<>不是不等于的意思    在SQL语句中,如果在WHERE⼦句中⽐较时整数型数据,则可以不⽤使⽤单引号,如果⽐较的是其他的数据类型,如字符串、⽇期等,则必须⽤单引号引起来,另外,WHERE⼦句中⽐较运算符的左侧和右侧的数据类型必须是类型兼容的        

2023年6月21日发(作者:)

SQL数据库基础语法SQL语句的概述SQL语⾔的分类  数据定义语⾔(Data Definition Language)主要⽤于修改、创建和删除数据库对象,其中包括CREATE ALTER DROP语句。  数据查询语⾔(Data Query Language)主要⽤于查询数据库中的数据,其主要是SELECT语句,SELECT语句包括五个⼦句,分别是FROM WHERE HAVING GROUP BY和WITH语句。  数据操作语⾔(Data Manipulation Language)主要⽤于更新数据库⾥数据表中的数据,包括INSERT UODATE DELETE语句。  数据控制语⾔(Data Control Language)主要⽤于授予和回收访问数据库的某种权限。包括GRANT REVOKE等语句。  事物控制语⾔,主要⽤于数据库对事物的控制,保证数据库中数据的⼀致性,包括COMMIT ROLLBACK语句。  常⽤的数据类型    MYSQL:      

  SQL语句的书写规范    SQL语句中不区分关键字的⼤⼩写    SQL语句中不区分列名和对象名的⼤⼩写    SQL语句对数据库中数据的⼤⼩写敏感    SQL语句中使⽤--注释时,--后⾯⾄少有⼀个空格,多⾏注释⽤/* */  数据库的创建与删除  (1)数据库的创建:    CREATE DATABASE database_name;    在中书写SQL语句时,在SQL语句后⾯都要加上分号  (2)数据库的删除    DROP DATABASE database_name;数据表的创建与更新  数据库中的表  (1)数据记录:在数据表中的每⼀⾏被称为数据记录  (2)字段:数据表中的每⼀列被称为字段  (3)主键(PRIMARY KEY):作为数据表中唯⼀的表⽰,保证了每⼀天数记录的唯⼀性。逐渐在关系数据库中约束实体完整性。所谓实体完整性,是指对数据表⾏的约束。  (4)外键(FOREIGN KEY):外键⽤来定义表与表之间的关系。在数据表中,如果属性列F是关系B中的⼀个属性(并不是关系B的主键),并且属性列F是关系A的主键,则F就是B的外键。外键在关系数据库中的约束参照完整性。所谓参照完整性是指表与表之间的约束。  (5)索引:索引是指向数据表中的⼀个指针,指向索引字段在数据表中的物理位置。⼀般可以在如下⼏种情况下建⽴索引  在主键列中创建索引    多表连接时,在经常使⽤的连接列上创建索引     在经常使⽤WHERE⼦句查询的列上创建索引    在经常进⾏分组GROUP BY及排序ORDER BY的列上创建索引  (6)约束:为了保证数据的完整性需要使⽤约束    唯⼀约束(UNIQUE)使⽤唯⼀约束的某⼀列或者某⼀组中没有相同的值,即保证了值的唯⼀性。但是唯⼀约束中可以插⼊NULL值。    主键约束(PRIMARY KEY)保证使⽤主键约束的列中只能有唯⼀的值,并且不能包含NULL值,数据表中每⼀列只能定义⼀个PRIMARY KEY    外键约束(FOREIGN KEY)保证表参照完整性,确保对⼀个数据表的数据操作不会对与之关联的表造成不利的影响    检查约束(CHECK)限制列的取值范围或者取值条件,可以为⼀个列定义多个CHECK约束    ⾮空约束(NOT NULL)⽤于对列的约束  创建数据表:    CREATE TABLE table_name(    column_name1 datatype [constraint_condition1]    [,column name2 datatype [constraint_condition2]    ...)  使⽤约束  (1)唯⼀约束(UNIQUE)⽤来保证某⼀列中没有相同的值列或者某⼀组列中没有相同的值,⼀般为列创建了⼀个约束后,数据库会⾃动为该列建⽴⼀个唯⼀索引,其索引名与约束名相同  例如:CREATE TABLE T_dept(      dept_ID VARCHAR(15) UNIQUE,      dept_Name VARCHAR(10)  (2)主键约束    CREATE TABLE T_result(    stuID VARCHAR(15),    cruID VARCHAR(15),    result DOUBLE,    PRIMARY KEY(stuID,curID)    )  (3)外键约束    FOREIGN KEY[表名1](列名1)REFERENCE 表名2 (列名2)    [ON UPDATE [CASCADE]|[SET NULL]|[RESTRICT]]    [ON DELETE [CASCADE]|[SET NULL]|[RESTRICT]]  其中,FOREIGN KEY是关键字,表名1是可选的,列名1是指定数据表中⽤于外键约束的外键,表名2表⽰主表的名字,列名2主表中与从表中列名1相对应列的名字,后⾯的ON UPDATE  ON DELETE表⽰对表中的数据的修改或者删除,从主表之间采取什么样的操作⽅式,是可选的    CASCADE:级联删除,如果主表中⼀条数据记录被删除,从表中的数据也将删除    SET NULL:置空删除,如果主表中的⼀条数据记录南北删除,从表中与之相连的数据也将置空    RESTRICE:受限删除,如果主表中的⼀条数据被删除,则在执⾏DELETE语句时系统会报错,通知⽤户与主表相对应的数据在从表中依然存在,但是与主表相对应的数据在从表中不被删除,它是默认的⽅式  CREATE TABLE T_result(   stuID VARCHAR(15),   curID VARCHAR(15),   result DOUBLE,   FOREIGN KEY (stuID) REFERCES T_student (stuID) ON DELETE CASCADE,   PRIMARY KEY (stuID,curID)  )  (4)检查约束CHECK  CREATE TABLE T_curriculum(  curID VARCHAR(15) PRIMARY KEY  curName VARCHAR(10),  credit INT,  CHECK(credit BETWEEN 3 AND 8)  )  (5)⾮空约束NOT NULL  使⽤索引  (1)唯⼀索引:在数据表中使⽤UNIQUE可以为⼀个数据列定义⼀个唯⼀索引,唯⼀索引中的每⼀个索引值只对应数据表中的⼀条记录,保证了数据列中记录的唯⼀性  (2)主索引:在数据表中使⽤PRIMARY KEY可以为⼀个数据列定义⼀个主索引,所谓的主索引就是在主键列中建⽴索引  (3)单列索引:定义在数据表中⼀个数据列上的索引就是单列索引,⼀般在数据查询时,如果WHERE⼦句中经常⽤到的数据表中的某⼀列作为查询条件,就可以把该列创建为单列索引  (4)复合索引:索引可以定义在⼀个数据表的多个数据列上,像这样的索引被称为复合索引  (5)聚簇索引:创建与删除索引      CREATE [UNIQUE]|[CLUSTER] INDEX index_name      ON table_name(column_name排S序⽅式...)A  排序:关键字ASC表⽰升序排列,关键字DESC表⽰降序排列  

  数据的查询操作  查询全部列的数据记录    SELECT *FROM table_name or view_name[,table_name1 or view_name1]  查询表中指定的列  SELECT ⽬标列[,⽬标列...]  FROM 表名或者视图名[,表名或者视图名...]    在SELECT语句中查询数据表或者视图指定的列时,在SELECT语句中指定的列名必须是指定的数据表或者视图中存在的列查询表中不重复的记录    SELECT DISTINCT⽬标列[,⽬标列...]    FROM表名或者视图名[,表名或者视图名...]  使⽤列别名查询    SELECT⽬标列[AS]列别名[,⽬标列 [AS] 列别名...]    FROM表名或者视图名[,表名或者视图名...]    在SELECT语句中使⽤别列名的形式对数据表或者视图查询时,可以在查询的列名后⾯使⽤⼀个空格键来代替AS,空格后⾯再跟上列别名的名字。如果列别名对字母⼤⼩写敏感,或者在使⽤包含有空格或者特殊字符的列别名,则必须使⽤单引号或者双引号将其引起来,否则系统将报错。  对查询的记录进⾏运算    SELECT语句还可以使⽤算术符对指定的列进⾏运算,其中算术运算符包括加减乘除以及模除,在SELECT语句中对指定的列进⾏算术符进⾏运算时,只会改变显⽰的结果,并不会改变显⽰的结果,并不会改变数据表中列的原有值  使⽤连接符(||)连接字段    在ORACLE中,可以使⽤||连接符连接多个字段,在使⽤连接符时,连接的数据类型应该是相同的,如果不同系统将会报错,如果需要在连接的字段加⼊字符或者⽇期类型的值,需要将该字符值或者⽇期类型的值使⽤单引号引起来。注意,在MYSQL和MYSQLSERVER中并不⽀持连接符||,在MYSQL中可以使⽤CONCAT函数,在MS SQL SERVER中可以使⽤+来连接  关于NULL 值    在数据库中,如果没有为该类赋值,⽽且该列也没有默认值,此时查询的结果就为空,即NULL使⽤WHERE⼦句查询表中满⾜条件的记录  ⽐较查询    ⽐较运算符分为三类,算数⽐较运算符,BETWEEN AND,IN  算术⽐较运算符    SQL语句中的算术⽐较运算符主要包括 = >= <= > < != <>(不等于) !>(不⼤于) !<(不⼩于),在SELECT语句的WHERE⼦句中可以使⽤算术⽐较运算符对指定的列进⾏⽐较,应指出的是,在MS SQL SERVER 中,<>不是不等于的意思    在SQL语句中,如果在WHERE⼦句中⽐较时整数型数据,则可以不⽤使⽤单引号,如果⽐较的是其他的数据类型,如字符串、⽇期等,则必须⽤单引号引起来,另外,WHERE⼦句中⽐较运算符的左侧和右侧的数据类型必须是类型兼容的