sqlserverWord文档下载推荐.docx
《sqlserverWord文档下载推荐.docx》由会员分享,可在线阅读,更多相关《sqlserverWord文档下载推荐.docx(40页珍藏版)》请在冰豆网上搜索。
数据库中的每一个表格都具有自己唯一的表格名称,都是由行和列组成,其中每一列包括了该列名称,数据类型,以及列的其它属性等信息,而行则具体包含某一列的记录或数据。
以下,是一个名为天气的数据库表格的实例。
QUOTE:
城市最高气温最低气温北京105上海158天津82重庆2013该表格中“城市”,“最高气温”和“最低气温”就是三个不同的列,而表格中的每一行则包含了具体的表格数据。
数据查询在众多的SQL命令中,select语句应该算是使用最频繁的。
Select语句主要被用来对数据库进行查询并返回符合用户查询标准的结果数据。
Select语句的语法格式如下:
selectcolumn1,column2,etcfromtablenamewherecondition;
(表示可选项)select语句中位于select关键词之后的列名用来决定那些列将作为查询结果返回。
用户可以按照自己的需要选择任意列,还可以使用通配符“*”来设定返回表格中的所有列。
select语句中位于from关键词之后的表格名称用来决定将要进行查询操作的目标表格。
Select语句中的where可选从句用来规定哪些数据值或哪些行将被作为查询结果返回或显示。
在where条件从句中可以使用以下一些运算符来设定查询标准:
=等于大于小于=大于等于=小于等于不等于除了上面所提到的运算符外,LIKE运算符在where条件从句中也非常重要。
LIKE运算符的功能非常强大,通过使用LIKE运算符可以设定只选择与用户规定格式相同的记录。
此外,我们还可以使用通配符“%”用来代替任何字符串。
举例如下:
selectfirstname,lastname,cityfromemployeewherefirstnameLIKEE%;
(注意,字符串必须被包含在单括号内)上述SQL语句将会查询所有名称以E开头的姓名。
或者,通过如下语句:
select*fromemployeewherefirstname=May;
查询所有名称为May的行。
SQL语言中的createtable语句被用来建立新的数据库表格。
Createtable语句的使用格式如下:
createtabletablename(column1datatype,column2datatype,column3datatype);
如果用户希望在建立新表格时规定列的限制条件,可以使用可选的条件选项:
createtabletablename(column1datatypeconstraint,column2datatypeconstraint,column3datatypeconstraint);
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);
例如:
/quoteinsertintoemployee(firstname,lastname,age,address,city)values(Li,Ming,45,No.77ChanganRoad,Beijing”);
/quote简单来说,当向数据库表格中添加新记录时,在关键词insertinto后面输入所要添加的表格名称,然后在括号中列出将要添加新值的列的名称。
最后,在关键词values的后面按照前面输入的列的顺序对应的输入所有要添加的记录值。
更新记录SQL语言使用update语句更新或修改满足规定条件的现有记录。
Update语句的格式为:
updatetablenamesetcolumnname=newvalue,nextcolumn=newvalue2.wherecolumnnameOPERATORvalueandorcolumnOPERATORvalue;
updateemployeesetage=age+1wherefirst_name=Maryandlast_name=Williams;
使用update语句时,关键一点就是要设定好用于进行判断的where条件从句。
删除记录SQL语言使用delete语句删除数据库表格中的行或记录。
Delete语句的格式为:
deletefromtablenamewherecolumnnameOPERATORvalueandorcolumnOPERATORvalue;
deletefromemployeewherelastname=May;
简单来说,当需要删除某一行或某个记录时,在deletefrom关键词之后输入表格名称,然后在where从句中设定删除记录的判断条件。
注意,如果用户在使用delete语句时不设定where从句,则表格中的所有记录将全部被删除。
删除数据库表格在SQL语言中使用droptable命令删除某个表格以及该表格中的所有记录。
Droptable命令的使用格式为:
droptabletablename;
droptableemployee;
如果用户希望将某个数据库表格完全删除,只需要在droptable命令后输入希望删除的表格名称即可。
Droptable命令的作用与删除表格中的所有记录不同。
删除表格中的全部记录之后,该表格仍然存在,而且表格中列的信息不会改变。
而使用droptable命令则会将整个数据库表格的所有信息全部删除。
以上,我们对SQL语言主要的命令和语句进行了较为详细的介绍。
应该说SQL语句的语法结构和风格还是相当简单和直观的,只要用户结合实践多加练习,一定会在短期内迅速掌握。
SELECTFROM为方便讲解,我们在数据库中创建名为Store_Information的如下数据表。
Store_InformationStore_NameSalesDateLosAngeles$1500Jan-10-2000SanDiego$250Jan-11-2000LosAngeles$300Jan-12-2000Boston$700Jan-12-2000SQL语言中用于数据库查询的最简单的命令就是SELECTFROM,语法格式为:
SELECTcolumn_nameFROMtable_name例如,如果我们希望查询Store_Information数据表中所有的商店名称时,可以使用如下命令:
SELECTstore_nameFROMStore_Information查询结果显示为:
Store_NameLosAngelesSanDiegoLosAngelesBoston如果用户希望一次查询多个字段,可以将所要查询的字段名称依次加入SELECT关键字之后,中间用“,”隔开即可。
DISTINCTSELECT关键字支持用户查询数据表中指定字段的所有数据,但是这样有时就会不可避免的出现重复信息。
如果用户希望只查询那些具有不同记录值的信息的话,可以使用SQL语言的DISTINCT关键字。
语法格式如下:
SELECTDISTINCTcolumn_nameFROMtable_name例如,我们可以使用以下命令查询Store_Information数据表具有不同记录值的所有记录。
SELECTDISTINCTStore_NameFROMStore_Information查询结果如下:
Store_NameLosAngelesSanDiegoBostonWHERE除了选择具有不同记录值的记录之外,有时我们可能还会需要根据某些条件对数据库中的数据进行查询。
例如,我们可能需要查询Store_Information数据表中销售额超过1000美圆的商店。
为此,我们可以使用SQL语言的WHERE关键字设定查询条件。
SELECTcolumn_nameFROMtable_nameWHEREcondition由此,我们可以使用如下命令查询销售额超过1000美圆的商店信息:
SELECTstore_nameFROMStore_InformationWHERESales1000查询结果显示为:
store_nameLosAngeles运算函数现在,我们已经了解到在使用SQL语言进行数据库查询操作时可以通过对数值的判断设定灵活的查询条件。
为了增强对运算的支持能力,SQL提供了众多实用的运算函数供广大用户使用。
例如,我们可以直接在SQL命令中调用SUM或AVG这两个分别用于计算总数和平均数的函数。
SELECTfunctiontype(column_name)FROMtable_name如果我们希望查询Store_Information数据表中所有商店的总销售额的话,可以使用如下命令:
SELECTSUM(Sales)FROMStore_Information查询结果显示为:
SUM(Sales)$2750COUNT除了SUM和AVG函数之外,COUNT函数是SQL语言中另一个较为常用的运算函数。
COUNT函数可以用来计算数据表中指定字段所包含的记录数目。
语法格式为:
SELECTCOUNT(column_name)FROMtable_name例如,如果我们希望查询Store_Information数据表中的有关商店的记录条数时,可以使用如下命令:
SELECTCOUNT(store_name)FROMStore_Information查询结果显示为:
Count(store_name)4COUNT函数可以和DISTINCT关键字一起使用从而可以查询数据表中指定字段中所有具有不同记录值的记录数目。
例如,如果我们希望查询Store_Information数据表中不同商店的数目时,可以使用如下命令:
SELECTCOUNT(DISTINCTstore_name)FROMStore_Information查询结果显示为:
Count(DISTINCTstore_name)3GROUPBY下面我们来进一步看一下SQL语言中的集合函数。
上文中,我们曾使用SUM函数计算所有商店的销售总额,如果我们希望计算每一家商店各自的总销售额时该怎么办呢?
要实现这一目的我们需要做两件事:
首先,我们需要查询商店名称和销售额两个字段;
然后,我们使用SQL语言的GROUPBY命令将销售额按照不同的商店进行分组,从而计算出不同商店的销售总额。
GROUPBY命令的语法格式为:
SELECTcolumn_name1,SUM(column_name2)FROMtable_nameGROUPBYcolumn_name1我们可以使用如下命令实现上述查询目的:
SELECTstore_name,SUM(Sales)FROMStore_InformationGROUPBYstore_name查询结果显示为:
store_nameSUM(Sales)LosAngeles$1800SanDiego$250Boston$700小注:
GROUPBY关键字一般应用于同时查询多个字段并对字段进行算术运算的SQL命令中。
HAVING用户在使用SQL语言的过程中可能希望解决的另一个问题就是对由sum或其它集合函数运算结果的输出进行限制。
例如,我们可能只希望看到Store_Information数据表中销售总额超过1500美圆的商店的信息,这时我们就需要使用HAVING从句。
SELECTcolumn_name1,SUM(column_name2)FROMtable_nameGROUPBYcolumn_name1HAVING(arithematicfunctioncondition)(GROUPBY从句可选)由此,我们可以使用如下命令实现上述查询目的:
SELECTstore_name,SUM(sales)FROMStore_InformationGROUPBYstore_nameHAVINGSUM(sales)1500查询结果显示为:
store_nameSUM(Sales)LosAngeles$1800小注:
SQL语言中设定集合函数的查询条件时使用HAVING从句而不是WHERE从句。
通常情况下,HAVING从句被放置在SQL命令的结尾处。
ALIAS下面,我们重点介绍一下如何在SQL命令中设定别名。
SQL语言中一般使用两种类型的别名,分别为字段别名和数据表别名。
简单的说,使用字段别名可以帮助我们有效的组织查询的输出结果。
例如,上文所列举的多个实例中,当