在ABAP SQL中使用表达式

本文介绍了ABAPSQL中的字面量和常量的区别,以及CAST用于类型转换的用法。通过CASE语句展示了如何根据条件动态判断航班状态。
摘要由CSDN通过智能技术生成

1.字面量和常量

字面量(Literal)指的是一个不可变的值,比如代码中的10,可变的是NUM1。

DATA NUM1 TYPE I VALUE 10.

常量(Constant)指的是不可变的变量,这里NUM2是常量,1234是字面量。

CONSTANTS NUM2 TYPE I VALUE 1234.

字面量和常量在ABAP SQL中的应用。Hello是字符类性的字面量,1和-1是数字类型的字面量。C_NUMBER是常量,在语句中需要用@符号标识。

CONSTANTS C_NUMBER TYPE I VALUE 1234.

SELECT FROM /DMO/CARRIER
    FIELDS 'Hello' AS CHARACTER,
            1 AS INTEGER1,
            -1 AS INTEGER2,
            @C_NUMBER AS CONSTANTS
INTO TABLE @DATA(RESULT).

OUT->WRITE( RESULT ).

在这里插入图片描述

2.CAST

CAST关键字用来进行类型转换,超过类型的长度会自动截断。

SELECT FROM /DMO/CARRIER
    FIELDS '19891109' AS CHAR_8,
        CAST( '19891109' AS CHAR( 4 ) ) AS CHAR_4,
        CAST( '19891109' AS NUMC( 8 ) ) AS NUMC_8,
        CAST( '19891109' AS INT4 ) AS INTEGER,
        CAST( '19891109' AS DEC( 10, 2 ) ) AS DEC_10_2,
        CAST( '19891109' AS FLTP ) AS FLTP,
        CAST( '19891109' AS DATS ) AS DATE
INTO TABLE @DATA(RESULT1).
OUT->WRITE( RESULT1 ).

在这里插入图片描述

3.CASE

SELECT FROM /DMO/FLIGHT
    FIELDS
        FLIGHT_DATE AS DATE,
        SEATS_MAX AS MAX,
        SEATS_OCCUPIED AS OCCUPIED,
        CASE
            WHEN SEATS_OCCUPIED < SEATS_MAX THEN 'Available'
            WHEN SEATS_OCCUPIED = SEATS_MAX THEN 'Full booked'
            WHEN SEATS_OCCUPIED > SEATS_MAX THEN 'Overbooked'
            ELSE 'No possible'
        END AS BOOKINGSTATUS
WHERE CARRIER_ID = 'LH'
    AND CONNECTION_ID = '0400'
INTO TABLE @DATA(RESULT3).
OUT->WRITE( RESULT3 ).

在这里插入图片描述


总结

打完收工。

  • 9
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值