下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Sybase的数据操纵语言 来源:未知 作者:未知1Select语句基本语法:SELECTall|distinct字段列表into表名from表名where条件表达式group by all字段列表having筛选表达式order by 字段列表asc|desccompute聚集函数列表by字段列表注意:Select语句中的子句必须按照上述顺序使用。也就是说,若该语句包括一个group by子句和一个order by子句where,group by子句必须放在order by子句之前。Having子句类似于where子句,不同之处有两点:(1)Having子句必须结合group by子句使用;
2、(2)where子句不能用聚集函数,而Having子句可以。下面通过实例来对Select的通常用法加以介绍。例1:选择所有的列,语法为select * from table_list如:select * from publishers例2:选择指定的列,语法为select column_name,column_name from table_name如:select pub_id,pub_name from publishers例3:重命名查询结果中的列,语法为select column_heading= column_namefrom table_name如:select Publisher
3、=pub_name,pub_idfrom publishers例4:select列表中的计算值,可以对select列表中的数值数据进行计算,下面列出了算术运算符。符号运算+加-减/除*乘%取模如select title_id,total_sales,total_sales*2 from titles例5:使用distinct消除重复的查询结果可选的关键词消除select语句的结果中的重复行。若不指定distinct,缺省值为all,将检索出包含重复行的所有行数据。如:select distinct au_id from titleauthor例6:选择行where语句select语句中的确切指
4、定要检索哪些行的准则,其一般格式为:select select_list from table_list where search_conditionswhere子句中的搜索条件(或称限制)包括:比较运算符(,!=等如:where advance*2total_sales*price范围(between和not between)如:where total_sales between 5000 and 10000列表(in和not in)如:where state in(“CA”,”IN”,”MD”)匹配字符(like和not like)如:where phone like “0535%”未知值
5、(is null和is not null)如:where advance is null以上各项的组合(and, or)如:where advance5000 or total_sales between 500 and 1000例7:用集合函数小结查询结果集合函数用特定列的数据来计算小结值。集合函数结 果Sum(all|distinctexpression)数值列中(不重复)值的总和Avg(all|distinctexpression)数值列中(不重复)值的平均count(all|distinctexpression)列中(不重复)非空值的数目Count(*)选定的行数Max(express
6、ion)Expression的最大值Min(expression)Expression的最小值如:select avg(advance),sum(total_sales) from titles where type=”as”select count(*) from titlesselect avg(distinct price) from titlesselect max(price) from books例8:分组组织查询结果group by 子句group by 子句用在select语句中将一张表分成若干组。如:select type, advance from titles group
7、 by type例9:选择分组数据having子句having为group by 子句设置条件,与where为select语句设置条件一样。Having搜索条件与where相同,但having可包括集合函数,而where不能包括。下列语句使用带集合函数having子句的例子。它把title表中的行按类型分组,但去掉了那只包含一本书的分组。Select type from titles group by type having count(*)1下面是一个不带集合函数的having子句的例子。它把title表中的行按类型分组,但去掉了那些不以字母“p”开头的类型。Select type from
8、 titles group by type having type like “p%”例10:查询结果排序order by子句Order by子句允许按一列或多列对查询结果排序。每个排序可以是升序的(asc)或降序的(desc)。若不特别指明,则按升序进行。下列查询返回按pub_id排序的结果:Select pub_id,type,title_id from titles order by pub_id例11:连接从多张表中检索数据连接两张或两张以上的表是这样一个过程:比较指定字段中的数据,根据比较结果用符合条件的行组成一张新表。举例:select publishers.pub_id,publ
9、ishers.pub_name,authors.*from publishers,authorswhere publishers.city=authors.city例12:分组计算子句Compute是Sybase对SQL标准中Group子句的扩充,可以将其看作带聚集计算的Group子句。例如:Select type,price,advanceFrom titlesOrder by typeCompute sum(price),sum(advance) by type2Insert语句用Insert命令向数据库中添加行有两种方法:使用关键词values或使用select语句。Insert语句的基
10、本语法为:Insertinto表名(字段列表)values(值列表)|select_statement举例:insert into publishersvalues(1622,Jardin,Inc.,Camden,NJ)Insert into publishers(pub_id,pub_name)values(1756,The Health Center)Insert authors select * from newauthorsInsert authors(au_id,address,au_lname,au_fname)Select * from newauthors3Delect语句De
11、lect可以对一行或多行进行操作。Delect语句的基本语法为:Delect 表名from 表名列表where条件表达式举例:Delect publisherswhere pub_name=”Jardin,Inc.”Delect titlesFrom authors, titlesWhere titles.title_id=authors.title_id4Update语句可以使用Update命令来改动表中的单个行、一组行或所有行。Update语句的基本语法为:Update表名Set column_name1=expression1|null|(select_statement),column_name2=expression2|null|(select_statement)from 表名列表where 条件表达式举
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
评论
0/150
提交评论