最进一个项目 里面有个查询的功能,它是进行组合查询的, 而且用的是存储过程写。写这样的存储过程,需要注意单引号的使用,请看本人下面的例子,假如你以后写的话 记得注意写就行:

create proc selectbyname

(

@LinkmanName VARCHAR(50)=NULL,

@LinkmanBirthday VARCHAR(50)=NULL,

@LinkmanCatalog VARCHAR(50)=NULL,

@linkmanCompany VARCHAR(50)=NULL,

@LinkmanPhoneNumber VARCHAR(50)=NULL,

@LinkmanEmail VARCHAR(50)=NULL

)

as

declare @string VARCHAR(1000) //此处需要定义长一点那个string 因为你组合起来的话,整个语句加起来的字符就很多的了。

if ( LEN(@LinkmanName)>0)

begin

if @string IS NULL

set @string='select * from linkman where lm_name like '''+@LinkmanName+ '%'''

else

set @string=@string+' and lm_name like '''+@LinkmanName+ '%'''

end

if (LEN(@LinkmanBirthday)>0)

begin

if @string IS NULL

set @string=@string+' select * from linkman where lm_birthday='''+@LinkmanBirthday+''''

else

set @string=@string+' and lm_birthday='''+@LinkmanBirthday+''''

end

if ( LEN(@LinkmanCatalog)>0)

begin

if @string IS NULL

set @string=@string +' select * from linkman where lm_catalog like ''' + @LinkmanCatalog + '%'''

else

set @string=@string +' and lm_catalog like ''' + @LinkmanCatalog + '%'''

end

if (LEN(@linkmanCompany) >0 )

begin

if @string IS NULL

set @string=@string +' select * from linkman where lm_company like '''+ @linkmanCompany + '%'''

else

set @string=@string +' and lm_company like '''+ @linkmanCompany + '%'''

end

if ( LEN(@LinkmanPhoneNumber)>0)

begin

if @string IS NULL

