数据库中:如何在存储过程中为一个变量,通过查询语句获赋值?

qiuzhizhe 2006-04-20 10:54:56
在存储过程中定义一个变量通过查询语句却无法赋值,该怎么解决呢?
DECLARE @SchoolworkID INT
SET @SchoolworkID = 0----可以获取值
SET @SchoolworkID = (SELECT TOP 1 SchoolworkID FROM StudentSchoolwork WHERE(schoolworkPath = @schoolworkPath))------但是这个语句就无法赋值,该怎么解决呢?


具体的存储过程如下:
CREATE PROCEDURE spUploadSchoolwork
@studentNO CHAR(6),
@schoolworkType CHAR(1),
@schoolworkPath VARCHAR(200),
---@teacherMarkedSign CHAR(1),
@schoolworkFileLength INT,
----uploadDay SMALLDATETIME DEFAULT GETDATE(),
@schoolworkFileType CHAR(5)
AS
DECLARE @SchoolworkID INT
SET @SchoolworkID = 0
SELECT @SchoolworkID = (SELECT TOP 1 SchoolworkID FROM StudentSchoolwork WHERE(schoolworkPath = @schoolworkPath))------这里@SchoolworkID无法获取值,该怎么解决呢?
-----PRINT @SchoolworkID-------
IF (@SchoolworkID = 0)
BEGIN
INSERT INTO StudentSchoolwork
VALUES(@studentNO, @schoolworkType, @schoolworkPath, '0', @schoolworkFileLength, GETDATE(), @schoolworkFileType)
END
ELSE
BEGIN
UPDATE StudentSchoolwork
SET studentNO = @studentNO,
schoolworkFileLength = @schoolworkFileLength,
uploadDay = GETDATE()
WHERE SchoolworkID = @SchoolworkID
END
GO
...全文
198 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
liujiayu10 2006-06-03
  • 打赏
  • 举报
回复
declare @i int
select @i=cid from table where xx=1
milchcow 2006-06-02
  • 打赏
  • 举报
回复
SET @SchoolworkID = (SELECT TOP 1 SchoolworkID FROM StudentSchoolwork WHERE(schoolworkPath = '一个schoolworkpath的值'))
select @SchoolworkID
改为:
SELECT TOP 1 @SchoolworkID =SchoolworkID FROM StudentSchoolwork WHERE(schoolworkPath = '一个schoolworkpath的值')
select @SchoolworkID
qiuzhizhe 2006-04-20
  • 打赏
  • 举报
回复
无法赋值,不提示错误,而且这个存储过程已经建立成功了,楼上所说的方法在查询分析器中单独的这个语句是可以的,但是到了存储过程中同样的语句却却不能正确赋值
活靶子哥哥 2006-04-20
  • 打赏
  • 举报
回复
SET @SchoolworkID = (SELECT TOP 1 SchoolworkID FROM StudentSchoolwork WHERE(schoolworkPath = @schoolworkPath))------但是这个语句就无法赋值,该怎么解决呢?


是有错误提示呢还是你运行过程中发现无法赋值

你在查询分析器内单独执行这部分看看到底有没有值

DECLARE @SchoolworkID INT
SET @SchoolworkID = (SELECT TOP 1 SchoolworkID FROM StudentSchoolwork WHERE(schoolworkPath = '一个schoolworkpath的值'))
select @SchoolworkID

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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