请大侠帮我改一句代码

hz03zhuhaowen 2008-12-09 04:19:06
我的程序

Private Sub m_ListInterface_MenuBarInitialize(ByVal oMenuBar As K3ClassEvents.MenuBar)
Dim rs As New ADODB.Recordset
Dim i As Integer
Dim FItemID() As Long
Set rs = m_ListInterface.K3Lib.GetData("Select FUserID From t_User Where FName IN (Select FName From t_Emp Where FDepartmentID In (Select FDepartmentID From t_Emp Where FItemID = ( " & _
" Select t1.FItemID From t_Emp t1 Join t_user t2 On t1.FName=t2.FName Where t2.FUserID = 16409)))")
ReDim FItemID(rs.RecordCount) As Long
For i = 1 To rs.RecordCount
FItemID(i - 1) = rs.Fields("FUserID")
FItemID = rs.Fields("FUserID")
' m_ListInterface.ListFilterString = (" t_BOS220000001.FBiller In ( '" & FItemID(i - 1) & "' )")
rs.MoveNext
Next
End Sub

SQL语句的结果为
FUserID
-------
16396
16422
16395
16428
16409

(所影响的行数为 5 行)
请帮我把以上程序中注释语句改成这样的形式
t_BOS220000001.FBiller In (16396,16422,16395,16428,16409)
代码应该怎么写?
...全文
62 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
hz03zhuhaowen 2008-12-10
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 feiyun0112 的回复:]
dim str
For i = 1 To rs.RecordCount
FItemID(i - 1) = rs.Fields("FUserID")
FItemID = rs.Fields("FUserID")
if str="" then
str=rs.Fields("FUserID")
else
str=str & rs.Fields("FUserID") &","
endif
rs.MoveNext
Next

m_ListInterface.ListFilterString = (" t_BOS220000001.FBiller In ( '" & str & "' )")



*****************************************…
[/Quote]
修改后的正确代码如下:

Private Sub m_ListInterface_MenuBarInitialize(ByVal oMenuBar As K3ClassEvents.MenuBar)
Dim rs As New ADODB.Recordset
Dim i As Integer
Dim FItemID() As Long
Dim str As String

'TODO: ÇëÔÚ´Ë´¦Ìí¼Ó´úÂëÏìӦʼþ MenuBarInitialize
Set rs = m_ListInterface.K3Lib.GetData("Select FUserID From t_User Where FName IN (Select FName From t_Emp Where FDepartmentID In (Select FDepartmentID From t_Emp Where FItemID = ( " & _
" Select t1.FItemID From t_Emp t1 Join t_user t2 On t1.FName=t2.FName Where t2.FUserID = '" & m_ListInterface.K3Lib.User.UserID & "')))")
ReDim FItemID(rs.RecordCount) As Long

For i = 1 To rs.RecordCount
FItemID(i - 1) = rs.Fields("FUserID")
If str = "" Then
str = rs.Fields("FUserID")
Else
str = str & "," & rs.Fields("FUserID")
End If
rs.MoveNext
Next
m_ListInterface.ListFilterString = (" t_BOS220000001.FBiller In ( " & str & " )")
End Sub
clear_zero 2008-12-09
  • 打赏
  • 举报
回复
1639616422 这个对于int太大了

定义long
hz03zhuhaowen 2008-12-09
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 feiyun0112 的回复:]
dim str
For i = 1 To rs.RecordCount
FItemID(i - 1) = rs.Fields("FUserID")
' FItemID = rs.Fields("FUserID")
if str="" then
str=rs.Fields("FUserID")
else
str=str & rs.Fields("FUserID") &","
endif
rs.MoveNext
Next

m_ListInterface.ListFilterString = (" t_BOS220000001.FBiller In ( '" & str & "' )")



*****************************************…
[/Quote]
调试后有错误:
将varchar值'1639616422,16395,16428,16409,'转换为数据类型为int的列时发生语法错误

hz03zhuhaowen 2008-12-09
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 feiyun0112 的回复:]
dim str
For i = 1 To rs.RecordCount
FItemID(i - 1) = rs.Fields("FUserID")
' FItemID = rs.Fields("FUserID")
if str="" then
str=rs.Fields("FUserID")
else
str=str & rs.Fields("FUserID") &","
endif
rs.MoveNext
Next

m_ListInterface.ListFilterString = (" t_BOS220000001.FBiller In ( '" & str & "' )")



