wfl_instance_query.lwm 5.65 KB
Newer Older
Spencer Chang's avatar
Spencer Chang committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120
<?xml version="1.0" encoding="UTF-8"?>
<!--
    $Author: Clocc  
    $Date: 2015-7-24 下午2:50:49  
    $Revision: 1.0  
    $Purpose: 
-->
<bm:model xmlns:bm="http://www.leaf-framework.org/schema/bm">
    <bm:operations>
        <bm:operation name="query">
            <bm:query-sql><![CDATA[
                SELECT
                    *
                FROM
                    (SELECT
                        p.project_id,
                        null as quotation_id,
                        null as contract_seq,
                        c.contract_id,
                        p.project_number,
                        p.project_name,
                        c.contract_number,
                        c.search_term_1,
                        c.contract_name,
                        (SELECT
                            v.code_value_name
                        FROM
                            sys_code_values_v v
                        WHERE
                            v.code       = 'PRJ501_PRJ_STATUS' AND
                            v.code_value = p.project_status
                        ) AS project_status_n,
                        (SELECT
                            sc.code_value_name
                        FROM
                            sys_code_values_v sc
                        WHERE
                            sc.code       = 'CON500_CONTRACT_STATUS' AND
                            sc.code_value = c.contract_status
                        ) AS contract_status_desc,
                        (SELECT hbm.bp_name FROM hls_bp_master hbm WHERE hbm.bp_id = c.bp_id_tenant
                        ) bp_id_tenant_name
                    FROM
                        prj_project p,
                        con_contract c
                    WHERE
                        p.project_id           = c.project_id AND
                        c.data_class = 'NORMAL'
                    -- UNION ALL
                    -- SELECT
                        -- NULL project_id,
                        -- NULL quotation_id,
                        -- NULL contract_seq,
                        -- c.contract_id,
                        -- NULL project_number,
                        -- NULL project_name,
                        -- c.contract_number,
                        -- c.search_term_1,
                        -- c.contract_name,
                        -- NULL project_status_n,
                        -- (SELECT
                            -- sc.code_value_name
                        -- FROM
                            -- sys_code_values_v sc
                        -- WHERE
                            -- sc.code       = 'CON500_CONTRACT_STATUS' AND
                            -- sc.code_value = c.contract_status
                        -- ) AS contract_status_desc
                    -- FROM
                        -- con_contract c
                    -- WHERE
                        -- c.quotation_id IS NULL AND
                        -- c.data_class    = 'NORMAL'
                    UNION ALL
                    SELECT
                        p.project_id,
                        NULL quotation_id,
                        NULL contract_seq,
                        NULL contract_id,
                        p.project_number,
                        p.project_name,
                        NULL contract_number,
                        NULL search_term_1,
                        NULL contract_name,
                        (SELECT
                            v.code_value_name
                        FROM
                            sys_code_values_v v
                        WHERE
                            v.code       = 'PRJ501_PRJ_STATUS' AND
                            v.code_value = p.project_status
                        ) AS project_status_n,
                        NULL contract_status_desc,
                        (SELECT hbm.bp_name FROM hls_bp_master hbm WHERE hbm.bp_id = p.bp_id_tenant
                        ) bp_id_tenant_name
                    FROM
                        prj_project p
                    WHERE
                        NOT EXISTS
                        (SELECT 1 FROM con_contract c WHERE p.project_id = c.project_id
                        )
                    ORDER BY
                        project_number,
                        search_term_1
                    ) t1 #WHERE_CLAUSE#
            ]]></bm:query-sql>
        </bm:operation>
    </bm:operations>
    <bm:query-fields>
        <bm:query-field name="project_number" queryExpression="t1.project_number like ${@project_number}"/>
        <bm:query-field name="contract_number" queryExpression="t1.contract_number like ${@contract_number}"/>
        <bm:query-field name="project_name" queryExpression="t1.project_name like ${@project_name}"/>
        <bm:query-field name="contract_name" queryExpression="t1.contract_name like ${@contract_name}"/>
        <bm:query-field name="search_term_1" queryExpression="t1.search_term_1 like ${@search_term_1}"/>
        <bm:query-field name="project_status_n" queryExpression="t1.project_status_n = ${@project_status_n}"/>
        <bm:query-field name="contract_status_desc" queryExpression="t1.contract_status_desc=${@contract_status_desc}"/>
        <bm:query-field name="bp_id_tenant_name" queryExpression="t1.bp_id_tenant_name like ${@bp_id_tenant_name}"/>
        <bm:query-field name="serial_number" queryExpression="exists (select 1           from con_contract_lease_item i          where i.contract_id = t1.contract_id            and i.serial_number like ${@serial_number}) or exists (select 1           from prj_project_lease_item i          where i.project_id = t1.project_id            and i.serial_number like ${@serial_number} )"/>
    </bm:query-fields>
</bm:model>