将多个值传递到查询中的where条件

2020-09-02 06:05发布

         点击此处--->   EasySAP.com群内免费提供SAP练习系统(在群公告中)

加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)


嗨, >

我将在"查询"中将具有多个值的参数从全局变量传递到" WHERE"条件

$ G_CLIENT中的"客户"位置

下面是执行作业时输入的变量。

$ G_Client ='\'100 \',\'200 \''(从客户端100和200中选择所有数据)

但是,条件不起作用。 谁能告诉我实现该目标的正确方法?

谢谢

(11.5 kB)

         点击此处--->   EasySAP.com群内免费提供SAP练习系统(在群公告中)

加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)


嗨, >

我将在"查询"中将具有多个值的参数从全局变量传递到" WHERE"条件

$ G_CLIENT中的"客户"位置

下面是执行作业时输入的变量。

$ G_Client ='\'100 \',\'200 \''(从客户端100和200中选择所有数据)

但是,条件不起作用。 谁能告诉我实现该目标的正确方法?

谢谢

(11.5 kB)
付费偷看设置
发送
1条回答
Doze时光
1楼 · 2020-09-02 06:09.采纳回答

我不是在Data Services Wiki上创建过关于各种选项的帖子吗?

https://wiki.scn.sap.com/wiki/display/EIM/Data+Services+Usage+Questions

之所以不起作用,是因为数据库是如何工作的。 发送到服务器的select语句将为"从(:string_param)中CLIENT的表中选择colA,colB"。

数据库将看到您的列表,这只是一个参数(因此相同) as CLIENT =:string_param),并在执行时尝试查找CLIENT ='100,200'的行。 没有行具有这样的字符串。

有多种方法可以解决该问题,大多数方法都有严厉的性能和处理处罚。

在您的情况下,我认为pushdown_sql()函数将是最佳方法。 它允许您在数据流开始时操作where子句。

https://help.sap.com/viewer/e54136ab6a4a43e6a370265bf0a2d744/4.2.12/en-US/576387f16d6d1014b3fc9283b0e91070.html

一周热门 更多>