为了省代码。。。为了方便管理WDA的查询条件。。。

首先建配置表:

说明:

上面的KEY基本都是维护的维度,可以根据销售组织,根据用户组,根据组件,根据SELECT OPTION的不同。。。等等,可以根据情况而定。

COMPONENT_NAME:wda组件名,不同的组件配置不同。

SELOPTION:SELECT OPTION名,不同的SELECT不同配置。

ATTRIBUTE:字段名,这里按照表字段名来处理的,方便后面做动态SQL。

TABNAME:表名,需要查的字段对应的数据库表,也是方便后面动态SQL。

DATAELEMENT:数据元素,创建OPTION的对象。

TEXT:字段标签,可以是OTR翻译文本,也可以是固定文本。

DISP_INDEX:SELECT条件的位置。

VISIABLE:查询条件是否可见。

MANDATORY:查询条件是否必填。

NO_EXTENSION:没有扩展选项
NO_INTERVALS:没有范围选择
AS_CHECKBOX:查询条件是CHECK BOX
AS_DROPDOWN:查询条件是下拉

SELECT OPTION初始化:

METHOD init_select_options .
DATA:
lt_range_table TYPE REF TO data,
read_only TYPE abap_bool.
DATA:
lr_componentcontroller TYPE REF TO ig_componentcontroller,
l_ref_cmp_usage TYPE REF TO if_wd_component_usage.
DATA:
display_btn_cancel TYPE abap_bool,
display_btn_check TYPE abap_bool,
display_btn_reset TYPE abap_bool,
display_btn_execute TYPE abap_bool.
DATA:gt_value_set TYPE wdy_key_value_table,
gw_value_set TYPE wdy_key_value,
gt_type TYPE TABLE OF crmc_proc_type_t,
gw_type LIKE LINE OF gt_type.
DATA:gt_zcrmt0888 TYPE TABLE OF zcrmt0888,
gw_zcrmt0888 LIKE LINE OF gt_zcrmt0888.
FIELD-SYMBOLS:<tab> TYPE table.
* create the used component
l_ref_cmp_usage = wd_this->wd_cpuse_select_option( ).
IF l_ref_cmp_usage->has_active_component( ) IS INITIAL.
l_ref_cmp_usage->create_component( ).
ENDIF.
* get a pointer to the interface controller of the select options
*component
wd_this->m_wd_select_options = wd_this->wd_cpifc_select_option( ). * init the select screen
wd_this->m_handler = wd_this->m_wd_select_options->init_selection_screen( ). SELECT * INTO TABLE gt_zcrmt0888 FROM zcrmt0888.
SORT gt_zcrmt0888 BY disp_index ASCENDING.
LOOP AT gt_zcrmt0888 INTO gw_zcrmt0888.
DATA:v_type TYPE string,
v_id TYPE string,
v_text TYPE string.
REFRESH:gt_value_set.
v_type = gw_zcrmt0888-dataelement."赋值数据元素类型
v_id = gw_zcrmt0888-attribute."赋值字段ID
v_text = gw_zcrmt0888-text.
IF gw_zcrmt0888-text CS 'ZCRM'."处理描述
v_text = zcl_otr=>get_text( v_text ).
ENDIF. lt_range_table = wd_this->m_handler->create_range_table( i_typename = v_type ). IF gw_zcrmt0888-attribute = 'PROCESS_TYPE'.
IF wd_comp_controller->bp_current_sales_org = 'O 50000005'.
SELECT * INTO TABLE gt_type FROM crmc_proc_type_t
WHERE process_type IN ('ZSO2','ZSO5')
AND langu = sy-langu.
ELSE.
SELECT * INTO TABLE gt_type FROM crmc_proc_type_t
WHERE process_type IN ('ZSO2','ZSO3','ZSO5')
AND langu = sy-langu.
ENDIF.
LOOP AT gt_type INTO gw_type.
gw_value_set-key = gw_type-process_type.
gw_value_set-value = gw_type-p_description.
APPEND gw_value_set TO gt_value_set.
ENDLOOP.
ELSEIF gw_zcrmt0888-attribute = 'DELIVERD'.
ASSIGN lt_range_table->* TO <tab>.
ls_stat-low = 'A'.
ls_stat-high = 'B'.
ls_stat-sign = 'I'.
ls_stat-option = 'BT'.
APPEND ls_stat TO <tab>.
ENDIF. wd_this->m_handler->add_selection_field(
i_id = v_id
i_obligatory = gw_zcrmt0888-mandatory
i_no_extension = gw_zcrmt0888-no_extension
i_no_intervals = gw_zcrmt0888-no_intervals
i_as_checkbox = gw_zcrmt0888-as_checkbox
i_as_dropdown = gw_zcrmt0888-as_dropdown
i_description = v_text
it_result = lt_range_table
it_value_set = gt_value_set
i_read_only = read_only ).
ENDLOOP. REFRESH:gt_zcrmt0888. * adjust the global options
wd_this->m_handler->set_global_options(
i_display_btn_cancel = display_btn_cancel
i_display_btn_check = display_btn_check
i_display_btn_reset = display_btn_reset
i_display_btn_execute = display_btn_execute ). ENDMETHOD.

