Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> 查询  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1702038
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

如何更改数据类型为“自动编号”“同步复制ID”的值?

作者:cg1  摘自:access911.net  :cg1  更新日期:2006-1-12  浏览人次:

 

问题:

我有一个表,里面有一个“自动编号”“长整型”字段,我如何修改该字段?
如何更改数据类型为“自动编号”“同步复制ID”的值?
我想添加一条记录,但是自动编号字段我想用我自己已经生成的GUID,但是 ACCESS 在状态栏提示我控件不能编辑。
我想更改已经存在的某条记录的自动编号同步复制ID,该如何操作?

 

回答:

ACCESS 的自动编号字段一旦生成就不能更改了。你可以在新增记录的时候自己定义这个自动编号字段是数值。但是,如果这个字段是“自动编号”“长整型”字段,那么一旦你自己定义了某个新增记录的数值后,这个字段的步进值和起始值都会更改,可能会导致以后生成数据时发生错误。

先举例说明如何自定义新增的“自动编号”“同步复制ID”的值:
用以下SQL语句新建一个查询即可
INSERT INTO 表名 (字段名) VALUES ("{AAC51707-43DF-4B02-9D81-2AFA211dEB56}")


当然,你也可以在 ADODB.RECORDSET.ADDNEW 的时候定义某个 
RECORDSET("字段名")=GUIDFromString("{AAC51707-43DF-4B02-9D81-2AFA2112EB51}")


注意这里有一个函数 GUIDFromString ,你可以查一下帮助,里面有具体的说明。

如果该记录已经存在,那么可以先新增一条记录,然后删除原先的记录就可以了。
比如有如下表:

自动编号同步复制ID                         字段2       字段3
{0AC51707-43DF-4B02-9D81-2AFA2112EB51}        ab          cd

我要更改这条记录的 GUID 为 {0AC51707-43DF-4B02-9D81-2AFA2112EB77} ,那么代码如下:
Function Test_ReplaceGUID()
    Dim strSQL As String
    strSQL = "insert into 表1(自动编号同步复制ID,字段2,字段3) select '{0AC51707-43DF-4B02-9D81-2AFA2112EB77}' AS NewGUID,字段2,字段3 FROM 表1 where 自动编号同步复制ID = '{0AC51707-43DF-4B02-9D81-2AFA2112EB51}'"
    CurrentProject.Connection.Execute strSQL
    strSQL = "delete from 表1 where 自动编号同步复制ID='{0AC51707-43DF-4B02-9D81-2AFA2112EB51}'"
    CurrentProject.Connection.Execute strSQL
End Function

当然,您最好加上事务处理以保证数据完整性
关于事务处理请参考以下文章及其相关文章: 
    什么是事务处理?怎么进行事务处理? 
    http://access911.net/?kbid;71FABE1E13DC

针对“自动编号”“长整型”字段,如果你要更改它的值,上述代码的方法也是可行的
Function Test_ReplaceAutoID()
    Dim strSQL As String
    strSQL = "insert into 表1(自动编号长整型,字段2,字段3) select 9 AS NewID,字段2,字段3 FROM 表1 where 自动编号长整型 = 1"
    CurrentProject.Connection.Execute strSQL
    strSQL = "delete from 表1 where 自动编号长整型=1"
    CurrentProject.Connection.Execute strSQL
End Function

注意,上述代码必须在 自动编号长整型 没有 9 这个值的时候才能运行,而且运行后其初始值将更改为 9 ,如果步进值为1,那么下一个编号为 10 ,如果编号为 10 的记录已经存在,那么将出现错误。

 

本站文章旨在为该问题提供解决思路及关键性代码,并不能完成应该由网友自己完成的所有工作,请网友在仔细看文章并理解思路的基础上举一反三、灵活运用。

access911.net 原创文章,作者本人对文章保留一切权利。
如需转载必须征得作者同意并注明本站链接

 

 
相关文章
     没有手动相关文章
     如何用JET SQL DDL创建自动编号GUID字段
     如何在已有数据的情况下更改某列的数据类型为“自动编号 递增”
     关于如何得到新增记录的自动编号字段数值方法三
     自动编号如果递增到的最大数后会怎么样?什么是同步复制ID?
     自动编号的字段在删除记录后编号不连续
     误删除了某条含有自动编号字段的记录?怎么恢复?
     关于如何得到新增记录的自动编号字段数值方法二
     如何定义自动编号字段的初始值和步进值?
     如何在表中新插入新记录后,获取该记录自动编号字段的值?
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利