仅当参数等于特定值时才如何更新列?

时间:2019-11-06 19:33:42

标签: sql stored-procedures coldfusion sybase

我有一个查询,该查询仅在参数等于1时才更新列。这是示例:

<cfquery name="updateQry" datasource="test">
    UPDATE Table1
    SET fname = form.fname,
        lname = form.lname,
        <cfif form.status eq 1>
            title = form.title,
        </cfif>
        last_update_dt = getDate()
    WHERE rec_id = form.record_id
 </cfquery>

我想将此SQL查询移至存储过程。如何仅使用SQL代码才能达到相同的过程?如何用SQL代码代替<cfif form.status eq 1> title = @title,</cfif>?我使用Sybase数据库和ColdFusion2016。上面的代码应移至存储过程。

1 个答案:

答案 0 :(得分:3)

我认为您想要一个Select *, SUBSTRING(filename, 30, 2) AS Mth, SUBSTRING(filename, 33, 2) AS Dy, SUBSTRING(filename, 44, 99) AS Fl from REUTERS_CPDG_2019 表达式,如下所示:

case

在存储过程中,您可能会使用参数:

UPDATE Table1
SET fname = form.fname,
    lname = form.lname,
    title = (case when form.status = 1 then form.title else table1.title end),
    last_update_dt = getDate()
WHERE rec_id = form.record_id;