当前位置:首页 > 用友T3用友通 > 正文内容

用友T3记账时报错,运行时错误‘-2147217873,怎么办?

8年前用友T3用友通5210

用友T3财务软件在记账的时候提示错误:运行时错误‘-2147217873(80040e2f)':违反了PRIMMARY KEY 约束‘GL-mpostcond1_pk"不能在对象‘GL-Mpostcond1中键入重复键。如下图所示:

运行时错误‘-2147217873(80040e2f)':违反了PRIMMARY KEY 约束‘GL-mpostcond1_pk"不能在对象‘GL-Mpostcond1中键入重复键错误提示图片

也有不少的财务会计朋友是在使用用友通T3软件的返记账过程中提示的。那么怎么解决这个问题呢?

微信号:yyrjlls
扫码 有偿解决 用友软件技术问题!
复制微信号

经过用友财务软件小编跟踪数据库发现主要是软件考虑的不够周全,后来用友畅捷通用友T310.8plus1标准版及后续版本使用补丁做了改进了,所以解决这个问题要看版本。

如果是用友T310.8plus1之前的版本,请先在查询分析器中执行如下脚本:

use ufdata_xxx_2014

delete from gl_mpostcond1

然后再执行如下脚本,避免后续出现类似的问题。

SET QUOTED_IDENTIFIER OFF      
GO      
SET ANSI_NULLS ON      
GO      
ALTER Proc [dbo].[GL_P_JZA](@iPer tinyint = 11, @ccash tinyint =1, @tcond varchar(5000)= '') AS SET NOCOUNT On declare @ss varchar(8000)      
declare @Checkflag varchar(20) declare @trnd bigint set @trnd=(select convert(bigint,rand()*100000000000)) declare @temptable varchar(50) declare @temptable2 varchar(50) set @temptable='GL_jztmp'+ convert(varchar(30),@trnd) set @temptable2='gl_bookB'+ convert(varchar(30),@trnd) set @Checkflag = (SELECT cvalue FROM AccInformation WHERE cSysID='GL' AND cName='bNotCheckJz')      
Delete From GL_mpostcond1 if @ccash=0 begin      
if @Checkflag = 'False' set @ss='SELECT iperiod,isignseq,ino_id From gl_accvouch where ibook=0 and iperiod= '+convert(char,@iPer,0) +(case when @tcond='' then '' else ' and (' + @tcond + ')' end)+' and (not (ccheck is null) and iflag is null or ccheck is null and iflag=1) GROUP BY iperiod,isignseq,ino_id' else set @ss='SELECT iperiod,isignseq,ino_id From gl_accvouch where ibook=0 and iperiod= '+convert(char,@iPer,0) +(case when @tcond='' then '' else ' and (' + @tcond + ')' end)+' and (iflag is null or ccheck is null and iflag=1) GROUP BY iperiod,isignseq,ino_id'      
Insert GL_mpostcond1 exec (@ss) End Else begin if not object_id('tempdb..'+@temptable) is null exec('drop table tempdb..'+ @temptable)      
if @Checkflag = 'False' set @ss='SELECT isignseq,ino_id,1 as zt into tempdb..'+@temptable+' FROM gl_accvouch inner join code ON gl_accvouch.ccode = code.ccode where ibook=0 and iperiod= '+convert(char,@iPer,0)+(case when @tcond='' then '' else ' and (' + @tcond + ')' end) +' and ((code.bbank ^ code.bcash) =1) and ((not (ccheck is null)) and (ccashier is null)) GROUP BY isignseq,ino_id Union SELECT isignseq,ino_id,0 as zt From gl_accvouch where ibook=0 and iperiod= '+convert(char,@iPer,0) +(case when @tcond='' then '' else ' and (' + @tcond + ')' end)+' and (not (ccheck is null) and iflag is null or ccheck is null and iflag=1) GROUP BY isignseq,ino_id' else set @ss='SELECT isignseq,ino_id,1 as zt into tempdb..'+@temptable+' FROM gl_accvouch inner join code ON gl_accvouch.ccode = code.ccode where ibook=0 and iperiod= '+convert(char,@iPer,0)+(case when @tcond='' then '' else ' and (' + @tcond + ')' end) +' and ((code.bbank ^ code.bcash) =1) and (ccashier is null) GROUP BY isignseq,ino_id Union SELECT isignseq,ino_id,0 as zt From gl_accvouch where ibook=0 and iperiod= '+convert(char,@iPer,0) +(case when @tcond='' then '' else ' and (' + @tcond + ')' end)+' and (iflag is null or ccheck is null and iflag=1) GROUP BY isignseq,ino_id'      
exec (@ss) exec('SELECT isignseq,ino_id,sum(zt) as zt1 into tempdb..' + @temptable2 + ' from tempdb..'+@temptable+' group by isignseq,ino_id') set @ss='select '+convert(char,@iPer,0)+' as iperiod,isignseq,ino_id from tempdb..' + @temptable2 + ' Where zt1 = 0 '+(case when @tcond='' then '' else ' and (' + @tcond + ')' end) insert GL_mpostcond1 exec (@ss) if not object_id('tempdb..'+@temptable2) is null exec('drop table tempdb..'+ @temptable2) End      
GO      
SET QUOTED_IDENTIFIER OFF      
GO      
SET ANSI_NULLS ON      
GO

如果是用友T310.8plus1之后的版本,包括用友T310.8plus1普及版和标准版请直接安装最新的补丁就行了,补丁下载地址在论坛中有哦:http://edu.zzerp.net

温馨提示:近期载地址失效频繁,如链接失效请点击此处查阅详情!

相关文章

怎样取消用友软件(T3/T6/U8)的月末结账

问题现象:怎样取消用友软件(T3/T6/U8)的月末结账?(一)如何取消月末结账在结账状态下,CTRL+SHIFT+F6,取消结账必须由账套主管完成。操作:在月末结账的状态处,点击到"取消结...

由于调拨业务引起的实际结存单价不符的情况如何处理?

问题现象:在用友U8软件的库存中填制库存调拔单时,所引用的存货的单价不是全月平均法计算出来的单价(仓库都选用的提全月平均法计价),而引用的是调出仓库的上月的期末结存单价,造成与实际结存单价不符的情况,...

用友U8财务软件教程之总账报表

用友U8财务软件教程之总账报表

问题现象:用友U8财务软件教程之总账报表? 1.首先点击电脑左下角开始按钮,进入u8的系统管理。 2.注册,然后以管理员admin的身份进入。...

用友U8期初余额如何清零重新结转?

问题现象:用友U8期初余额如何清零重新结转?1、把系统日期调整到上年年末,登录总账;2、反结上年12月份账;3、增补上年利润结转到利润分配的结转凭证,并审核记账;4、重新结转去年12月份账;5、把系统...

用友u8存货核算取消记账时,能否选任意一张单据

问题现象:用友u8存货核算取消记账时,能否选任意一张单据? 单选全月平均仓库、个别计价仓库和计划价仓库(没有做过计划价调整)时,可以选取任意一张单据,对于移动平均、先进先出、后进先出核算的方式下,由...

U8年结技术之常见错误存货模块在12月份期末处理时,提示有暂估报销单据

问题现象:U8年结技术之常见错误存货模块在12月份期末处理时,提示有暂估报销单据未进行结算成本处理,而在结算成本处理处,却过滤不出来单据。存货模块在12月份期末处理时,提示有暂估报销单据未进行结算成本...

发表评论

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。