SEARCH里处理:(部分)

DATA: rt_object_id TYPE REF TO data.
FIELD-SYMBOLS: <table> TYPE table,
<any> TYPE any. DATA:
gt_zcrmt0888 TYPE TABLE OF zcrmt0888,
gw_zcrmt0888 LIKE LINE OF gt_zcrmt0888,
lv_id TYPE string.
lo_api_controller ?= wd_this->wd_get_api( ).
lo_message_manager = lo_api_controller->get_message_manager( ).
lo_nd_so_search = wd_context->get_child_node( name = wd_this->wdctx_so_search ). DATA:gt_range TYPE rsds_trange,
gw_range LIKE LINE OF gt_range,
gt_field TYPE TABLE OF zsfrange,
gw_field LIKE LINE OF gt_field,
gw_selec TYPE rsdsselopt,
gt_where TYPE TABLE OF crmt_where.
SELECT * INTO TABLE gt_zcrmt0888 FROM zcrmt0888 WHERE visiable = 'X'. LOOP AT gt_zcrmt0888 INTO gw_zcrmt0888.
lv_id = gw_zcrmt0888-attribute.
rt_object_id = wd_this->m_handler->get_range_table_of_sel_field( i_id = lv_id ).
ASSIGN rt_object_id->* TO <table>.
LOOP AT <table> ASSIGNING <any>.
MOVE-CORRESPONDING <any> TO gw_selec.
APPEND gw_selec TO gw_field-selopt_t.
ENDLOOP.
UNASSIGN:<any>,<sales_org>.
gw_field-fieldname = gw_zcrmt0888-attribute.
APPEND gw_field TO gw_range-frange_t.
CLEAR:gw_field.
ENDLOOP.
APPEND gw_range TO gt_range.
CLEAR:gw_range. CALL FUNCTION 'FREE_SELECTIONS_RANGE_2_WHERE'
EXPORTING
field_ranges = gt_range
IMPORTING
where_clauses = gt_where.

。。。

看看效果:

输入查询条件,看处理结果:

这里没配TABLENAME,都是默认的:

可以根据TABLENAME分到不同的动态SQL里,然后加到常规SQL中。

