Access 新手来看:编号的生成问题

原创 2004年04月05日 23:22:00

Access 新手来看:编号的生成问题

 

 

问题:

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

 

回答:

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

 

问题:


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

 

回答:

你可以在保存按钮上写点代码切分数据,即使连续窗体也可以在 BEFOREUPDATE事件里面写代码。代码可以类似:
Sub SplitString()
    Dim strA() As String
    strA() = Split(Me.TextBoxA, "-")
    Dim i As Integer
    For i = 0 To UBound(strA)
        Debug.Print strA(i)
        Me("TextBox" & i).value=strA(i)
    Next
End Sub

http://access911.net 站长收藏

Access新手来看:Access的特点、概念

Access新手来看:Access的特点、概念 问题:这里只解决一个问题,到底什么是Access? 设计一个数据库管理系统,用access在access里面设计好表,查询,,然后再用vb做窗体做连接,...
  • changechange
  • changechange
  • 2004年01月25日 21:19
  • 4728

java(优化一) 编号规则生成器(一)

一 需求: 编写一个接口,要求自动生成000001-999999的一个值。传入参数:user_id、project_code 返回结果:000001-999999中不重复的数值。 二 操作步骤:  ...
  • zengdeqing2012
  • zengdeqing2012
  • 2015年04月22日 14:19
  • 2748

ACCESS中使用GUID全局唯一标识符的自动唯一编号[同步复制ID]之解决方法

背景:这段时间临时为一个旅游类网站制作一些网站程序。数据表的情况大致如下: 图1 数据库表的大致情况 由于是Access数据库,之前有两个数据表:TC_TourCompany和TC_SubDetai...
  • johnsuna
  • johnsuna
  • 2008年04月24日 11:00
  • 20653

生成不重复唯一编号工具类

生成不重复唯一编号工具类根据ip地址,MAC地址,访问时间以及哈希算法生成唯一不重复的唯一编号以及访问IP地址获取工具类/** * 生成随机数工具类 * @author sun Email:wns...
  • u010427935
  • u010427935
  • 2016年08月24日 13:54
  • 5978

access自动编号字段出现重复

今天修复一个客户的数据库,竟然发现自增字段作为主键的一个表更新数据时提示主键重复,在表中手动输入数据后,发现自动生成的数字与前面的有重复! 而且access的压缩修复功能发现不了这个错误,修复不了它...
  • hank5658
  • hank5658
  • 2012年05月03日 14:58
  • 1359

Java生成NO201601270001这样的流水编号

首先从数据库查询出已有的最大编号 拼成NO+当前时间格式的字符串 判断最大编号是否存在,最大编号中是否包含当天时间 如果最大编号不存在,则直接生成第一个编号NO201601270001 如果最大编号存...
  • jianyuerensheng
  • jianyuerensheng
  • 2016年01月27日 09:26
  • 6923

自动生成自增长编号

/// 单据编号,产生自增编号,如:入参为"DJ000002",将返回"DJ000003"         ///         /// 原值         /// 下一值       ...
  • suixufeng
  • suixufeng
  • 2013年10月09日 16:52
  • 1657

ADO 实现ACCESS文本型自动连续编号

Option Compare DatabaseOption ExplicitDim objrs1 As ADODB.RecordsetDim zdm()   定义动态数组Private Sub For...
  • shable
  • shable
  • 2006年05月07日 12:23
  • 853

java生成随机编码的方法(新)。

import java.util.Calendar; /**  * @author : suyuyuan * @date :2016年6月3日 下午4:50:42  * @versio...
  • suyu_yuan
  • suyu_yuan
  • 2016年06月06日 10:49
  • 593

设置ACCESS自动编号的格式

设置ACCESS自动编号的格式【转】 一,Access中的“自动编号”怎么才能不从1开始 1、在access里新建一个查询。 2、把视图改为sql视图。 3、在里面输入:    AL...
  • gavin_yang
  • gavin_yang
  • 2013年07月04日 20:31
  • 2713
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Access 新手来看:编号的生成问题
举报原因:
原因补充:

(最多只允许输入30个字)