ABAP学习笔记--数据查询语句SELECT.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ABAP学习笔记--数据查询语句SELECT

ABAP学习笔记--数据查询语句SELECT c通常使用Open SQL的数据查询语句SELECT将数据库条目选择到内存。一.SELECT语句:1)SELECT用于确定读取数据表中的哪些字段;2)FROM子句用于确定从哪些内表或者视图中读取数据;3)INTO用于确定将数据读取到程序内的哪些数据对象;4)WHERE用于限定选择条件;SELECT select_clause FROM from_clause INTO into_clause WHERE where_clause.在传统的ABAP语言中,如果使用TABLES语句声明表工作区,则可省略INTO子句(此方法已经被ABAP Object禁用)除以上4种外还有:GROUP BY:用于将一组数据条目压缩为一个单行作为选择最终结果;HAVING:用于限定ORDER BY子句子数据目组的选择条件;ORDER BY:用于限定行排序;SELECT整体语法结构:SELECT result FROM source INTO target [WHERE condition] [GROUP BY fields] [HAVING cond] [ORDER BY fields].二.选择单行数据:如果只需要选取一个结果数据行,系统在数据库种找到第一个符合条件的数据条目时,就停止查询。单行选择需要在SELECT中使用SINGLE关键字,且INTO自居的结构必须为扁平结构:SELECT SINGLE RESULT INTO target FROM source ...如果系统找到一个完全符合指定条件的行,SY-SUBRC返回0,否则返回4。1.选择全部字段一般不需要指明所有字段,而是在SELECT后用*符号,其中INTO语句种的目标对象最好与FROM种的类型相同。2.选择指定字段若指定多个数据对象,则需要将这些对象放在括号中,并用逗号隔开,而且其顺序需要与SELECT子句中指明的表字段顺序一致。如果指定一个扁平结构作为目标对象,且该结构体中的字段多需要选择的字段,则可以使用INTO子句的CORRESPONDING FIELDS选项,该选项只会将SELECT子句中指明字段的内容传送到目标工作区的同名组建中。三.选择多行数据将符合条件的数据全部选取出,其语句结构也需要有相应变化,包括循环选择和选择至内表,两种情况。多行选择也可以使用“*”选择整行数据或指定要选择的字段列表。1.循环选择通过SELECT / ENDSELECT循环从数据库中读取多行。SELECT [DISTINCT] result...statement block ENDSELECT.注:使用DISTINCT自动去掉重复的行;SY-DBCNT(系统字段)为每次循环计数;对三塔tement block中语句块进行处理。2.选择至内表克刚变得一次性把数据选择到一个内表中去。SELECT ...INTO|APPENDING[CORRESPONDING FIELDS OF]TABLE itab.注:该情况下SELECT并不启动循环,因而不需要使用ENDSELECT语句;如果itab非空,则SELECT语句将用读取的数据覆盖其中的内容,使用APPENDING代替INTO将布覆盖内表,若结构不完全相同,也可使用CORRESPONDING FIELDS选项将同名区域相对应。3.指定选择包大小包的大小指的是一次选择到内表的行数,可使用INTO子句的PACKAGE SIZE选项。SELECT * ... INTO TABLE itab PACKAGE SIZE n ... statement blockENDSELECT.注:由于指定了包的大小,该语句以循环的形式出现;如果n小于等于0,将出现运行是错误。四.指定查询条件:1.比较运算符:(=、、、、=、=及相应关键字)WHERE ... f operatorg ... //f为不带前缀数据表名称的字段名FROM中指定,g任意数据对象。2.范围限定运算符:WHERE ... f[NOT]BETWEEN g1 AND g2 ... //条目中f必须在g1与g2之间的值。3.字符比较运算符:WHERE f[NOT]LIKE g [ESCAPE h] ... //数据条目中,字段f值必须符合g的模式。g中通配符“_”用于代替单个字符,“%”用于代替任意字符串(包含空串)。注:可使用ESCAPE选项指定一个忽略符号(h),如果通配符前有忽略符号,那么通配符和忽略符号本身都失去了其功能,而是还原为本义。4.检查列表值:WHERE ... f[NOT] IN (g1,...,gn)... //来价差数据库字段f中的值是否等于括号内列表中的一个值。e.g. SELECT ... WHERE city IN(beij

文档评论(0)

dart002 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档