- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在努力完成以下任务:
使用 VBA 循环遍历一个表格,并使用以下三个参数分配餐 table 上的座位:
1) 个人的优先级分数。
2) 个人对坐在哪张 table 上的偏好。
3) table 的座位数。
理想情况下,VBA 会从 Priority 1 组的第一条记录开始,分配尽可能多的人可以放在 Table1 中,然后继续根据他们的偏好分配 Priority 1 个人,同时检查他们的首选表是否是满负荷运转。
在为所有优先级为 1 的个人分配了一个表(在表对象中指定了“Table_Assignment”值)之后,VBA 移至优先级为 2 的个人,依此类推。
在我的数据库中,我有下表(名为“tbl_Assignments”的表对象):
RecordID | Table_Assignment | Priority | Title | Preference_1 | Preference_2 |... Preference_n
001 1 CEO Table1
002 1 CEO-spouse Table1
003 1 VP Table1 Table2
004 1 VP-spouse Table1 Table2
005 2 AVP Table1 Table2
006 2 AVP-spouse Table1 Table2
007 3 Chief counsel Table1 Table2 Table_n
008 3 COO Table1 Table2 Table_n
此外,我创建了一个查询,告诉您在对表进行分配时还剩下多少空缺(名为“qry_capacity_sub1”的查询对象):
TableID | Maximum_seating | Seats_taken | Vacancies
Table1 4 3 1
Table2 4 2 2
Table3 4 0 4
Table4 4 1 3
我曾尝试编写带有循环的 VBA,这将实现我的目标,即在表格 ('tbl_Assignments') 中循环并在单击窗体上的命令按钮后为 'Table_Assignment' 字段分配值。
更新 (11/09/2014):将 VBA 更新到我现在在此过程中的位置。对 VBA 的更改也反射(reflect)了 Jérôme Teisseire 的建议。
下面的 VBA 是从我在这里看到的开始的:Looping Through Table, Changing Field Values
Private Sub Command0_Click()
Dim db As DAO.Database
Dim rs As DAO.Recordset
Dim strSQL As String
Set db = CurrentDb()
strSQL = "Select RecordID, Table_Assignment, Priority, Preference_1, Preference_2, Preference_3 FROM tbl_Assignments WHERE Priority =1"
Set rs = db.OpenRecordset(strSQL)
On Error GoTo Err_Handler
Do Until rs.EOF
With rs
If there are seats available at your first preferred table Then
.Edit
!Table_Assignment = rs!Preference_1
.Update
.MoveNext
End If
If the first table you preferred has reached capacity, and there are seats left in your second preferred table Then
.Edit
!Table_Assignment = rs!Preference_2
.Update
.MoveNext
End If
'..keep checking each the person's preferred tables. If they cannot be assigned a table because their preferred tables are at capacity...
Else
.Edit
!Table_Assignment = "Unassigned"
.Update
.MoveNext
End With
Loop
rs.Close
Exit_Handler:
Set rs = Nothing
Set db = Nothing
Exit Sub
Err_Handler:
MsgBox "You need to debug"
Resume Exit_Handler
End Sub
最佳答案
可能 qry_capacity_sub1 依赖于 tbl_Assignments,当您尝试同时查询和更新它时,它会导致 Access 崩溃。为了验证这一点,您尝试用一些虚假检查替换您的 DLookup 条件,例如
If True Then
...
只是为了验证其余代码是否正常工作。
我还认为您的代码在 DLookup 条件中存在另一个逻辑错误 - “TableID='Preference_1'”将搜索“Preference_1”字符串而不是列值。我认为它一定是 liek "TableID='"+ rs!Preference_1 + "'",但恐怕这也无济于事。
我建议您将每个表的空缺缓存到 in-memory dictionary 中并在每次分配表格时减少空缺。所以代码可能类似于下面给出的。另请注意,最好不要将 MoveNext 嵌套在任何 If 中,以确保不会出现死循环(这也可能是导致崩溃的原因)。
Private Sub Command0_Click()
Dim db As DAO.Database
Dim rs As DAO.Recordset
Dim strSQL As String
Dim VacancyPerTable As New Scripting.dictionary
Set db = CurrentDb()
Set rsVac = db.OpenRecordset("SELECT DISTINCT TableID, Vacancies FROM qry_capacity_sub1")
While Not rsVac.EOF
VacancyPerTable.Add rsVac!TableID, rsVac!Vacancies
Loop
rsVac.Close
strSQL = "Select RecordID, Table_Assignment, Priority, Preference_1, Preference_2, Preference_3 FROM tbl_Assignments WHERE Priority =1"
Set rs = db.OpenRecordset(strSQL)
On Error GoTo Err_Handler
Do Until rs.EOF
With rs
If VacancyPerTable(!Preference_1) > 0 Then
.Edit
!Table_Assignment = rs.Fields(3)
.Update
VacancyPerTable(!Preference_1) = VacancyPerTable(!Preference_1) - 1
ElseIf VacancyPerTable(!Preference_2) > 0 Then
.Edit
!Table_Assignment = rs.Fields(4)
.Update
VacancyPerTable(!Preference_2) = VacancyPerTable(!Preference_2) - 1
ElseIf VacancyPerTable(!Preference_3) > 0 Then
.Edit
!Table_Assignment = rs.Fields(5)
.Update
VacancyPerTable(!Preference_3) = VacancyPerTable(!Preference_3) - 1
Else
.Edit
!Table_Assignment = "UnAssigned"
.Update
End If
.MoveNext
End With
Loop
rs.Close
Exit_Handler:
Set rs = Nothing
Set db = Nothing
Exit Sub
Err_Handler:
MsgBox "You need to debug"
Resume Exit_Handler
End Sub
关于database - 如何循环遍历某些记录、检查查询并使用 VBA 有条件地分配字段值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26813497/
如何在 2014-10-04 - 2014-10-30 仅工作日和 08.00 - 20.00 之间随机更新日期列? 2014-10-04 - 2014-10-30 random working-da
我有一个二维 (3x7) 数组,我想转换为一维数组,以便我提供的行位于中心。行值可能沿途变化,但必须位于中心。 #define numRows 3 #define numCols 7 #define
我有2张 table : 第一个是“人”: person_id, 人名 第二个是“PersonsGraphs”: person_id1, person_id2, 关系类型 我正在寻找一种建立“家谱”的
是否可以在序列化 JSON 响应的同时根据 If 条件排除某些元素? if(a == 1) { //show element } else { //don't show element }
是否可以在序列化 JSON 响应的同时根据 If 条件排除某些元素? if(a == 1) { //show element } else { //don't show element }
尝试使用 jQuery 编写一个条件,该条件基本上说明,如果 div.gathering 不包含 a.cat-link,则执行以下操作。我已经尝试过以下方法,但似乎不起作用。有人能解释一下吗? if(
该练习要求插入值 x 的副本(这也是要在列表中搜索的值),但前提是该位置是另一个值 n 的倍数。未指定副本应插入到 x 值之前还是之后。 我的问题是并非在所有情况下都插入副本。我认为问题在于,当我插入
我遇到了这个[问题]:How can I store values into a multi-parameter struct and pass typedef struct to a functio
出于某种原因,当我编写 getWinner() 时,它仅适用于 2 种情况(最后一行)。就对角线和列而言,我拥有其他一切,但第 2 行(嗯,三,但数组,所以 2)基本上只适用于 o。只有当 o 位于
我有一个问题。 我想将“guid”列中的值复制到“帖子内容” 所有行都在一个表“wp-posts”中 “postparent”列中的一行有一个值,而“ID”列中的另一项也有相同的值 我必须做的事情是
我想将两个像这样的表合并到一个表中,并为重复的键行添加合并表中最旧的 DateAdded 值。 (Key1,Key2) 是主键。 +-----------+-----------+------+---
通过下面的表格和数据,我试图获得最高的 effective_from每个唯一 brand 小于当前时间戳的值/model组合 - 实际上是每件商品的当前价格。 CREATE TABLE things
您能告诉我如何删除未知号码的最后一条记录(有条件)吗? 例如,在这种情况下我想删除id为6到10的记录。 注意:该表和记录不是恒定的。 +----+-----+---------+ | id | ur
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
我有两个表, 标签 -> id,name,description,user,status 标签_连接。 -> id, Label_id, 类别 所以有多个类别,假设 1 => 新的,2 => 旧的。
好的,我会长话短说。 这是我的代码 String s = edittextkata.getText().toString(); String[] vowels = {"a","
我有一个非常具体的要求,我发现很难做到,我需要查找并替换文件中的某些行,但问题是文本不同,唯一的好处是它们都有一个 .[扩展名] 例如: 30/07/2012 14:46 17
我有一个大型数据库,其中存在各种不一致之处。我想澄清的项目之一是根据人口更改国家/地区状态。 数据样本是: { "_id" : "D", "name" : "Deutschland", "pop" :
我需要将范围(有条件)中的唯一值组合到同一行的另一个范围中。 其实我前两天发过类似的问题Link所提供的答案在我提出上述问题时有效。 但后来,我遇到了一个新问题,我宁愿问一个新的问题,让它更清楚: (
我刚开始使用 VBA,并且正在努力处理需要清理的工作表。 我有一列包含混合邮政编码和城市名称的字符串。我想从 A 列中提取邮政编码并放在 B 列中,并在 C 列中提取带有下划线的城市名称。 我的(示例
我是一名优秀的程序员,十分优秀!