Access交流网
  • 设为首页|收藏本站|繁体中文|手机版
  •     
  • Access培训-Access开发平台-Access行业开发

  • 首页
  • 资讯
  • 技巧
  • 源码
  • 行业
  • 资源
  • 活动
  • 关于

技巧

ACCESS数据库

启动/设置/选项/背景

修复/压缩

安全/加密/解密

快捷键

版本升级/其它等

数据表

命名方式/设计规范

表设计

查询

Sql语言基础

选择查询

更新查询

删除查询

追加查询

生成表查询

交叉表查询

SQL特定查询

查询参数

查询综合应用

界面/窗体/控件

标签

文本框

命令按钮

组合框/列表框

选项组/复选框/选项按钮

选项卡

子窗体

窗体本身/综合应用

其它

报表打印

报表设计

高级报表

模块/函数/VBA/API/系统

VBA基础

内置函数

调试/跟踪/Debug

模块/类模块

API/COM/系统相关

字符数字日期

网络通信游戏

加密解密安全

文件处理

经典算法

宏/菜单/工具栏/功能区

宏/脚本

菜单/工具栏

功能区/Ribbon

图表/图形/图像/多媒体

图表

图形/图像

音频

视频/动画

DAO/链接表/ADO/ADP

DAO/链接表/ODBC

ADO/RDO

ADP

ActiveX/第三方控件/插件

Treeview树控件

ListView列表控件

Toolbar工具栏控件

微软其它控件

Dbi-Tech

CodeJock

Grid++Report

FastReport

ComponentOne

加载项/插件/Addin

OFFICE集成/导入导出/交互

Excel导入导出/交互

Word导入导出/交互

PPT交互

Outlook控制/邮件

Text文本文件/INI/CSV

PDF/SWF/XML格式

CAD格式

Sharepoint/其它Office

SqlServer/其它数据库

表

视图

存储过程/触发器

函数

用户/权限/安全

调试/维护

SqlServer其它/综合

发布/打包/文档/帮助

开发版/运行时

打包/发布/部署

开发文档/帮助制作

Access完整行业系统

采购管理系统

销售管理系统

仓库管理系统

人力资源管理HRM

CRM管理系统

MRP/ERP管理系统

BRP/流程优化

其它管理系统

心得/经验/绝招
其它/杂项
Excel技巧

Excel应用与操作

Excel开发编程

Word技巧

Word应用与操作

Word开发编程

Outlook技巧

Outlook应用与操作

Outlook开发编程

