首页 > 解决方案 > 使用多个文本框搜索数据库 Asp.net

问题描述

我有一个使用文本框从数据库中提取数据的存储过程。但是,我添加了另一个文本框,它也可以为他们提供另一个选项来提取相同的数据。用户可以使用身份证号或地址进行搜索。但是假设我在 id 文本框中输入数据并将地址文本框留空,它会拉出所有记录;不是基于输入的身份证号码的记录;但是,如果我将 id 文本框留空并输入地址文本框,它将返回所需的一条记录。

存储过程

select id, name, age, address, telephone where 
  WHERE id= @id
  OR ISNULL(@id, '') = '' and address= @address
  OR ISNULL(@address, '') = ''

标签: c#sql-serverstored-procedures

解决方案


你需要括号:

SELECT id, name, age, address, telephone 
WHERE ( ISNULL(@id, '') = '' AND ISNULL(@address, '') = '' )
  OR  ( ISNULL(@id, '') = '' AND address = @address )
  OR  ( ISNULL(@address, '') = '' AND id = @id )
  OR  ( id = @id AND address = @address )

推荐阅读