0

我正在创建一个 Web 应用程序,在该应用程序中我对存储过程执行选择命令,但我想将相同的获取数据插入到另一个表中。

所以我尝试做类似以下的事情

CREATE PROCEDURE profinalinstexpensesonid  
    (@from varchar(5000),                
     @to varchar(5000),                
     @trainer varchar(5000),  
     @sonvinid varchar(5000)              
    )            
AS                
BEGIN    
    INSERT INTO invoice(sonvinid, tid, date, brandname, zone, location, area, venuename, venue, instructore, amount)  
        SELECT
            instructoreexpense.sonvinid,  
            sonvininsert.trainer,               
            CONVERT(VARCHAR, sonvininsert.date, 105) AS date,
            sonvininsert.brandname,                
            SUBSTRING(sonvininsert.zone, 1, 1) AS zone,                
            sonvininsert.location,                
            sonvininsert.area,                
            companysonvinunitvenue.venuename,              
            sonvininsert.venue,                
            sonvininsert.instructore,                            
            instructoreexpense.amount  
        FROM
            instructoreexpense                 
        LEFT OUTER JOIN
            sonvininsert ON sonvininsert.sonvinid = instructoreexpense.sonvinid 
                         AND sonvininsert.status = '0'                  
        LEFT OUTER JOIN 
            finalinstructoreexpense ON finalinstructoreexpense.sonvinid = instructoreexpense.sonvinid                  
        LEFT OUTER JOIN
            companysonvinunitvenue ON companysonvinunitvenue.id =  sonvininsert.comsonvinid                           
        WHERE
            sonvininsert.date BETWEEN CONVERT(DATETIME, @from, 105)
                                  AND CONVERT(DATETIME, @to, 105) 
            AND sonvininsert.trainer = (SELECT empname 
                                        FROM trainerdetails 
                                        WHERE trid = @trainer)  
            AND instructoreexpense.sonvinid NOT IN (SELECT CAST(Item AS INTEGER)  
                                                    FROM SplitString(@sonvinid, ','))
        ORDER BY 
            instructoreexpense.sonvinid  
END   

当我执行存储过程时

exec profinalinstexpensesonid '01-01-2013','01-01-2017','andrews'

我收到以下错误

消息 8152,级别 16,状态 13,过程 profinalinstexpensesonid,第 10 行
字符串或二进制数据将被截断。

在我的第 10 行,我有以下代码

insert into invoice(sonvinid, tid, date, brandname, zone, location, area, venuename, venue, instructore, amount)

我不知道这里有什么问题?

4

2 回答 2

2

错误消息指出invoice表中列的大小小于插入其中的数据的大小。

例如,如果列brandname具有数据类型varchar(50)并且您尝试插入多个50字符,那么它将导致错误。

要解决此问题invoice,请将列的大小与插入的列的大小进行比较。

于 2017-01-19T07:11:16.577 回答
0

您需要检查发票表的列大小以及从中填充数据的选择列表中的列。

假设您要在具有 table1varchar(70)中的数据类型的列“A”中插入具有来自 table2 的数据类型的列“B” varchar(50);这不起作用,因为您试图在 50varchar大小的列中插入 70 个字符。

检查源和目标列数据类型及其长度;并更改它并重试。

于 2017-01-19T07:29:39.963 回答