求助:vb调用SQL数据库中的表,将表中数据用mschart画出曲线图(附程序)

icelends 2012-03-18 02:14:35
各位大侠:

本人问题RT,想要做个界面,将数据库中的程序用曲线显示出来,网上找了许多例子,都是ACCESS数据库的,借用了一下,弄了许久都不见曲线,故来求赐教,不胜感激,先谢过各位啦。
我的程序如下:总觉得数据库给mschart赋值未成功,希望各位给予赐教,不胜感激!


Private Sub Command1_Click()
Dim DblSec As Double, MaxSec As Double, MinSec As Double, TempSec As Double
Dim strconn As String ' 定义连接字符串

Dim MyCon As New ADODB.Connection
Dim Rst As New ADODB.Recordset
Dim MyData() As Double
strconn = " Provider=SQLOLEDB.1;Persist Security Info=False;User ID=sa;password =333666;Initial Catalog =node;DataSource= (local)"

MyCon.ConnectionString = strconn: MyCon.Open

Rst.Open "select * from stOdr", MyCon, adOpenKeyset, adLockOptimistic '表的名字为:gytagb,可根据需要来更改

'conn.Open strconn


ReDim MyData(Rst.RecordCount + 1, 1)
MaxSec = 0: MinSec = 0: MinSec = 0
For i = 0 To Rst.RecordCount + 1
MyData(i, 0) = Rst("时间").Value '第一列存放X轴数据
MyData(i, 1) = Rst("温度").Value '第二列存放Y轴数据
TempSec = DateDiff("s", "0:0:0", Rst.Fields("时间").Value)
If i = 0 Then
MaxSec = TempSec: MinSec = TempSec
End If
If TempSec > MaxSec Then MaxSec = TempSec '求最大值
If TempSec < MinSec Then MinSec = TempSec '求最小值
Rst.MoveNext
Next
Rst.Close: MyCon.Close
Set Rst = Nothing: Set MyCon = Nothing
'波形图外观设置
With MSChart1
.chartType = VtChChartType2dXY '设置图形为二维散点图'注意本语句的位置,如果放在最后X轴坐标将显示成小数而非时间格式
.TitleText = "温度"
' '设置图线的外观
.Plot.SeriesCollection(1).Pen.Width = 30
.Plot.SeriesCollection(1).Pen.Style = VtPenStyleSolid
'设置XY轴
.Plot.Axis(VtChAxisIdX).ValueScale.Auto = False
.Plot.Axis(VtChAxisIdY).ValueScale.Auto = False
'// 设置最大值
.Plot.Axis(VtChAxisIdX).ValueScale.Maximum = 40950 '这里根据你的数据库中的最大值设置一合适值
.Plot.Axis(VtChAxisIdY).ValueScale.Maximum = 40 '这里根据你的数据库中的最大值设置一合适值
'// 设置最小值
.Plot.Axis(VtChAxisIdX).ValueScale.Minimum = 40600
.Plot.Axis(VtChAxisIdY).ValueScale.Minimum = -10
'设置X轴标签显示格式
.Plot.Axis(VtChAxisIdX).Labels(1).Format = "yyyy-m-d hh:mm"
.Plot.Axis(VtChAxisIdX).ValueScale.MajorDivision = 12 'X轴主要网格数量
.Plot.Axis(VtChAxisIdY).ValueScale.MajorDivision = 10 'Y轴主要网格数量
.Plot.Axis(VtChAxisIdX).ValueScale.MinorDivision = 0 'X轴次要网格数量
.Plot.Axis(VtChAxisIdY).ValueScale.MinorDivision = 0 'Y轴次要网格数量
.Plot.Axis(VtChAxisIdX).AxisGrid.MajorPen.Style = VtPenStyleDotted
.Plot.Axis(VtChAxisIdY).AxisGrid.MajorPen.Style = VtPenStyleDotted
.Plot.Axis(VtChAxisIdX).Labels(1).VtFont.Size = 7
.Plot.AutoLayout = False
.Plot.UniformAxis = False

.ChartData = MyData '数据
End With
End Sub

唉 贴不上来图!就是运行后没有曲线 其他都有
...全文
379 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
xiao_xiao_1_1 2013-02-21
  • 打赏
  • 举报
回复
现在好了吗,我也出现同样的情况,不知道怎么解决呀
icelends 2012-03-19
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 icelends 的回复:]
引用 1 楼 veron_04 的回复:
http://download.csdn.net/detail/veron_04/1483925
先看看 谢谢~~
[/Quote]看了你的程序,很是感谢,我找到原因了,应该是从SQL数据库读数据到MSChart1时候有问题,不知道您对数据库连接以及读SQL数据库数据到MSCart了解不,我从网上找了好多例子,都没有试验成功。
icelends 2012-03-19
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 veron_04 的回复:]
http://download.csdn.net/detail/veron_04/1483925
[/Quote] 先看看 谢谢~~

1,216

社区成员

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

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