帮忙

okcat 2004-10-16 07:13:40
窗体上有六个标签,标签分别为数据库中记录的各个字段。标签为控件数组。相对应的还有六个文本框,也是控件数组,分别放查找条件,还有一个命令按钮。点击进行查询。即从图书信息表中查找图书信息.
我是这样想的,查询的时候首先判断六个文本框中是否有查询条件,若有则用AND连接起来。然后再查询显示在网格控件中
我想请教一下,ztj = tz & "="&'"&trim(ty)&"'

ztj = ztj & "and" & tz & "=" & '& " & Trim(ty) & "&'&"
上面这两句条件连接的语句该如何写。
        
       

Private Sub Form_Load()
Set con = New ADODB.Connection
str = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\Documents and Settings\Administrator\桌面\图书管理系统\图书管理系统.mdb;Persist Security Info=False"
con.Open str
Set rs = con.Execute("select * from 图书信息表 ")
End Sub



Private Sub Command1_Click
Dim a As Integer
For i = 0 To 5
If Text1(i) <> "" Then
a = a + 1
If a = 1 Then
tz = Label1(i).Caption      记录字段的名称
ty = Text1(i).Text        字段的值
ztj = tz & "="&'"&trim(ty)&"'   连接起来,字段=值
Else
tz = Label1(i).Caption
ty = Text1(i).Text
ztj = ztj & "and" & tz & "=" & '& " & Trim(ty) & "&'&"
End If
End If
Next i
End Select
q = "select * from 图书信息表 where"
Set rs = con.Execute(q & ztj)
Set mg1.DataSource = rs

...全文
126 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
okcat 2004-10-18
  • 打赏
  • 举报
回复
up
okcat 2004-10-18
  • 打赏
  • 举报
回复
up
xiaoxiaoP 2004-10-18
  • 打赏
  • 举报
回复
Private Sub Command1_Click(Index As Integer)
Select Case Index
Case 0
Dim a As Integer
For i = 0 To 5
If Text1(i) <> "" Then
a = a + 1              
If a = 1 Then
ztj = Label1(i).Caption & "=" & "'" & Text1(i).Text & "'"  


Else
ztj = ztj & "and " & Label1(i).Caption & "=" & "'" & Text1(i).Text &"'"  

End If
End If
Next i

Set rs = con.Execute("select * from 图书信息表 where" & ztj)
End Select
End Sub
okcat 2004-10-17
  • 打赏
  • 举报
回复
不行啊,我改了一下,改为如下。可还是总提示from子句语法错误。头都大了。又是哪里的错啊。好心人邦忙

Private Sub Command1_Click(Index As Integer)
Select Case Index
Case 0
Dim a As Integer
For i = 0 To 5
If Text1(i) <> "" Then
a = a + 1               判断条件个数
If a = 1 Then
ztj = "Label1(i).Caption ='" & Text1(i).Text & "'"   第一个条件不需要“AND”

Else
ztj = ztj & "and " & Label1(i).Caption & "=" & Text1(i).Text  二个或二个以上用AND                                      连接
End If
End If
Next i

Set rs = con.Execute("select * from 图书信息表 where" & ztj)
End Select
End Sub


itcoco 2004-10-16
  • 打赏
  • 举报
回复
dim ss as string
dim sql as string
if len(text1(1))>0 then ss= Label1.caption & text1(1).text
if len(text1(2))>0 and ss<>"" then ss="and" & Label2.caption & text1(2).text
elseif ss=""
ss=Label2.caption & text1(2).text
end if
......
if len(text1(6))>0 and ss<>'' then ss="and " & Label6.caption & text1(6).text

sql="select * from 图书信息表 where" & ss
内容概要:本文介绍了一种基于双层优化的微电网系统规划设计方法,旨在通过Matlab代码实现,解决微电网在规划与运行中的多目标、多层次决策问题。该方法将优化过程分为上下两层:上层通常负责容量配置、设备选址等长期规划决策,下层则聚焦于能量管理、出力调度等短期运行优化,通过迭代交互实现全局最优。文中详细阐述了模型构建、约束条件设定、目标函数设计及求解算法实现流程,并提供了完整的Matlab代码供复现实验,有助于深入理解微电网系统的设计逻辑与优化机制。; 适合人群:具备一定电力系统基础知识和Matlab编程能力,从事新能源、微电网、综合能源系统等领域研究的研究生、科研人员及工程技术人员。; 使用场景及目标:① 学习和掌握双层优化理论在微电网规划设计中的具体应用;② 通过阅读和运行Matlab代码,复现并改进经典优化模型,用于学位论文、科研项目或实际工程方案设计;③ 深入理解微电网中分布式能源、储能与负荷的协同优化调度策略。; 阅读建议:此资源以Matlab代码实现为核心,强调理论与实践的结合。建议读者先理解双层优化的基本思想和数学模型,再结合代码逐行分析,重点关注变量定义、约束条件的代码转化以及主从问题间的迭代逻辑。鼓励在提供的代码基础上进行参数调整、场景扩展或算法改进,以深化学习效果。

1,217

社区成员

发帖
与我相关
我的任务
社区描述
VB 数据库(包含打印,安装,报表)
社区管理员
  • 数据库(包含打印,安装,报表)社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