logo 广告
Loading...
 导航 所在位置:论坛首页 -> ┈┋电脑网络┋┈ -> 数据库技术 -> Access 新手来看:编号的生成问题
回复
标题:Access 新手来看:编号的生成问题收藏 编辑 删除 楼主 | 上一篇 下一篇
内德维德
头像
等级:职业侠客
权限:普通用户
积分:67
金钱:257
声望:140
经验:140
发帖数:140
注册:2008年10月7日
资料 短消息2008-12-2 10:01:17

简述:以一段聊天记录来解释实际生活中编号的定义方法以及误区

问题:

我跟你说说我这边的情况吧。好像工号03-0756-004-1JF,表示:03表示03年生产,0756是合同号,004表示对方单位的编号,1表示合同的第几项,JF是表示车间。你说这样的工号会不会很烦?

回答:

我只能说,你在设计数据结构的时候就已经错误了。

很多程序员认为“编号”是一个字段,在计算机中这的确是正确的,但是,在计算机中,编号是没有含义的,没有语法、没有组合、没有任何意义,仅表示记录的唯一标识。而实际生产中,编号往往包含很多意义(除非你使用数据库查询系统来管理随机编号)。因此就像你说的,编号的每个部分都有含义。所以,应该以每个部分为最小单位来建立数据库结构。简单的说,就是生产日期、合同号、对方单位编号、车间分几个字段存储,这也可以说是“原子性”扩展。其实SQL不仅仅可以查询数据,还可以组织数据,比如

select日期&合同号&单位号&车间as编号,全名from产品表

问题:

但很惨的是:录入员已经习惯很连续地录入03-0456-002-4JF这样的工号了,叫他们分开来录入,恐怕很麻烦。

回答:

你可以在保存按钮上写点代码切分数据,即使连续窗体也可以在BEFOREUPDATE事件里面写代码。代码可以类似:

以下为引用的内容:
SubSplitString()
  DimstrA()AsString
  strA()=Split(Me.TextBoxA,"-")
  DimiAsInteger
  Fori=0ToUBound(strA)
    Debug.PrintstrA(i)
    Me("TextBox"&i).value=strA(i)
  Next
EndSub

签名

2008-12-2 10:01:17 顶部
第1页 共页 共0个回复     <<    >>    
 快速回复
  • 支持UBB,HTML标签

  • 高级回复

  • 操作选项:评分 加精 解精 奖惩 设专题 设公告 解公告 固顶 总固顶 解固顶 结帖 解结帖 锁帖 解锁 移帖 删帖
      首页 | 购买指南 | 虚拟主机 | 特色介绍 | 下载中心 | 支付方式
    Copyright 2004-2008 BBSGood.com Powered By: BBSGood.Speed Version 5.0
      咨询电话:0575-85513832、0575-85513825(传真)、7*24小时咨询服务:13606552007 不良信息举报中心 浙ICP备05029817号
      业务QQ:38958768、客服QQ1:415896239、客服QQ2:343896043、MSN:jccsxx@hotmail.com