Access数据库"自动编号"字段归零

Access数据库“自动编号”数据类型是一个非常实用的类型,它可以很方便地帮助我们完成标识不同记录ID的工作。但是由于JET引擎的特性(SQLserver使用T-SQL),当我们在Access数据库某张表中执行了删除所有数据的操作后,被用来标识唯一ID的字段将不再归零(从头开始计数),而是会继续延续上次ID递增计数,我们可以用若干种方法解决这样的问题,以下结合ASP推荐两种方法(以下方法都是建立在空数据表的“自动编号”归零的前提下):

第一种:压缩数据库

用过Access的朋友应该都知道在Access的工具栏上我们可以通过:

点击“工具”=>“数据库实用工具”=>“压缩和修复数据库”来完成对数据库的压缩和修复工作,当这项工作完成时,Access各空数据表的“自动编号”字段也会做归零操作。

而我们也可以用ASP来完成这项工作,以下是压缩数据库主要SUB:

Sub CompactDB(strDBFileName)

Set fso =CreateObject("Scripting.FileSystemObject")

Dim strOldDB

strOldDB = Server.MapPath(strDBFileName)

Dim strNewDB

strNewDB = Server.MapPath("New"& strDBFileName)

If fso.FileExists(strOldDB) Then

'压缩数据库

Set jro=Server.CreateObject("JRO.JetEngine")

strPvd ="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="

jro.CompactDatabase strPvd & strOldDB , strPvd& strNewDB

set jro=Nothing

'删除旧的数据库文件

fso.DeleteFile strOldDB

'将压缩好的数据库文件拷贝回来

fso.MoveFilestrNewDB, strOldDB

Response.Write "数据库压缩完毕!"

Else

Response.Write "找不到指定的数据库文件!"

End If

Set fso = Nothing

End Sub

%>

我们可以很轻松地使用完成调用。

第二种:SQL语句

如果你了解SQL里ALTER TABLE的用法,这一切将变得非常简单:

ALTER TABLE — 更改表属性

ALTER TABLE table [ * ]

ADD [ COLUMN] column type

ALTER TABLE table [ * ]

ALTER [COLUMN ] column { SET DEFAULT value | DROP DEFAULT }

ALTER TABLE table [ * ]

RENAME [COLUMN ] column TO newcolumn

ALTER TABLE table

RENAME TOnewtable

输入

table

试图更改的现存表的名称.

column

现存或新的列名称.

type

新列的类型.

newcolumn

现存列的新名称.

newtable

表的新名称.

输出

ALTER

从被更名的列或表返回的信息.

ERROR

如果一个列或表不存在返回的信息.

我们解决Access数据库“自动编号”字段自动归零可以这样完成:

ALTER TABLE tableName ALTER COLUMN OrderId COUNTER (1, 1)

其中COLUMN关键字可以省略,下面这样也是可以的:

ALTER TABLE tableName ALTER OrderId COUNTER (1, 1)

剩下的交给ASP执行SQL语句完成就可以了,这里不再赘述。

值得注意的一点:有些程序员喜欢保存Access数据库为其它后缀名如.asp、.asa等,当我们重命名这些数据库时有可能会出现数据库体积增大的情况,而这种情况亦有可能导致上面的ALTERTABLE语句无法正常工作,这种异常我曾经在改名后的Access数据库的SQL特定查询中遇到过,当时报错情况是:无效的字段数据类型。后来反复尝试了几遍,发现利用“压缩和修复数据库”也可以修复这个异常,大家可以自己注意一下^_^

Access数据库“自动编号”数据类型是一个非常实用的类型,它可以很方便地帮助我们完成标识不同记录ID的工作。但是由于JET引擎的特性(SQLserver使用T-SQL),当我们在Access数据库某张表中执行了删除所有数据的操作后,被用来标识唯一ID的字段将不再归零(从头开始计数),而是会继续延续上次ID递增计数,我们可以用若干种方法解决这样的问题,以下结合ASP推荐两种方法(以下方法都是建立在空数据表的“自动编号”归零的前提下):

第一种:压缩数据库

用过Access的朋友应该都知道在Access的工具栏上我们可以通过:

点击“工具”=>“数据库实用工具”=>“压缩和修复数据库”来完成对数据库的压缩和修复工作,当这项工作完成时,Access各空数据表的“自动编号”字段也会做归零操作。

而我们也可以用ASP来完成这项工作,以下是压缩数据库主要SUB:

Sub CompactDB(strDBFileName)

Set fso =CreateObject("Scripting.FileSystemObject")

Dim strOldDB

strOldDB = Server.MapPath(strDBFileName)

Dim strNewDB

strNewDB = Server.MapPath("New"& strDBFileName)

If fso.FileExists(strOldDB) Then

'压缩数据库

Set jro=Server.CreateObject("JRO.JetEngine")

strPvd ="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="

jro.CompactDatabase strPvd & strOldDB , strPvd& strNewDB

set jro=Nothing

'删除旧的数据库文件

fso.DeleteFile strOldDB

