首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >数据未插入Server表

数据未插入Server表
EN

Stack Overflow用户
提问于 2021-05-26 07:45:15
回答 2查看 100关注 0票数 0

我正在开发一个项目,我在Server中遇到了一个困难,我创建了一个过程,我需要当表Bi_medicao中的值大于10时,他将该行放在另一个表Bi_alerta中,但问题是,当我运行代码时,一切都很好,但是当我看到它时,它并没有把任何东西放在表中.只是不要向Bi_alerta表添加任何行。

Server存储过程:

代码语言:javascript
复制
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

ALTER PROCEDURE [dbo].[Bi_alertainset] 
    @alerta_hum varchar(50),
    @alerta_temp varchar(50),
    @alerta_lpg varchar(50),
    @alerta_co varchar(50),
    @alerta_fumo varchar(50)
AS
BEGIN
    SELECT
        @alerta_hum = med_hum,
        @alerta_temp = med_temp,
        @alerta_lpg = med_lpg,
        @alerta_co = med_co,
        @alerta_fumo = med_fumo
    FROM 
        Bi_medicao

    IF (@alerta_hum > 10)
        INSERT INTO Bi_alerta (alerta_hum, alerta_temp, alerta_lpg, alerta_co, alerta_fumo)
        VALUES (@alerta_hum, @alerta_temp, @alerta_lpg, @alerta_co, @alerta_fumo)
END
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2021-05-26 20:57:37

我认为问题可能是@alerta_hum是Varchar而不是INT。要么将声明更改为INT,要么也转换@alerta_hum,我建议对IF也使用BEGIN/END。

代码语言:javascript
复制
IF (CONVERT(INT, @alerta_hum) > 10)
BEGIN
    INSERT INTO Bi_alerta (alerta_hum, alerta_temp, alerta_lpg, alerta_co, alerta_fumo)
    VALUES (@alerta_hum, @alerta_temp, @alerta_lpg, @alerta_co, @alerta_fumo)
END

如果这仍然不起作用,您应该检查您的变量是否在使用Bi_medicao重置后都已签名。简单的方法是插入一些打印语句,如PRINT @alerta_hum

票数 0
EN

Stack Overflow用户

发布于 2021-05-26 07:52:28

如果没有任何样本数据、表结构等,就很难再现。无论如何,我建议将插入的内容修改如下:

代码语言:javascript
复制
INSERT INTO Bi_alerta (alerta_hum, alerta_temp, alerta_lpg, alerta_co, alerta_fumo)
SELECT med_hum, med_temp, med_lpg, med_co, med_fumo
  FROM Bi_medicao
  WHERE CAST(med_hum AS INT) > 10
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67700612

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档