Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
251 views
in Technique[技术] by (71.8m points)

sql - SQL:WHERE子句中的IF子句(SQL: IF clause within WHERE clause)

Is it possible to use an IF clause within a WHERE clause in MS SQL?

(是否可以在MS SQL中的WHERE子句中使用IF子句?)

Example:

(例:)

WHERE
    IF IsNumeric(@OrderNumber) = 1
        OrderNumber = @OrderNumber
    ELSE
        OrderNumber LIKE '%' + @OrderNumber + '%'
  ask by Bryan Roth translate from so

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

Use a CASE statement

(使用CASE语句)
UPDATE: The previous syntax (as pointed out by a few people) doesn't work.

(更新:以前的语法(由少数人指出)不起作用。)

You can use CASE as follows:

(您可以按如下方式使用CASE:)

WHERE OrderNumber LIKE
  CASE WHEN IsNumeric(@OrderNumber) = 1 THEN 
    @OrderNumber 
  ELSE
    '%' + @OrderNumber
  END

Or you can use an IF statement like @ NJ Reed points out.

(或者您可以使用像@ NJ Reed指出的IF语句。)


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...