'将压缩好的数据库文件拷贝回来

fso.MoveFilestrNewDB, strOldDB

Response.Write "数据库压缩完毕!"

Else

Response.Write "找不到指定的数据库文件!"

End If

Set fso = Nothing

End Sub

%>

我们可以很轻松地使用完成调用。

第二种:SQL语句

如果你了解SQL里ALTER TABLE的用法,这一切将变得非常简单:

ALTER TABLE — 更改表属性

ALTER TABLE table [ * ]

ADD [ COLUMN] column type

ALTER TABLE table [ * ]

ALTER [COLUMN ] column { SET DEFAULT value | DROP DEFAULT }

ALTER TABLE table [ * ]

RENAME [COLUMN ] column TO newcolumn

ALTER TABLE table

RENAME TOnewtable

输入

table

试图更改的现存表的名称.

column

现存或新的列名称.

type

新列的类型.

newcolumn

现存列的新名称.

newtable

表的新名称.

输出

ALTER

从被更名的列或表返回的信息.

ERROR

如果一个列或表不存在返回的信息.

我们解决Access数据库“自动编号”字段自动归零可以这样完成:

ALTER TABLE tableName ALTER COLUMN OrderId COUNTER (1, 1)

其中COLUMN关键字可以省略,下面这样也是可以的:

ALTER TABLE tableName ALTER OrderId COUNTER (1, 1)

剩下的交给ASP执行SQL语句完成就可以了,这里不再赘述。

值得注意的一点:有些程序员喜欢保存Access数据库为其它后缀名如.asp、.asa等,当我们重命名这些数据库时有可能会出现数据库体积增大的情况,而这种情况亦有可能导致上面的ALTERTABLE语句无法正常工作,这种异常我曾经在改名后的Access数据库的SQL特定查询中遇到过,当时报错情况是:无效的字段数据类型。后来反复尝试了几遍,发现利用“压缩和修复数据库”也可以修复这个异常,大家可以自己注意一下^_^


相关文章

  • 计算机题目[1]
  • 第一套 1. 用于设定控件的输入格式,仅仅文本型或日期型数据有效地控件的数据属性为[输入掩 码] 2. B [?]ll 可以找到ball 和bill 和bell 3. 表结构的设计和维护,是在["表"设计器窗口中]完成的 ...查看


  • 信息资源管理
  • 1. 资源管理器是Windows系统提供的信息资源管理工具.它是采用实现目录管理 A. 树型目录 B. 网络型目录 C. 交叉型目录 D. 线性目录 2. 张先生是南京大学一位研究<红楼梦>的专家,因为研究的需耍,他现在要把有关 ...查看


  • 2010年4月全国数据库及其应用真题
  • 2010年4月全国数据库及其应用真题 一.单项选择题(本大题共20小题,每小题2分,共40分)在每小题列出的四个备选项中只有一个是符合题目要求的,请将其代码填写在题后的括号内.错选.多选或未选均无分. 1. 数据库系统与文件的主要区别是[] ...查看


  • 数据库技术期末考试试题
  • <数据库技术> 一.单项选择题(本大题共20小题,每小题2分,共40分) 1.E-R 模型属于数据库的( A ) A .概念模型 C .内部模型 B .逻辑模型 D .外部模型 2. 不同实体之间之所以不同是根据( A )的不同 ...查看


  • 数据库期末考试
  • 1."自动编号"字段的值永远不会[重复] 2.双击已创建的ACCESS 数据库文件,可启动ACCESS 并可同时[打开该库文件] 3.窗体是数据库中用户和应用程序之间的主要界面,用户对数据库的[操作]都可以通过窗体来完成 ...查看


  • 动态网页建设步骤
  • 动态网页制作基础 使用Dreamweaver 8创建动态网站时,配置计算机的系统环境很重要.需要安装并配置IIS服务.设计Access数据库.创建DSN以及定义数据库连接等.通过本次课的学习,应该掌握以下内容: 1的运行环境 在Window ...查看


  • 数据库选择题全集
  • 下列不常用的数据模型为.C 概念模型 A.层次模型 B网状模型 C概念模型 D关系模型 在关系数据模型中,用来表示实体关系的是.C 记录 A字段 B记录 C表 D指针 在关系数据库系统中,一个关系相当于.A 一张二维表 A一张二维表 B一条 ...查看


  • office办公软件高级应用
  • 第一章 1. 单选题 在Word 2010编辑状态下,绘制一文本框,应使用的选项卡是( ). (B) 开始 (C) 页面布局 (D) 引用 Word 2010的替换功能所在的选项卡是( ). (A) 视图 √ (B) 开始 (C) 插入 ( ...查看


  • 个人网站设计与实现(毕业设计论文)
  • 陕西师范大学远程教育学院 毕业论文(设计) 论文题目 个人网站设计与实现 姓 名 姜雯 学 号 [1**********]05 专 业 计算机科学技术 批次/层次 专升本 指导教师 郭志强 学习中心 西阳职教中心 目 录 摘 要 . ... ...查看


热门内容