a我考网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 92|回复: 0

[Access] 实例编程:Access新手来看

[复制链接]
发表于 2012-7-31 22:26:35 | 显示全部楼层 |阅读模式
述:以一段聊天记录来解释实际生活中编号的定义方法以及误区
0 K! s! ]$ e5 J, ]& g% |$ y  问题:5 |' F, Y4 h  ]' r9 R
  我跟你说说我这边的情况吧。好像工号03-0756-004-1JF,表示:03表示03年生产,0756是合同号,004表示对方单位的编号,1表示合同的第几项,JF是表示车间。你说这样的工号会不会很烦?2 k- Q5 @+ o' Q' m  V
  回答:
0 U! @4 b( W. ~. F% b' {  我只能说,你在设计数据结构的时候就已经错误了。6 F! m# G0 @9 ?9 y+ [: t
  很多程序员认为 “编号”是一个字段,在计算机中这的确是正确的,但是,在计算机中,编号是没有含义的,没有语法、没有组合、没有任何意义,仅表示记录的唯一标识。而实际生产中,编号往往包含很多意义(除非你使用数据库查询系统来管理随机编号)。因此就像你说的,编号的每个部分都有含义。所以,应该以每个部分为最小单位来建立数据库结构。简单的说,就是 生产日期、合同号、对方单位编号、车间分几个字段存储,这也可以说是“原子性”扩展。其实 SQL 不仅仅可以查询数据,还可以组织数据,比如! L) Q+ j5 B! \* \  o$ y( h0 d
  select 日期 & 合同号 & 单位号 & 车间 as 编号,全名 from 产品表9 R2 n5 ^; g7 E: r3 x. {
  问题:# P& s  K& S3 ~# c% \
  但很惨的是:录入员已经习惯很连续地录入03-0456-002-4JF这样的工号了,叫他们分开来录入,恐怕很麻烦。4 B6 Q$ m$ X8 z# Q0 H
  回答:
1 c- E6 f+ _1 g  你可以在保存按钮上写点代码切分数据,即使连续窗体也可以在 BEFOREUPDATE事件里面写代码。代码可以类似:; o' R0 }3 z7 y: J2 N; P
  Sub SplitString()
, {# s# l; N, t) q  Dim strA() As String' S' g* H% ?! g7 b0 t
  strA() = Split(Me.TextBoxA, "-")& \( \7 c5 h2 N0 z) z
  Dim i As Integer
' t. N4 S1 B! O( }5 x; k  For i = 0 To UBound(strA)& Z/ b3 w; k2 L( O1 `, Z9 w* u9 t. X
  Debug.Print strA(i)6 f6 ]6 j- c# L) I8 k! v% ?
  Me("TextBox" & i).value=strA(i)' `0 [( ^/ P3 K" a8 P
  Next
  e, t' F. H, e' N+ L8 ]2 m  ~- y  End Sub
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|Woexam.Com ( 湘ICP备18023104号 )

GMT+8, 2024-6-27 03:30 , Processed in 0.207926 second(s), 22 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表