PB11.5+SQL2005的一个老有关问题——标识符无法更新,老鸟们来帮看看
PB11.5+SQL2005的一个老问题——标识符无法更新,老鸟们来帮看看。
记得曾经解决过这个问题,但是忘了是怎么解决的了,隐约记得好像是什么文件的设置问题。请大家帮看看:
用PB8的时候,就碰到过这个问题。在数据窗口中Insert——Update后,新增行的标识列的值无法自动返回。
在安装PB的本机上,这个标识列值是可以自动返回的,Update后马上就能看见。但是在安装Runtime Packager的客户机上,无法自动返回这个标识列的值,Update后仍然是空框框,但是数据库里肯定是保存起了的(只是无法自动返回到程序的数据窗口中)。
由于我必须要GetItemNumber 其值,所以很头痛。
我的pbodb115.ini设置如下:
[Microsoft SQL Server]
PBCatalogOwner='dbo'
PBSystemOwner='sys'
PBSyntax='MS_SQLSERVER_SYNTAX'
PBDateTime='MSSQLSERVER_DATETIME'
PBFunctions='MSSQL_FUNCTIONS'
PBSpecialDataTypes='SYBASE_SPECIALDATATYPES'
PBObjectIDs='YES'
PBMaxBlobSize='0'
PBMaxTextSize='32767'
PBDWDynamic='NO'
PBPrimaryKeyName='YES'
Block=1
SQLSrvrTSPrefix='0x'
PBUseProcOwner='YES'
PBDefaultValues='USER,SYSTEM_USER,USER_ID(),HOST_ID(),HOST_NAME(),DB_ID(),DB_NAME(),CURRENT_TIMESTAMP,NULL'
PBDefaultCreate='YES'
PBDefaultAlter='NO'
PBDefaultExpressions='YES'
请老鸟们帮我想想~~~~~~~~~~~~~~~~~谢谢
------解决方案--------------------
试试加
DbParm="Identity='SCOPE_IDENTITY()'"
并且如果有触发器的要加
set nocount on
这个是必须的
------解决方案--------------------
我也遇到这样的情况,解决方案是修改identity产生方式;
PB默认的自增是使用@@IDENTITY,这个你PB连接配置里能够找到;
我一般都这样使用
Database='databaseName',CommitOnDisconnect='No',Identity='IDENT_CURRENT()'
当然你使用SCOPE_IDENTITY也行,只是作用域不同;当然根据你个人情况了!
在一条 INSERT、SELECT INTO 或大容量复制语句完成后,@@IDENTITY 中包含语句生成的最后一个标识值。如果语句未影响任何包含标识列的表,则 @@IDENTITY 返回 NULL。如果插入了多个行,生成了多个标识值,则 @@IDENTITY 将返回最后生成的标识值。如果语句触发了一个或多个触发器,该触发器又执行了生成标识值的插入操作,那么,在语句执行后立即调用 @@IDENTITY 将返回触发器生成的最后一个标识值。如果对包含标识列的表执行插入操作后触发了触发器,并且触发器对另一个没有标识列的表执行了插入操作,则 @@IDENTITY 将返回第一次插入的标识值。出现 INSERT 或 SELECT INTO 语句失败或大容量复制失败,或者事务被回滚的情况时,@@IDENTITY 值不会恢复为以前的设置。
如果语句和事务失败,它们会更改表的当前标识,从而使标识列中的值出现不连贯现象。即使未提交试图向表中插入值的事务,也永远无法回滚标识值。例如,如果因 IGNORE_DUP_KEY 冲突而导致 INSERT 语句失败,表的当前标识值仍然会增加。
@@IDENTITY、SCOPE_IDENTITY 和 IDENT_CURRENT 是相似的函数,因为他们都返回插入到表的 IDENTITY 列的最后一个值。
@@IDENTITY 和 SCOPE_IDENTITY 可以返回当前会话中的所有表中生成的最后一个标识值。但是,SCOPE_IDENTITY 只在当前作用域内返回值,而 @@IDENTITY 不限于特定的作用域。
IDENT_CURRENT 不受作用域和会话的限制,而受限于指定的表。IDENT_CURRENT 可以返回任何会话和任何作用域中为特定表生成的标识值。
@@IDENTITY 函数的作用域是执行该函数的本地服务器上的当前会话。此函数不能应用于远程或链接服务器。若要获得其他服务器上的标识值,请在远程服务器或链接服务器上执行存储过程,并使(在远程或链接服务器的环境中执行的)该存储过程收集标识值,并将其返回本地服务器上的发出调用的连接。
记得曾经解决过这个问题,但是忘了是怎么解决的了,隐约记得好像是什么文件的设置问题。请大家帮看看:
用PB8的时候,就碰到过这个问题。在数据窗口中Insert——Update后,新增行的标识列的值无法自动返回。
在安装PB的本机上,这个标识列值是可以自动返回的,Update后马上就能看见。但是在安装Runtime Packager的客户机上,无法自动返回这个标识列的值,Update后仍然是空框框,但是数据库里肯定是保存起了的(只是无法自动返回到程序的数据窗口中)。
由于我必须要GetItemNumber 其值,所以很头痛。
我的pbodb115.ini设置如下:
[Microsoft SQL Server]
PBCatalogOwner='dbo'
PBSystemOwner='sys'
PBSyntax='MS_SQLSERVER_SYNTAX'
PBDateTime='MSSQLSERVER_DATETIME'
PBFunctions='MSSQL_FUNCTIONS'
PBSpecialDataTypes='SYBASE_SPECIALDATATYPES'
PBObjectIDs='YES'
PBMaxBlobSize='0'
PBMaxTextSize='32767'
PBDWDynamic='NO'
PBPrimaryKeyName='YES'
Block=1
SQLSrvrTSPrefix='0x'
PBUseProcOwner='YES'
PBDefaultValues='USER,SYSTEM_USER,USER_ID(),HOST_ID(),HOST_NAME(),DB_ID(),DB_NAME(),CURRENT_TIMESTAMP,NULL'
PBDefaultCreate='YES'
PBDefaultAlter='NO'
PBDefaultExpressions='YES'
请老鸟们帮我想想~~~~~~~~~~~~~~~~~谢谢
------解决方案--------------------
试试加
DbParm="Identity='SCOPE_IDENTITY()'"
并且如果有触发器的要加
set nocount on
这个是必须的
------解决方案--------------------
我也遇到这样的情况,解决方案是修改identity产生方式;
PB默认的自增是使用@@IDENTITY,这个你PB连接配置里能够找到;
我一般都这样使用
Database='databaseName',CommitOnDisconnect='No',Identity='IDENT_CURRENT()'
当然你使用SCOPE_IDENTITY也行,只是作用域不同;当然根据你个人情况了!
在一条 INSERT、SELECT INTO 或大容量复制语句完成后,@@IDENTITY 中包含语句生成的最后一个标识值。如果语句未影响任何包含标识列的表,则 @@IDENTITY 返回 NULL。如果插入了多个行,生成了多个标识值,则 @@IDENTITY 将返回最后生成的标识值。如果语句触发了一个或多个触发器,该触发器又执行了生成标识值的插入操作,那么,在语句执行后立即调用 @@IDENTITY 将返回触发器生成的最后一个标识值。如果对包含标识列的表执行插入操作后触发了触发器,并且触发器对另一个没有标识列的表执行了插入操作,则 @@IDENTITY 将返回第一次插入的标识值。出现 INSERT 或 SELECT INTO 语句失败或大容量复制失败,或者事务被回滚的情况时,@@IDENTITY 值不会恢复为以前的设置。
如果语句和事务失败,它们会更改表的当前标识,从而使标识列中的值出现不连贯现象。即使未提交试图向表中插入值的事务,也永远无法回滚标识值。例如,如果因 IGNORE_DUP_KEY 冲突而导致 INSERT 语句失败,表的当前标识值仍然会增加。
@@IDENTITY、SCOPE_IDENTITY 和 IDENT_CURRENT 是相似的函数,因为他们都返回插入到表的 IDENTITY 列的最后一个值。
@@IDENTITY 和 SCOPE_IDENTITY 可以返回当前会话中的所有表中生成的最后一个标识值。但是,SCOPE_IDENTITY 只在当前作用域内返回值,而 @@IDENTITY 不限于特定的作用域。
IDENT_CURRENT 不受作用域和会话的限制,而受限于指定的表。IDENT_CURRENT 可以返回任何会话和任何作用域中为特定表生成的标识值。
@@IDENTITY 函数的作用域是执行该函数的本地服务器上的当前会话。此函数不能应用于远程或链接服务器。若要获得其他服务器上的标识值,请在远程服务器或链接服务器上执行存储过程,并使(在远程或链接服务器的环境中执行的)该存储过程收集标识值,并将其返回本地服务器上的发出调用的连接。