SQL语言入门.docx
《SQL语言入门.docx》由会员分享,可在线阅读,更多相关《SQL语言入门.docx(14页珍藏版)》请在冰豆网上搜索。
SQL语言入门
SQL语言入门
SQL是英文StructuredQueryLanguage的缩写,意思为结构化查询语言。
SQL语言的主要功能就是同各种数据库建立联系,进行沟通。
按照ANSI(美国国家标准协会)的规定,SQL被作为关系型数据库管理系统的标准语言。
SQL语句可以用来执行各种各样的操作,例如更新数据库中的数据,从数据库中提取数据等。
目前,绝大多数流行的关系型数据库管理系统,如Oracle,Sybase,MicrosoftSQLServer,Access等都采用了SQL语言标准。
虽然很多数据库都对SQL语句进行了再开发和扩展,但是包括Select,Insert,Update,Delete,Create,以及Drop在内的标准的SQL命令仍然可以被用来完成几乎所有的数据库操作。
下面,我们就来详细介绍一下SQL语言的基本知识。
数据库表格
一个典型的关系型数据库通常由一个或多个被称作表格的对象组成。
数据库中的所有数据或信息都被保存在这些数据库表格中。
数据库中的每一个表格都具有自己唯一的表格名称,都是由行和列组成,其中每一列包括了该列名称,数据类型,以及列的其它属性等信息,而行则具体包含某一列的记录或数据。
以下,是一个名为天气的数据库表格的实例。
城市最高气温最低气温
北京105
上海158
天津82
重庆2013
该表格中“城市”,“最高气温”和“最低气温”就是三个不同的列,而表格中的每一行则包含了具体的表格数据。
数据查询
在众多的SQL命令中,select语句应该算是使用最频繁的。
Select语句主要被用来对数据库进行查询并返回符合用户查询标准的结果数据。
Select语句的语法格式如下:
selectcolumn1[,column2,etc]fromtablename
[wherecondition];
([]表示可选项)
select语句中位于select关键词之后的列名用来决定那些列将作为查询结果返回。
用户可以按照自己的需要选择任意列,还可以使用通配符“*”来设定返回表格中的所有列。
select语句中位于from关键词之后的表格名称用来决定将要进行查询操作的目标表格。
Select语句中的where可选从句用来规定哪些数据值或哪些行将被作为查询结果返回或显示。
在where条件从句中可以使用以下一些运算符来设定查询标准:
=等于
>大于
<小于
>=大于等于
<=小于等于
<>不等于
除了上面所提到的运算符外,LIKE运算符在where条件从句中也非常重要。
LIKE运算符的功能非常强大,通过使用LIKE运算符可以设定只选择与用户规定格式相同的记录。
此外,我们还可以使用通配符“%”用来代替任何字符串。
举例如下:
selectfirstname,lastname,cityfromemployeewherefirstnameLIKE‘E%’;
(注意,字符串必须被包含在单括号内)
上述SQL语句将会查询所有名称以E开头的姓名。
或者,通过如下语句:
select*fromemployeewherefirstname=‘May’;
查询所有名称为May的行。
创建表格
SQL语言中的createtable语句被用来建立新的数据库表格。
Createtable语句的使用格式如下:
createtabletablename(column1datatype,column2datatype,column3datatype);
如果用户希望在建立新表格时规定列的限制条件,可以使用可选的条件选项:
createtabletablename(column1datatype[constraint],column2datatype[constraint],column3datatype[constraint]);
举例如下:
createtableemployee(firstnamevarchar(15),lastnamevarchar(20),agenumber(3),addressvarchar(30),cityvarchar(20));
简单来说,创建新表格时,在关键词createtable后面加入所要建立的表格的名称,然后在括号内顺次设定各列的名称,数据类型,以及可选的限制条件等。
注意,所有的SQL语句在结尾处都要使用“;”符号。
使用SQL语句创建的数据库表格和表格中列的名称必须以字母开头,后面可以使用字母,数字或下划线,名称的长度不能超过30个字符。
注意,用户在选择表格名称时不要使用SQL语言中的保留关键词,如select,create,insert等,作为表格或列的名称。
数据类型用来设定某一个具体列中数据的类型。
例如,在姓名列中只能采用varchar或char的数据类型,而不能使用number的数据类型。
SQL语言中较为常用的数据类型为:
char(size):
固定长度字符串,其中括号中的size用来设定字符串的最大长度。
Char类型的最大长度为255字节。
varchar(size):
可变长度字符串,最大长度由size设定。
number(size):
数字类型,其中数字的最大位数由size设定。
Date:
日期类型。
number(size,d):
数字类型,size决定该数字总的最大位数,而d则用于设定该数字在小数点后的位数。
最后,在创建新表格时需要注意的一点就是表格中列的限制条件。
所谓限制条件就是当向特定列输入数据时所必须遵守的规则。
例如,unique这一限制条件要求某一列中不能存在两个值相同的记录,所有记录的值都必须是唯一的。
除unique之外,较为常用的列的限制条件还包括notnull和primarykey等。
Notnull用来规定表格中某一列的值不能为空。
Primarykey则为表格中的所有记录规定了唯一的标识符。
向表格中插入数据
SQL语言使用insert语句向数据库表格中插入或添加新的数据行。
Insert语句的使用格式如下:
insertintotablename(first_column,...last_column)
values(first_value,...last_value);
例如:
insertintoemployee(firstname,lastname,age,address,city)values(‘Li’,‘Ming’,45,‘No.77ChanganRoad’,‘Beijing”);
简单来说,当向数据库表格中添加新记录时,在关键词insertinto后面输入所要添加的表格名称,然后在括号中列出将要添加新值的列的名称。
最后,在关键词values的后面按照前面输入的列的顺序对应的输入所有要添加的记录值。
更新记录
SQL语言使用update语句更新或修改满足规定条件的现有记录。
Update语句的格式为:
updatetablenamesetcolumnname=newvalue[,nextcolumn=newvalue2...]wherecolumnnameOPERATORvalue[and|orcolumnOPERATORvalue];
例如:
updateemployeesetage=age+1wherefirst_name=‘Mary’andlast_name=‘Williams’;
使用update语句时,关键一点就是要设定好用于进行判断的where条件从句。
删除记录
SQL语言使用delete语句删除数据库表格中的行或记录。
Delete语句的格式为:
deletefromtablenamewherecolumnnameOPERATORvalue[and|orcolumnOPERATORvalue];
例如:
deletefromemployee
wherelastname=May;
简单来说,当需要删除某一行或某个记录时,在deletefrom关键词之后输入表格名称,然后在where从句中设定删除记录的判断条件。
注意,如果用户在使用delete语句时不设定where从句,则表格中的所有记录将全部被删除。
删除数据库表格
在SQL语言中使用droptable命令删除某个表格以及该表格中的所有记录。
Droptable命令的使用格式为:
droptabletablename;
例如:
droptableemployee;
如果用户希望将某个数据库表格完全删除,只需要在droptable命令后输入希望删除的表格名称即可。
Droptable命令的作用与删除表格中的所有记录不同。
删除表格中的全部记录之后,该表格仍然存在,而且表格中列的信息不会改变。
而使用droptable命令则会将整个数据库表格的所有信息全部删除。
我们日常使用SQL语言的工作过程中,使用最多的还是从已经建立好的数据库中查询信息。
下面,我们就来详细介绍一下如何使用SQL语言实现各种数据库查询操作。
SELECT…FROM
为方便讲解,我们在数据库中创建名为Store_Information的如下数据表。
Store_Information
Store_Name
Sales
Date
LosAngeles
$1500
Jan-10-2000
SanDiego
$250
Jan-11-2000
LosAngeles
$300
Jan-12-2000
Boston
$700
Jan-12-2000
SQL语言中用于数据库查询的最简单的命令就是SELECT…FROM,语法格式为:
SELECT"column_name"FROM"table_name"
例如,如果我们希望查询Store_Information数据表中所有的商店名称时,可以使用如下命令:
SELECTstore_nameFROMStore_Information
查询结果显示为:
Store_Name
LosAngeles
SanDiego
LosAngeles
Boston
如果用户希望一次查询多个字段,可以将所要查询的字段名称依次加入SELECT关键字之后,中间用“,”隔开即可。
DISTINCT
SELECT关键字支持用户查询数据表中指定字段的所有数据,但是这样有时就会不可避免的出现重复信息。
如果用户希望只查询那些具有不同记录值的信息的话,可以使用SQL语言的DISTINCT关键字。
语法格式如下:
SELECTDISTINCT"column_name"
FROM"table_name"
例如,我们可以使用以下命令查询Store_Information数据表具有不同记录值的所有记录。
SELECTDISTINCTStore_NameFROMStore_Information
查询结果如下:
Store_Name
LosAngeles
SanDiego
Boston
WHERE
除了选择具有不同记录值的记录之外,有时我们可能还会需要根据某些条件对数据库中的数据进行查询。
例如,我们可能需要查询Store_Information数据表中销售额超过1000美圆的商店。
为此,我们可以使用SQL语言的WHERE关键字设定查询条件。
语法格式如下:
SELECT"column_name"
FROM"table_name"
WHERE"condition"
由此,我们可以使用如下命令查询销售额超过1000美圆的商店信息:
SELECTstore_nameFROMStore_InformationWHERESales>1000
查询结果显示为:
store_name
LosAngeles
运算函数
现在,我们已经了解到在使用SQL语言进行数据库查询操作时可以通过对数值的判断设定灵活的查询条件。
为了增强对运算的支持能力,SQL提供了众多实用的运算函数供广大用户使用。
例如,我们可以直接在SQL命令中调用SUM或AVG这两个分别用于计算总数和平均数的函数。
语法格式如下:
SELECT"functiontype"("column_name")
FROM"table_name"
如果我们希望查询Store_Information数据表中所有商店的总销售额的话,可以使用如下命令:
SELECTSUM(Sales)FROMStore_Information
查询结果显示为:
SUM(Sales)
$2750
COUNT
除了SUM和AVG函数之外,COUNT函数是SQL语言中另一个较为常用的运算函数。
COUNT函数可以用来计算数据表中指定字段所包含的记录数目。
语法格式为:
SELECTCOUNT("column_name")
FROM"table_name"
例如,如果我们希望查询Store_Information数据表中的有关商店的记录条数时,可以使用如下命令:
SELECTCOUNT(store_name)
FROMStore_Information
查询结果显示为:
Count(store_name)
4
COUNT函数可以和DISTINCT关键字一起使用从而可以查询数据表中指定字段中所有具有不同记录值的记录数目。
例如,如果我们希望查询Store_Information数据表中不同商店的数目时,可以使用如下命令:
SELECTCOUNT(DISTINCTstore_name)
FROMStore_Information
查询结果显示为:
Count(DISTINCTstore_name)
3
GROUPBY
下面我们来进一步看一下SQL语言中的集合函数。
上文中,我们曾使用SUM函数计算所有商店的销售总额,如果我们希望计算每一家商店各自的总销售额时该怎么办呢?
要实现这一目的我们需要做两件事:
首先,我们需要查询商店名称和销售额两个字段;然后,我们使用SQL语言的GROUPBY命令将销售额按照不同的商店进行分组,从而计算出不同商店的销售总额。
GROUPBY命令的语法格式为:
SELECT"column_name1",SUM("column_name2")
FROM"table_na
Sql表数据操作
表数据操作包括数据的插入、修改和删除。
一、插入数据
在向表中添加数据时应该注意两点:
第一是用户权限,只有sysadmin角包成员、数据库和数据库对
象所有者及其授权用户才有权限向表中添加数据;第二是数据格式,对于不同的数据类型,插入数据的
格式也不一样,应严格遵守它们各自的格式要求。
Transact-SQL语言中用INSERT语句向表或视图中插入新的数据行。
INSERT语句的语法格式为:
INSERT[INTO]table_source
{[column_list]
VALUES({DEFAULT|constant_expression}[,…n])
|DEFAULTVALUES
|select_statement
|execute_statement
}
}
其中,column_list参数为新插入数据行中一列或多列列名列表,它说明INSERT语句只为指定列插
入数据。
在给表或视中部分列插入数据时,必须使用列名列表方式指出这部分列名。
其余未指定列的列
值要根据它们的默认值和空值属性情况而定,它们有以下几种可能取值:
(1)对于timestamp列或具有IDENTITY属性列,它们的列值由SQLServer计算后自动赋值。
(2)如果这些列有默认值或关联有默认数据库对象,插入新列时,它们的值为默认值。
(3)当这些列没有默认值设置时,但它们允许空值时,该列值为空。
(4)当这些列既没有默认值设置,也不允许空值时,SQLServer在执行INSERT语句时将产生错误,
导致插入操作失败。
当未指定column_list参数时,为各列所提供的数据顺序应严格按照表中各列的定义顺序,而使用
column_list参数则可以调整向表中所插入数据的列顺序,只要VALUES子句所提供的数据顺序与column_
list参数中指定的列顺序相同即可。
VALUES子句为新插入行中column_list参数所指定列提供数据,这些数据可以以常量表达式形式提
供,或使用DEFAULT关键字说明向列中插入其默认值。
DEFAULTVALUES说明向表中所有列插入其默认值。
对于具有INDENTITY属性或timestamp数据类型
列,系统将自动插入下一个适当值。
对于没有设置默认值的列,如果它们允许空值,SQLServer将插入
null,否则返回一错误消息。
select_statement是标准的数据库查询语句,它是SQLServer为INSERT语句所提供的又一种数据插
入方式。
INSERT语句将select_statement子句所返回的结果集合数据插入到指定表中。
查询语句结果集
合每行中的数据数量、数据类型和排列顺序也必须与表中所定义列或column_list参数中指定列的数
量、数据类型和排列顺序完全相同。
SQLServer为INSERT语句提供的第四种数据插入方式是通过执行系统存储过程,其数据来自于过程
执行后所产生的结果集合。
所执行的过程可以为存储过程、系统存储过程或扩展存储过程,它们既可以
为本地存储过程,又可以是远程服务器上的存储过程,只要用户具有它们的执行权限即可。
有关存储过
程请参阅对应的内容。
table_source说明INSERT语句插入数据时所操作的表或视图,其语法格式可简单书写为:
{table_name[[AS]table_alias]
|view_name[[AS]table_alias]
}
table_name和view_name说明被插入数据的表或视图名称,table_alias参数为表或视图设置别名。
使用别名有两方面原因:
第一、当表或视图名称较长时,使用别名可以简化书写工作;第二,在自连接
或子查询中,使用别名可以区别同一个表或视图。
在向表中插入数据时,如果所插入的数据与约束或规则的要求冲突,或是它们的数据类型不兼容
时,将导致INSERT语句执行失败。
当使用SELECT或EXECUTE子句向表中一次插入多行数据时,如果其中
有任一行数据有误,它将导致整个插入操作失败,使SQLServer停止所有数据行的插入操作。
例一、使用数值列表方式(假定usertable表中只定义了name、age和sex字段,且name、sex均为
char类型,age为int类型)。
INSERTusertable
VALUES('张三','女',18)
例二、使用列名列表方式
INSERTusertable(age,name)
VALUES(18,'张三')
例三、在数值列表中,还可以将变量的值插入到表中。
在使用变量为列提供数据时,应保证变量的
数据类型与列数据类型相同,或是可以自动将它们转换为相同的数据类型。
例如:
DECLARE@namechar(16)
SET@name='张三'
INSERTusertable
VALUES(@name,DEFAULT,20)
本例中Asp中是这样的:
dimname
name="张三"
sqlstr="INSERTusertableVALUES('"&name&"','女',20)"
……
例四、将SELECT子句的所返回的结果集合插入到表中。
例如:
INSERTusertable(name,sex,age)
SELECT's'+name,sex,age
FROMusertable
WHEREnamelike'张%%'
二、修改数据
Transact-SQL中的UPDATE语句用于修改表中数据,该语句的语法格式为:
UPDATE()
SET(
column_name={expression|DEFAULT}
|@variable=expression
}[,…n]
[FROM
{
|(select_statement)[AS]table_alias[,…m])]
}
[,…n]
]
[WHERE
|CURRENTOF({[GLOBAL]cursor_name}|cursor_variable_name}}
]
别看写了一大堆,最常用的只是下列格式:
UPDATEtable_name
SETcolumn_name1=variable1,column_name2=variable2
WHEREsearch_conditions
其中table_or_view参数指出待修改的表或视图名称,其格式与INSERT语句中该参数的格式相同。
SET子句指出表中被修改的列或变量,以及它们的新值。
column_name为被修改的列名,@variable
为一个已经声明的局部变量名称,它们修改后的值由expression表达式提供,或使用DEFAULT关键字将
默认值赋给指定列。
FROM子句引出另一个表,它为UPDATE语句的数据修改操作提供条件。
WHERE子句中的search_conditions参数说明UPDATE语句的修改条件,它指出表或视图中的哪些行
需要修改。
省略WHERE子句时,说明对指定的表或视图中的所有行进行修改!
!
!
!
WHERE子句中的CURRENTOF说明在游标的当前位置处执行修改操作,游标由curror_name或游标变
量cursor_variable_name指定。
UPDATE不能修改具有IDENTITY属性列的列值。
例一、将usertable表中所有人员的性别改为'男'
UPDATEusertable
SETsex='男'
例二、将性别为null的所有人员的性别改成'男'
UPDATEusertable
SETsex='男'
WHEREsexISNULL
例三、将所有姓名为null的人员的姓名改为'张三'、性别改为'女',年龄改为18
UPDATEusertable
SETname='张三',sex='女',age=18
WHEREnameISNULL
三、删除数据