WDA基础十八:Select option配置的更多相关文章

  1. Bootstrap <基础十八>面包屑导航(Breadcrumbs)

    面包屑导航(Breadcrumbs)是一种基于网站层次信息的显示方式.以博客为例,面包屑导航可以显示发布日期.类别或标签.它们表示当前页面在导航层次结构内的位置. Bootstrap 中的面包屑导航( ...

  2. WDA基础十二:FREE PROGRAM SH (WDA TREE)

    一个需要用TREE展示搜索帮助的需求: 1.创建WDA程序:ZCATEGORY 2.Component Controller中添加节点: (说明,此节点仅在搜索帮助程序中使用,可以不用interfac ...

  3. WDA基础十:OVS搜索帮助的使用

    对于WDA来说,常用的搜索帮助有OVS,标准SH,Interface view等.今天来说说两种常用的OVS的使用: 一:普通字段,表字段的搜索帮助(在创建节点的时候指定搜索帮助OVS,或者后面加上去 ...

  4. WDA基础十四:ALV字段属性配置表

    ALV配置表管理 一.字段属性配置表 对于可编辑的ALV不用这个,尽可能多的设置一些控制: 单元格类型:默认A,特殊选择 ZLYE_TYPE        E       A       1      ...

  5. redis(十八):Redis 配置

    #redis.conf# Redis configuration file example.# ./redis-server /path/to/redis.conf ################# ...

  6. 黑马程序员 Java基础<十八>---> 网路编程

    --------------- ASP.Net+Android+IO开发S..Net培训.期待与您交流! --------------- 第一  概述 一.概述: 1.网络模型:OSI参考模型和TCP ...

  7. java基础(十八)----- java动态代理原理源码解析

    关于Java中的动态代理,我们首先需要了解的是一种常用的设计模式--代理模式,而对于代理,根据创建代理类的时间点,又可以分为静态代理和动态代理. 静态代理 1.静态代理 静态代理:由程序员创建或特定工 ...

  8. WDA基础十六:ALV的颜色

    这里介绍三种类型的颜色:列的背景色,单元格的背景色,单元格文本的颜色. 1.给ALV结构添加颜色控制字段: 三个字段都是同一类型:WDY_UIE_LIBRARY_ENUM_TYPE COL_BACKG ...

  9. WDA基础十五:POPUP WINDOW

    1.组件控制器定义属性: 2.实现popup方法: METHOD stock_popup . DATA: l_cmp_api TYPE REF TO if_wd_component, l_window ...

随机推荐

  1. zz开源 MNN:淘宝在移动 AI 上的实践

    开源 MNN:淘宝在移动 AI 上的实践   陈以鎏(离青) 阅读数:40612019 年 6 月 28 日   随着深度学习的快速发展和端侧设备算力的不断提升,原本在云端执行的推理预测工作正在部分迁 ...

  2. 学习:逆向PUSH越界/INT 68/反调试导致的程序

    自己根据shark恒老师的分析,总结一下: 一般反调试自动关闭程序利用的函数有: 1.CreateToolhelp32Snapshot 2.FindWindow 3.ExitProcess 4.Pos ...

  3. Jike_Time

    数据分析全景图 1. 数据采集.它是我们的原材料,也是最“接地气”的部分,因为任何分析都要有数据源. 2. 数据挖掘.它可以说是最“高大上”的部分,也是整个商业价值所在.之所以要进行数据分析,就是要找 ...

  4. testcontainers 方便的db测试框架

    testcontainers是一个强大,简单,基于容器的db测试解决方案 目前已经支持了主流的开发语言 参考资料 https://github.com/testcontainers/testconta ...

  5. requests--传递参数

    传递参数 传递URL参数 data = {'city': '北京'} # 参数有中文如果发送不了,必须要编码 city = parse.urlencode(data).encode('utf-8') ...

  6. Linux性能优化实战学习笔记:第五十讲

    一.上节回顾 上一节,我以 ksoftirqd CPU 使用率高的问题为例,带你一起学习了内核线程 CPU 使用率高时的分析方法.先简单回顾一下. 当碰到内核线程的资源使用异常时,很多常用的进程级性能 ...

  7. oracle--DG初始化参数

    下列参数为Primary角色相关的初始化参数 DB_NAME 注意保持同一个Data Guard中所有数据库DB_NAME相同 例如:DB_NAME=kingle DB_UNIQUE_NAME 为每一 ...

  8. 花一天时间踩了node npm的一个坑

    在一个后端眼里nodejs这工具真的难用,最近为了用elementui,然后去硬着头皮学vue,学着学着,发现还要去用node,webpack.真想掐死前端那一群人啊.... 好了,进入正题.话说我装 ...

  9. Visual Studio 调试系列10 附加到正在运行的进程

    系列目录     [已更新最新开发文章,点击查看详细] 可将 Visual Studio 调试器附加到本地或远程计算机上正在运行的进程. 进程运行后,在 Visual Studio 中选择“调试” & ...

  10. Django初见

    什么市WEB应用? 所谓的web应用就是我们基于浏览器打开的一个个网页(对应网址得到的内容) 软件开发架构 C/S架构: 客户端/服务端 B/S架构:浏览器/服务器 所有的B/S架构本质上就是C/S架 ...