*****************************************…
[/Quote]
明白
hz03zhuhaowen 2008-12-09
  • 打赏
  • 举报
回复
不明白
yaomin65 2008-12-09
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 feiyun0112 的回复:]
dim str
For i = 1 To rs.RecordCount
FItemID(i - 1) = rs.Fields("FUserID")
FItemID = rs.Fields("FUserID")
if str="" then
str=rs.Fields("FUserID")
else
str=str & rs.Fields("FUserID") &","
endif
rs.MoveNext
Next

m_ListInterface.ListFilterString = (" t_BOS220000001.FBiller In ( '" & str & "' )")

[/Quote]
帮顶
feiyun0112 2008-12-09
  • 打赏
  • 举报
回复
dim str
For i = 1 To rs.RecordCount
FItemID(i - 1) = rs.Fields("FUserID")
FItemID = rs.Fields("FUserID")
if str="" then
str=rs.Fields("FUserID")
else
str=str & rs.Fields("FUserID") &","
endif
rs.MoveNext
Next

m_ListInterface.ListFilterString = (" t_BOS220000001.FBiller In ( '" & str & "' )")



*****************************************************************************
欢迎使用CSDN论坛专用阅读器 : CSDN Reader(附全部源代码)
http://feiyun0112.cnblogs.com/
整合FileDisk和Filemon的MFC开源码,希望对新手有助! 说明:对大侠们可能没什么价值,仅以此献给像我一样的菜鸟! 软件环境和框架: 1.软件环境:VS.net2003 + XP IFS + DS3.2 2.框架:采用MFC框架; 功能: 1.自动加载FileDisk和Filemon的驱动程序部分; 2.用FileDisk生成一个虚拟硬盘,并自动分配盘符; 3.对新生成的虚拟盘符挂接Filemon的过滤驱动; 4.退出时自动卸载FileDisk和Filemon驱动; 不完善的地方(有兴趣的朋友可以完善下,并希望完善后在我这里跟帖上传源码,就算是对我开源的支持,谢谢!): 1.FileDisk生成的虚拟硬盘需要先手动在资源管理器里进行格式化;可以在程序里调用SHFormat之类的启动格式化窗口进行善,也可以使用第三方提供的格式化函数进行格式化; 2.Filemon目前是应用程序使用按照时间来进行查询的过滤方式,希望能成驱动程序主动通知应用程序。 ------- 整理后面的回贴后追加的内容 ---------------- 1.在BOOL CMainFrame::Init(void)函数里有段网络通讯的代码,里面访问了我自己建的局域网服务器,大家那里应该是没有的,所以会报错,不好意思!注释或删掉以下内容就好了! CWebWrapper clsWebWrapper; CHttpDataPackage_Receive HttpData_Receive; //Call server function if (clsWebWrapper.PostCommand( _T(""), _T("abcd我你他"), &HttpData_Receive, _T("WebGrab"), this, FALSE, FALSE)) //if (clsWebWrapper.GetCommand( _T(""), _T("abcd我你他"), &HttpData_Receive, // _T("WebGrab"), this, FALSE, FALSE)) { AfxMessageBox(HttpData_Receive.GetContent_DataAll()); } else { AfxMessageBox("网络通讯失败"); return FALSE; } 2.大家如果想看文件过滤出来的信息,可以在BOOL CMainFrame::Init(void)函数里去掉对这句话//m_nTimer = SetTimer( 1, 500/*ms*/, NULL );的注释,那就相当于启动了定时器,然后会有信息显示在子窗口里,,当然我并没有去实现子窗口的滚动,所以子窗口里的内容满了后,就看不到最新的信息了,,哈哈,,我实在是没时间啊,,公司里的项目这2天在出演示版呢,,,忙啊。。。。大家自己加加代码哈,,,这也是个不完善的地方,希望完善了的朋友,,上传下代码啊,,,多谢! 3.另外,下载使用了的朋友,有空的话来忙说下使用上有没有问题啊,如果有问题,我好及时做修啊,谢谢了!如果可以用的话,有空就忙回个贴,说可以用,这样别的朋友就知道这个代码是可以用的,免得大家还以为下了个不能用的东东,那不是郁闷死了!先谢谢了! ------------- 最新补充说明 ------------------- 1.FileDisk和Filemon我用的都是比较老的版本了,FileDisk是2004年的,Filemon是4.34 ;FileDisk的作者在其网站上已经出了新版本了,是2006年的,我下载了,还没时间看过,所以大家有空也可以整合2006的驱动来替换我的老版本,毕竟老版本是可能有些不完善的地方的;而Filemon则没有再继续开放源码,,所以如果有朋友有幸获得了新版本的源码,能不能上传个,,多谢了! 2.Filemon.exe会自动在其目录下创建File.img文件做为虚拟磁盘使用的文件,大家只要手动格式化一次创建出来的虚拟磁盘,以后就不用再格式化,可以不断使用了,所以以后大家要是做成产品的话,可以直接把已经格式化好的对应的File.img文件一起打包到安装包里,呵呵! 3.我放弃了FileDisk中对CDROM部分的支持,以及Filemon中对Win9x的VxD驱动的支持,如果有朋友需要的话,可以自行添加!
JAVA相关基础知识 1、面向对象的特征有哪些方面 1.抽象: 抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面。抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节。抽象包括两个方面,一是过程抽象,二是数据抽象。 2.继承: 继承是一种联结类的层次模型,并且允许和鼓励类的重用,它提供了一种明确表述共性的方法。对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类继承了原始类的特性,新类称为原始类的派生类(子类),而原始类称为新类的基类(父类)。派生类可以从它的基类那里继承方法和实例变量,并且类可以修或增加新的方法使之更适合特殊的需要。 3.封装: 封装是把过程和数据包围起来,对数据的访问只能通过已定义的界面。面向对象计算始于这个基本概念,即现实世界可以被描绘成一系列完全自治、封装的对象,这些对象通过一个受保护的接口访问其他对象。 4. 多态性: 多态性是指允许不同类的对象对同一消息作出响应。多态性包括参数化多态性和包含多态性。多态性语言具有灵活、抽象、行为共享、代码共享的优势,很好的解决了应用程序函数同名问题。 2、String是最基本的数据类型吗? 基本数据类型包括byte、int、char、long、float、double、boolean和short。 java.lang.String类是final类型的,因此不可以继承这个类、不能修这个类。为了提高效率节省空间,我们应该用StringBuffer类 3、int 和 Integer 有什么区别 Java 提供两种不同的类型:引用类型和原始类型(或内置类型)。Int是java的原始数据类型,Integer是java为int提供的封装类。Java为每个原始类型提供了封装类。 原始类型封装类 booleanBoolean charCharacter byteByte shortShort intInteger longLong floatFloat doubleDouble 引用类型和原始类型的行为完全不同,并且它们具有不同的语义。引用类型和原始类型具有不同的特征和用法,它们包括:大小和速度问题,这种类型以哪种类型的数据结构存储,当引用类型和原始类型用作某个类的实例数据时所指定的缺省值。对象引用实例变量的缺省值为 null,而原始类型实例变量的缺省值与它们的类型有关。 4、String 和StringBuffer的区别 JAVA平台提供了两个类:String和StringBuffer,它们可以储存和操作字符串,即包含多个字符的字符数据。这个String类提供了数值不可变的字符串。而这个StringBuffer类提供的字符串进行修。当你知道字符数据要变的时候你就可以使用StringBuffer。典型地,你可以使用StringBuffers来动态构造字符数据。 5、运行时异常与一般异常有何异同? 异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机的通常操作中可能遇到的异常,是一种常见运行错误。java编译器要求方法必须声明抛出可能发生的非运行时异常,但是并不要求必须声明抛出未被捕获的运行时异常。 6、说出Servlet的生命周期,并说出Servlet和CGI的区别。 Servlet被服务器实例化后,容器运行其init方法,求到达时运行其service方法,service方法自动派遣运行与求对应的doXXX方法(doGet,doPost)等,当服务器决定将实例销毁的时候调用其destroy方法。 与cgi的区别在于servlet处于服务器进程中,它通过多线程方式运行其service方法,一个实例可以服务于多个求,并且其实例一般不会销毁,而CGI对每个求都产生新的进程,服务完成后就销毁,所以效率上低于servlet。 7、说出ArrayList,Vector, LinkedList的存储性能和特性 ArrayList和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安全),通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。 8、EJB是基于哪些技术实现的?并说出SessionBean和EntityBean的区别,StatefulBean和StatelessBean的区别。 EJB包括Session Bean、Entity Bean、Message Driven Bea

7,762

社区成员

发帖
与我相关
我的任务
社区描述
VB 基础类
社区管理员
  • VB基础类社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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