查询条件使用配置表——SQL Server

为了解决客户信息完整性检查的维护难题,本文提出了将查询条件存储在配置表中的方法,使得维护人员只需更新配置表即可实现需求,降低了代码的复杂性和维护成本。
摘要由CSDN通过智能技术生成

有时需要知道填入的客户信息是否完整,可以将完整性条件写进sql代码中,但是,维护起来会比较麻烦。所以考虑写一张配置表,维护人员只需要改配置表的内容即可

现有如下问题,想得到某客户信息是否完整以及来呢西人信息完整的数量~

/****** Object:  StoredProcedure [dbo].[P_DJ_CustomInfo_Isornot_Complete]    Script Date: 2019/12/6 15:53:41 ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

Create proc [dbo].[P_DJ_CustomInfo_Isornot_Complete]
as
declare @condition nvarchar(max)
declare @number nvarchar(max)

set @condition=(select new_parameter_value from new_configuration_parameters 
where new_parameter_name = 'account_info_valid_condition')
set @number=(select new_parameter_value from new_configuration_parameters 
where new_parameter_name = 'contact_info_valid_condition')

declare @sql nvarchar(max)

set @sql=N'

select  a.BusinessUnitId
       ,a.Name as Dept
       ,b.SystemUserId
       ,case when b.IsDisabled=0 then b.FullName 
	         when b.IsDisabled=1 then ''离职人员'' end as Salesman  -- 销售员
	   ,AccountBase.AccountId
	   ,AccountBase.name as AccountName  -- 客户
	   ,d.new_productline  -- 产品线id 
	   '
	set @sql=@sql+',case when '+@condition +' then ''是'' else ''否'' end as Isornotcomplete'
	set @sql=@sql+',case when '+@number +' then 1 else 0 end as CompleteNumber'
	set @sql=@sql+N'
from BusinessUnitBase a
left join SystemUserBase b on a.BusinessUnitId=b.BusinessUnitId  -- 部门id
left join AccountBase  on b.SystemUserId=AccountBase.OwnerId  -- 销售id
left join Contact on b.SystemUserId=Contact.OwnerId and AccountBase.AccountId=Contact.AccountId
-- 产品线分派表
left join new_productline_assignmentBase d on AccountBase.AccountId=d.new_customer  -- 客户id 
'
exec dbo.sp_executesql @sql
GO

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

BI-段二胖

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值