热门文章

  • Access建表规范总结(..
  • 自动编号的字段在删除记录后..
  • Access隐藏表中的列
  • 真正实现两个列表框动态关联
  • 让Access的自动编号字..
  • 用交叉表来反映帐龄的2种方..

最新文章

  • Access用代码创建表
  • access表的设计技巧
  • access实现自动编号从..
  • Access2010出现“..
  • 使用输入掩码控制数据输入格..
  • 索引和主键的异同

联系方式

Access交流网(免费Access交流)

QQ:18449932 

网  址:www.access-cn.com

当前位置:首页 > 技巧 > 数据表 > 表设计
表设计

如何解决导出DBF时“字段将不能置于记录中”错误?记录过大错误

题:

  如何解决导出DBF时“字段将不能置于记录中”错误?

 

 

 

回答:
 

 
access表的文字字段总长度应小于3900(2007中估算)个字节。

 

以前有人提问在设计表或者更改表的时候提示“记录过大”,原因:access 2003 及以前对文字字段总长度有2000个字符数的限制,所以不要在一个表中创建太多文字字段。
access 2007 当字段的 UnicodeCompression 属性设置为“是”时记录中的字符个数(除“备注”和“OLE 对象”字段外)为4000以下。

 

'===========================================================
' 过程及函数名:  RaiseError
' 版本号      :  --
' 说明        :  本示例演示怎样会发生“字段将不能置于记录中”错误
'                 access导出到DBF时提示“字段将不能置于记录中。”
'                 引起上述错误的原因可能是access表的字段中文本字段
'                 太多,造成总长度超过 DBF 限制。
'                 解决方案是减少字段总长度,或者分多个DBF导出,在
'                 FoxPro 中再进行组合。
' 测试环境    :  win2003+office2007 chs
' 引用        :  --
' 输入参数    :  --
' 输出值      :  --
' 返回值      :  --
' 调用演示    :  RaiseError
'                 按 Alt+F11 转到VBE界面,菜单->插入->模块
'                 将下列代码赋值粘贴进模块,将光标停放(单击)在
'                 Function RaiseError 这行上,然后按F5键运行看效果
' 最后修改日期:  2008-10-26 11:59:00
' 示例地址    :  http://access911.net/?kbid;72FABF1E13DCE7F3
' 作者        :  cg1
' 电子邮件    :  access911@gmail.com
' 版权        :  作者保留一切权力,
'                 请在公布本代码时将本段说明一起公布,谢谢!
'===========================================================

Function RaiseError()

 

    Dim strSql As String
    Dim strFields As String
    Dim i As Long
    
    
    For i = 1 To 40
        strFields = strFields & ", f" & i & " text(250)"
    Next
    
    DropTable "test_temp"
    
    strSql = "create table test_temp (f0 text(250) " & strFields & " )"
    CurrentProject.Connection.Execute strSql
    
    '以下这行将提示错误“字段将不能置于记录中”。
    DoCmd.TransferDatabase acExport, "dBase 5.0", CurrentProject.Path, acTable, "test_temp", "aaa.dbf"
    
    '将每个文本字段的字段长度尽量减少即可解决问题,或者分多次导出到多个 DBF ,每次只导出几个字段,也可以。
    
    
End Function


Function DropTable(ByVal TableName)
On Error Resume Next
    Dim strSql As String
    strSql = "drop table " & TableName
    CurrentProject.Connection.Execute strSql
End Function

 

 

 

 

 

'===========================================================
' 过程及函数名:  TestFieldsLenCountLimit
' 版本号      :  --
' 说明        :  测试总长度达到多少时会出错。测试结果是一般为3900-4000
' 测试环境    :  win2003+office2007 chs
' 引用        :  --
' 输入参数    :  --
' 输出值      :  --
' 返回值      :  --
' 调用演示    :  TestFieldsLenCountLimit
'                 按 Alt+F11 转到VBE界面,菜单->插入->模块
'                 将下列代码赋值粘贴进模块,将光标停放(单击)在
'                 TestFieldsLenCountLimit 这行上,然后按F5键运行看效果
' 最后修改日期:  2008-10-26 11:59:00
' 示例地址    :  http://access911.net/?kbid;72FABF1E13DCE7F3
' 作者        :  cg1
' 电子邮件    :  access911@gmail.com
' 版权        :  作者保留一切权力,
'                 请在公布本代码时将本段说明一起公布,谢谢!
'===========================================================

Function TestFieldsLenCountLimit()
    Dim i As Long
    Dim lngFieldSize As Long
    Dim lngStart As Long
    lngStart = 235
    lngFieldSize = 16
    
    For i = lngStart To 255
        Debug.Print "正在测试" & i & "个字段"
        DoEvents
        If RaiseError1(i, lngFieldSize) = True Then
            Debug.Print i, "测试长度:" & i * lngFieldSize
            Exit For
        End If
    Next
End Function

 

Private Function RaiseError1(ByVal fields As Long, ByVal TextLength As Long) As Boolean

    Dim strSql As String
    Dim strFields As String
    Dim i As Long
On Error GoTo RaiseError1_Err
    
    For i = 1 To fields
        strFields = strFields & ", f" & i & " text(" & TextLength & ")"
    Next
    
    DropTable "test_temp"
    
    strSql = "create table test_temp (f0 long " & strFields & " )"
    Debug.Print strSql
    CurrentProject.Connection.Execute strSql
    
    '以下这行将提示错误“字段将不能置于记录中”。
    DoCmd.TransferDatabase acExport, "dBase 5.0", CurrentProject.Path, acTable, "test_temp", "aaa.dbf"
    
    '将每个文本字段的字段长度尽量减少即可解决问题,或者分多次导出到多个 DBF ,每次只导出几个字段,也可以。
    
    
    Exit Function
RaiseError1_Err:
    Select Case Err.Number
    Case 0
    
    Case 3016
        RaiseError1 = True
    Case Else
        MsgBox Err.Number & Err.Description
    End Select
    
    
End Function

 

 

 

 

 


发布人:cg1-access911.net  
分享到:
点击次数:  更新时间:2008-11-25 09:31:59  【打印此页】  【关闭】
上一条:如何动态创建窗体并设置页脚页眉  下一条:pb中压缩整理access数据库文件(mdb)



相关文章

  • • Access用代码创建表
  • • access表的设计技巧
  • • access实现自动编号从1开始排序且不中断
  • • Access2010出现“错误一对多” 调试解决办法
  • • 使用输入掩码控制数据输入格式
  • • 索引和主键的异同
  • • “排队不长,只是很粗”——浅谈化宽为长
  • • Access数据表能做什么

热门文章

  • [2009-04-01] 如何设置表的Caption和Description属性,即“标题”和“说明”属access数据库
  • [2005-02-04] 如何恢复误删除了含有自动编号字段的记录access数据库
  • [2009-04-02] 如何设定表的某字段默认值?access数据库
  • [2008-11-13] 十万条Access数据表分页的两个解决方法access数据库
  • [2005-02-24] 怎样确保没有空字段?access数据库
  • [2009-04-28] 何时使用导入或联接access数据库

热门产品

公司动态|在线留言|在线反馈|友情链接|会员中心|站内搜索|网站地图

Access交流网 版权所有 1999-2018 粤ICP备10043721号

QQ:18449932

Access应用 Access培训 Access开发 Access平台

access|数据库|access下载|access教程|access视频|access软件

Powered by MetInfo 5.3.12 ©2008-2023  www.metinfo.cn