找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1604|回复: 5
收起左侧

关于VB的水晶报表程序问题

[复制链接]
ID:278851 发表于 2019-3-11 10:18 | 显示全部楼层 |阅读模式
5黑币
这是一段水晶报表的程序,程序如下
Private Sub Form_Load()
Dim Strsql As String
If Cn.State = adStateOpen Then
Else
    Cn.CursorLocation = adUseClient

    Cn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & App.Path & "\lujingData.mdb;Persist Security Info=False"
End If
Rs.CursorLocation = adUseClient
Strsql = "select DMEA,HKLA From " & Trim$(Text5) & ""调用表的数据
Set Rs = Cn.Execute(Strsql)
Screen.MousePointer = vbHourglass
CRViewer91.ReportSource = CrystalReport6
CrystalReport6.Database.SetDataSource Rs
CrystalReport6.ReadRecords
CRViewer91.ViewReport
Screen.MousePointer = vbDefault
End Sub

运行之后提示from子句语法错误,但是用
Set Rs = Cn.Execute("select DMEA,HKLA From hy18"又是对的,为什么无法用sql语句呢

最佳答案

查看完整内容

问题解决了没有。
回复

使用道具 举报

ID:346616 发表于 2019-3-11 10:18 | 显示全部楼层
问题解决了没有。
回复

使用道具 举报

ID:278851 发表于 2019-3-11 10:51 | 显示全部楼层
网上说修改ADOC的.CommandType = adCmdTable就可以,但是我用的ADODB,不知道该增加什么命令
回复

使用道具 举报

ID:346616 发表于 2019-3-11 14:09 | 显示全部楼层
  1. Strsql = "select DMEA,HKLA From " & chr(32) & "" & trim(text5.text) & "" & chr(32) & ""
复制代码


这里chr(32)是空格的意思,虽然手动空格也可以,不过为了编码清晰,用了chr(32)。
回复

使用道具 举报

ID:346616 发表于 2019-3-11 14:26 | 显示全部楼层
我在板凳写的代码,用到你的程序中,其实后面一个chr(32)可以不加,我给你加上是方便你做sql语句扩展,比如添加排序。
回复

使用道具 举报

ID:278851 发表于 2019-3-14 09:41 | 显示全部楼层

无论如何还是很感谢您的回复。后来我发现是我自己在编程时逻辑出了点问题,已经改正过来了。
回复

使用道具 举报

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

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

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