欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【Access 新手来看:编号的生成问题】,下面是详细的分享!
Access 新手来看:编号的生成问题
简述:以一段聊天记录来解释实际生活中编号的定义方法以及误区
问题:
我跟你说说我这边的情况吧。好像工号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 |
以上所分享的是关于Access 新手来看:编号的生成问题,下面是编辑为你推荐的有价值的用户互动:
相关问题:ACCESS数据库自动编号中怎样生成001、002…………
答:Access 默认的自动编号为1、2、……100、101,为了满足题目的要求,需要将自动编号的ID修改一下格式,如下图: 保存后,结果如下: >>详细
相关问题:请问在Access里,如何自动生成这种编号?
答:提供一个思路吧,在SQL Server 2008中测试。假设你这个表名叫Product。 Declare @Type nvarchar(8) Set @Type = 'A' Declare @TypeCnt Int Select @TypeCnt = COUNT(1) From Product Where [产品类别] = @Type Set @TypeCnt = @TypeCnt + 1 Inse... >>详细
相关问题:请问,如何将access的自动编号设置成“年份+编号”,...
答:有几种解决方法: (一)用VBA编程一个自定义函数,准备设为自动编号的字段值设为长整型,其默认值用自定义函数生成填入。 (二)不编程: 首先,在设计视图,将表新建一字段“年份”,其默认值=Year(Now()),自动编号的字段的格式设为“000”(个数... >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