set @string=@string +' select * from linkman where lm_mobile ='''+@LinkmanPhoneNumber+''''

else

set @string=@string +' and lm_mobile ='''+@LinkmanPhoneNumber+''''

end

if (LEN(@LinkmanEmail)>0)

begin

if @string IS NULL

set @string=@string +' select * from linkman where lm_email='''+@LinkmanEmail+''''

else

set @string=@string +' and lm_email='''+@LinkmanEmail+''''

end

if(@string is null)

begin

set @string='select * from linkman '

end

exec( @string)

?

程序界面:

SQL组合查询的存储过程写法 - 376735332 - 376735332的博客

?

确定按钮代码:

private void button1_Click(object sender, EventArgs e)

{

string strProName = "selectbyname";

string conn = DBUtility.SqlHelper.connString;

本文来源于网络,若有侵权,请告知,谢谢!!

SQL组合查询的存储过程写法的更多相关文章

  1. SQL Server查询所有存储过程信息、触发器、索引

    1. [代码]查询所有存储过程      01 select Pr_Name as [存储过程], [参数]=stuff((select ','+[Parameter] 02 from ( 03 se ...

  2. SQL Server分页的存储过程写法以及性能比较

    ------创建数据库data_Test ----- create database data_Test GO use data_Test GO create table tb_TestTable - ...

  3. SQL命令查询Oracle存储过程信息(代码内容等)

    SELECT * FROM ALL_SOURCE  where TYPE='PROCEDURE'  AND TEXT LIKE '%0997500%'; --查询ALL_SOURCE中,(脚本代码)内 ...

  4. 佩特来项目经验小集合(2)___组合查询存储过程,报错 "varchar JBID='' 转换成数据类型 int 时失败"

       今天写一个组合查询的存储过程遇到这样一个问题:在将 varchar 值 'SELECT * FROM View_DLS_WXJD_Customer WHERE 1=1 and JBID ='' ...

  5. 关系数据库SQL之高级数据查询:去重复、组合查询、连接查询、虚拟表

    前言 接上一篇关系数据库SQL之基本数据查询:子查询.分组查询.模糊查询,主要是关系型数据库基本数据查询.包括子查询.分组查询.聚合函数查询.模糊查询,本文是介绍一下关系型数据库几种高级数据查询SQL ...

  6. 【知识库】-数据库_MySQL之高级数据查询:去重复、组合查询、连接查询、虚拟表

    简书作者:seay 文章出处: 关系数据库SQL之高级数据查询:去重复.组合查询.连接查询.虚拟表 回顾:[知识库]-数据库_MySQL之基本数据查询:子查询.分组查询.模糊查询 Learn [已经过 ...

  7. Thinkphp查询 1.查询方式 2.表达式查询 3.快捷查询 4.区间查询 5.组合查询 6.统计查询 7.动态查询 8.SQL 查询

    1.使用字符串作为条件查询 $user = M('User'); var_dump($user->where('id=1 AND user="蜡笔小新"')->sele ...

  8. SQL语句汇总(三)——聚合函数、分组、子查询及组合查询

    聚合函数: SQL中提供的聚合函数可以用来统计.求和.求最值等等. 分类: –COUNT:统计行数量 –SUM:获取单个列的合计值 –AVG:计算某个列的平均值 –MAX:计算列的最大值 –MIN:计 ...

  9. SQL语句汇总(三)——聚合函数、分组、子查询及组合查询

    拖了一个星期,终于开始写第三篇了.走起! 聚合函数: SQL中提供的聚合函数可以用来统计.求和.求最值等等. 分类: –COUNT:统计行数量 –SUM:获取单个列的合计值 –AVG:计算某个列的平均 ...

随机推荐

  1. [转]CSS3 Media Query实现响应布局

    讲到响应式布局, 相信大家都有一定的了解,响应式布局是今年很流行的一个设计理念,随着移动互联网的盛行,为解决如今各式各样的浏览器分辨率以及不同移动设备的显示效果, 设计师提出了响应式布局的设计方案.今 ...

  2. 一个有趣的回答(摘自http://www.51testing.com/html/03/n-860703.html)

    假设这有一个各种字母组成的字符串,假设这还有另外一个字符串,而且这个字符串里的字母数相对少一些.从算法上讲,什么方法能最快的查出所有小字符串里的字母在大字符串里都有? 比如,如果是下面两个字符串: S ...

  3. JavaScript中style, currentStyle和 getComputedStyle的异同

    今天在做项目的时候,习惯性的用到了element.style.width,然而浏览器却报错,错误提示是style is undefined,这是我才意识到,内联样式表和外联样式表在js应用中也有很大的 ...

  4. Javascript跨域

    跨域:只要协议.域名或端口有任何一个不同,就定义为跨域. CORS(Cross-Origin Resource Sharing):即跨域资源共享.定义了在访问跨域资源时,浏览器和服务器该如何沟通.CO ...

  5. javascript页面加载完执行事件

    <script type="text/javascript" language="JavaScript"> //: 判断网页是否加载完成 docum ...

  6. 八皇后java算法

    import java.util.Date; public class EightQueen { public static void main(String[] args) {  long star ...

  7. git学习心得总结

    最近学习git,应为git可以不需要服务器而在任意的Linux机器上管理代码,相对svn和cvs还是有它的优势的,所以我选用了git来管理我的小项目,以后在提供svn的管理. 在使用了一段时间后想写一 ...

  8. 输出MYSQL所有SQL语句

    在my.cnf中的mysqld段增加如下参数,然后重启MYSQL: log-output = FILE general_log = 1 general_log_file = "D:/Visu ...

  9. 使用Object类型的多态引用是会付出代价的

    import java.util.*; public class FiveShi { String name; public void eat(){ System.out.println(" ...

  10. Linux/Unix 线程同步技术之互斥量(1)

    众所周知,互斥量(mutex)是同步线程对共享资源访问的技术,用来防止下面这种情况:线程A试图访问某个共享资源时,线程B正在对其进行修改,从而造成资源状态不一致.与之相关的一个术语临界区(critic ...