| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 372 人关注过本帖, 1 人收藏
标题:所设计的库存程序Combo控件的问题
只看楼主 加入收藏
VB丶小宇
Rank: 3Rank: 3
来 自:河北省石家庄市
等 级:论坛游侠
帖 子:172
专家分:142
注 册:2013-3-11
结帖率:96.77%
收藏(1)
已结贴  问题点数:20 回复次数:4 
所设计的库存程序Combo控件的问题
首先,这是界面
图片附件: 游客没有浏览图片的权限,请 登录注册

这是程序运行时的界面
图片附件: 游客没有浏览图片的权限,请 登录注册

选择Combo控件列表框中的钢材,记录仍指向第一条,而下面的详细内容也没有变,此问题,如何解决?
Combo1代码:
程序代码:
Private Sub cmbField_Click()
Dim i As String
cmbname.Clear
i = Adodc1.RecordSource = "select * form 库存表"
Adodc1.Refresh
Do While Not Adodc1.Recordset.EOF
cmbname.AddItem Adodc1.Recordset.Fields(cmbField.Text)
Adodc1.Recordset.MoveNext
Loop
cmbname.Text = cmbname.List(0)
End Sub
Combo2代码:
程序代码:
Private Sub cmbname_Click()
Dim condition
Dim s As String
condition = Trim(cmbField.Text)
If Adodc1.Recordset.Fields(condition).Type = 202 Then
s = Adodc1.RecordSource = "select * form 库存表 where " & condition & "='" & cmbname.Text & "'"
Else
s = Adodc1.RecordSource = "select * form 库存表 where" & condition & "=" & cmbname.Text
End If
Adodc1.Refresh
txtno.Text = Adodc1.Recordset.Fields("货物编号")
txtname.Text = Adodc1.Recordset.Fields("货物名称")
txtstocknumber.Text = Adodc1.Recordset.Fields("库存量")
txtunit.Text = Adodc1.Recordset.Fields("单位")
End Sub
如何修改?谢谢。
搜索更多相关主题的帖子: Combo1 钢材 记录 如何 
2013-12-24 21:15
vbvcr51
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:18
帖 子:364
专家分:1724
注 册:2013-11-3
收藏
得分:0 
text1.Text = Adodc1.Recordset.Fields("货物编号")
2013-12-27 12:51
VB丶小宇
Rank: 3Rank: 3
来 自:河北省石家庄市
等 级:论坛游侠
帖 子:172
专家分:142
注 册:2013-3-11
收藏
得分:0 
回复 2楼 vbvcr51
抱歉,没明白您的意思。。
是将
txtno.Text = Adodc1.Recordset.Fields("货物编号")
改为
text1.Text = Adodc1.Recordset.Fields("货物编号") 
么?可是我设置货物编号的Caption属性是txtno啊。

编程最蛋疼的事:不是编程多么累,而是编完后,一点运行,出现四个字:程序错误。。。
2013-12-27 20:50
vbvcr51
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:18
帖 子:364
专家分:1724
注 册:2013-11-3
收藏
得分:20 
已经好了。
  问题分析:
adodc1控件的属性recordsouce被设定成了"库存表"(你自己看看,属性栏里),然后在单击事件里试想变成select * form 库存表 where " & condition & "='" & cmbname.Text & "'"按条件找记录。这样是错误的。后者不会起作用的,实际上还是adodc1.recordsource=库存表(集合了全部的记录),text1只能是显示第一条记录相应的字段,即'3'。

  修改:
可以再增加一个adodc2控件,adodc2控件按条件找记录,即adodc2.recordsouce=select * form 库存表 where " & condition & "='" & cmbname.Text & "'",那就可以找到相应的记录了。

[ 本帖最后由 vbvcr51 于 2013-12-27 23:10 编辑 ]
收到的鲜花
  • VB丶小宇2013-12-28 07:59 送鲜花  5朵   附言:好文章!
2013-12-27 23:06
VB丶小宇
Rank: 3Rank: 3
来 自:河北省石家庄市
等 级:论坛游侠
帖 子:172
专家分:142
注 册:2013-3-11
收藏
得分:0 
回复 4楼 vbvcr51
非常非常的感谢您!困扰了我许久的问题!

编程最蛋疼的事:不是编程多么累,而是编完后,一点运行,出现四个字:程序错误。。。
2013-12-28 07:58
快速回复:所设计的库存程序Combo控件的问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.019642 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved