关于存储过程判断

remember_way 2016-12-19 10:13:33
有没有大神说一下存储过程判断语句怎么写,大概的逻辑是-----判断输入的一条数据是否在参考表里面有对应,如果没有就不插入正式表,如果有就插入。
附带一下解析,我是新手
...全文
355 16 打赏 收藏 转发到动态 举报
写回复
用AI写文章
16 条回复
切换为时间正序
请发表友善的回复…
发表回复
-Arvin 2016-12-22
  • 打赏
  • 举报
回复
你想根据用户输入的内容判断是否存在该数据不用参数写存储过程? 我看吧里哪位大神能不用参数给你写出来? 连你自己的逻辑哪些是该给程序处理的事,哪些该用数据库你都分不清楚。
道素 2016-12-22
  • 打赏
  • 举报
回复
一楼wmxcn2000 的办法可以,不过可能和你要的意思反了 你想要的是不存在就插入吧 ,那么应该是 NOT EXISTS 如果已经存在,那句insert into 语句即使执行也不会什插入数据 如果你还有存在就更新的需求,你还可以参考下MERGE INTO 操作
remember_way 2016-12-22
  • 打赏
  • 举报
回复
引用 13 楼 baidu_35289351 的回复:
我是想要不带参数的。。。。就根据界面输入,在存储过程判断输入的数据是否和参考表的数据对应,如果对应,就插入新表,如果不对应,就给出对应的@ERROR_REMARK=‘输入....有误’ 参考表有4个,判断的字段也有4个 --参考表(字段1,字段2,字段3,字段4) --正式表(字段1,字段2,字段3,字段4) --通过界面输入“字段1”的内容在参考表查询出字段2,字段3,字段4,插入到正式表去,存储过程的名称为 insert_data create proc insert_data @字段1 varchar(20) as begin declare @字段2 varchar(20),@字段3 varchar(20),@字段4 varchar(20),@ERROR_REMARK(20) if exists (select @字段2=字段2,@字段3=字段3,@字段3=字段3 from 参考表 where 字段1=@字段1) begin insert into 正式表(字段1,字段2,字段3,字段4) values(@字段1,@字段2@,字段3,@字段4) set @ERROR_REMARK='插入数据成功' end else begin set @ERROR_REMARK='输入错误' endf select @ERROR_REMARK --作用是返回值 end
就是這個,謝謝大神,結貼咯
baidu_35289351 2016-12-21
  • 打赏
  • 举报
回复
我是想要不带参数的。。。。就根据界面输入,在存储过程判断输入的数据是否和参考表的数据对应,如果对应,就插入新表,如果不对应,就给出对应的@ERROR_REMARK=‘输入....有误’ 参考表有4个,判断的字段也有4个 --参考表(字段1,字段2,字段3,字段4) --正式表(字段1,字段2,字段3,字段4) --通过界面输入“字段1”的内容在参考表查询出字段2,字段3,字段4,插入到正式表去,存储过程的名称为 insert_data create proc insert_data @字段1 varchar(20) as begin declare @字段2 varchar(20),@字段3 varchar(20),@字段4 varchar(20),@ERROR_REMARK(20) if exists (select @字段2=字段2,@字段3=字段3,@字段3=字段3 from 参考表 where 字段1=@字段1) begin insert into 正式表(字段1,字段2,字段3,字段4) values(@字段1,@字段2@,字段3,@字段4) set @ERROR_REMARK='插入数据成功' end else begin set @ERROR_REMARK='输入错误' endf select @ERROR_REMARK --作用是返回值 end
remember_way 2016-12-20
  • 打赏
  • 举报
回复
引用 9 楼 baidu_35289351 的回复:
不带那个参数。基本上没什么变化啊。带参数的是不是你想要的。。
我是想要不带参数的。。。。就根据界面输入,在存储过程判断输入的数据是否和参考表的数据对应,如果对应,就插入新表,如果不对应,就给出对应的@ERROR_REMARK=‘输入....有误’ 参考表有4个,判断的字段也有4个
baidu_35289351 2016-12-20
  • 打赏
  • 举报
回复
不带那个参数。基本上没什么变化啊。带参数的是不是你想要的。。
remember_way 2016-12-20
  • 打赏
  • 举报
回复
引用 7 楼 baidu_35289351 的回复:
--参考表(id,name) --正式表(id,name,class,age) declare @id int,@name varchar(20),@class varchar(20),@res varchar(20) set @name='张三' set @class='高三班' --开始,判断name是否在参考表中,存在就读取对于的ID,然后写到正式表 begin if exists (select @id=id from 参考表 where name=@name) begin insert into 正式表(id,name,class) values(@id,@name,@class) set @res='插入成功' end else begin set @res='插入失败' end end
如果不带参数的呢?
baidu_35289351 2016-12-20
  • 打赏
  • 举报
回复
--参考表(id,name) --正式表(id,name,class,age) declare @id int,@name varchar(20),@class varchar(20),@res varchar(20) set @name='张三' set @class='高三班' --开始,判断name是否在参考表中,存在就读取对于的ID,然后写到正式表 begin if exists (select @id=id from 参考表 where name=@name) begin insert into 正式表(id,name,class) values(@id,@name,@class) set @res='插入成功' end else begin set @res='插入失败' end end
remember_way 2016-12-20
  • 打赏
  • 举报
回复
引用 5 楼 wmxcn2000 的回复:
1 楼的方法你试了吗?你为什么说不行?
不是说这个写法不对,而是跟需求不一样,被这个弄的很头疼
卖水果的net 2016-12-20
  • 打赏
  • 举报
回复
1 楼的方法你试了吗?你为什么说不行?
remember_way 2016-12-20
  • 打赏
  • 举报
回复
引用 11 楼 baidu_35289351 的回复:
你把你判断表的语句写出来 然后,把你的插入语句写出来。 帮你完成存储过程。
加我,我把參考表,存儲過程發給你看下 QQ234861404
baidu_35289351 2016-12-20
  • 打赏
  • 举报
回复
你把你判断表的语句写出来 然后,把你的插入语句写出来。 帮你完成存储过程。
-Arvin 2016-12-19
  • 打赏
  • 举报
回复
BEGIN  
    if exists (select IntervalID from IntervalInfo where IntervalName=@IntervalName and StationID=@StationID )
	begin   --存在
	-- 写你的插入语句
	end
	else  --不存在
	begin  
	--不存在
	end
END
卖水果的net 2016-12-19
  • 打赏
  • 举报
回复
-- 大概这样的一个语法
insert into t (col1,col2...)
select .... from x 
where exists(select .... from y where x.id = y.id  )
remember_way 2016-12-19
  • 打赏
  • 举报
回复
引用 1 楼 wmxcn2000 的回复:
-- 大概这样的一个语法
insert into t (col1,col2...)
select .... from x 
where exists(select .... from y where x.id = y.id  )
这个不行,因为这个是先查询插入再进行判断的,要的是在insert into前面判断的.
remember_way 2016-12-19
  • 打赏
  • 举报
回复
引用 2 楼 oArvin1234 的回复:
BEGIN  
    if exists (select IntervalID from IntervalInfo where IntervalName=@IntervalName and StationID=@StationID )
	begin   --存在
	-- 写你的插入语句
	end
	else  --不存在
	begin  
	--不存在
	end
END
我开始也是用这种方式,但是有多个条件的判断,先判断后插入,如果判断出不对应,给出类似select @error_remark提示,能否给出具体一些? 还有不加参数就单单是字段之间的判断怎么写?

22,209

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