Rss & SiteMap
Foxtable(狐表) http://www.foxtable.com
项目连接Access正常,但是连接SQL Server(2005和2008)时,在打开项目就出现错误提示,然后出现登录窗口,登录后,数据载入窗口的ComboBox控件没有数据,项目不能运行,不知道问题在哪里?
开始认为是数据库问题,所以重装SQL Server2005和SQL Server2008r2各一次,数据库安装过程都很正常,没有错误提示。新建库后,利用定向在新建的数据库里建新表,然后再用高速合并将数据导入SQL Server中新建的表中,在外部数据源设置窗口中也能预览到表的内容,按理说,SQL Server应该没有问题,所以将有关文件上传,请各位老师帮助在SQL Server上测试一下,看看问题到底出在哪里?谢谢!!
下载信息 [文件大小: 下载次数: ] | |
![]() |
SQL 语法错误:
SELECT * FROM (SELECT DISTINCT 报表年月 From {日报源表} ORDER BY 报表年月 DESC)
应该改为:
SELECT DISTINCT 报表年月 From {日报源表} ORDER BY 报表年月 DESC
其余类推。
另外遇到这种问题,可以看看以下章节的内容,以便定位错误代码所在的行。
http://www.foxtable.net/help/topics/1485.htm
我用上面的代码发现执行到下面这样代码的时候发生错误:
dmb.ComboList= dt.GetComboListString("报表年月","","报表年月 Desc")
那么肯定是dt出现问题,等于nothing,可能是SQL语句有误,为了验证,将下面的SQL语句复制到SQL执行窗口执行:
SELECT * FROM (SELECT DISTINCT 报表年月 From {日报源表} ORDER BY 报表年月 DESC)
会发现无法执行,至此就找出原因了。
谢谢狐爸老师的指教,已经解决大部分的问题,部分功能已经能够实现,但是,在点击任务栏窗口“按月分析”和“按年分析”两个节点时,出现错误提示(如下图),看上去像SQL语法问题,但是对SQL语法测试也可以通过,不知道问题出在那里?请各位老师帮助看看,谢谢!!
另外,觉得很纳闷,同样是外部资源,为什么用Access全部正常,而在SQL Server上却有问题?
另附代码如下:
Case "按月分析"
Dim sql As String
If _UserGroup = "填报" Then '定义用户组
sql = "Select 报表年月,日期,单位,Sum(加工费) As 加工费,Sum(投工) As 投工 FROM {日报源表} WHERE 单位 = '" & _UserName & "' Group By 报表年月,日期,单位 ORDER BY 单位,日期,报表年月"
Else
sql = "Select 报表年月,日期,单位,Sum(加工费) As 加工费,Sum(投工) As 投工 FROM {日报源表} Group By 报表年月,日期,单位 ORDER BY 单位,日期,报表年月"
End If
Dim b As New GroupTableBuilder("按月分析",sql,"SCGL")
b.Groups.AddDef("日期", DateGroupEnum.Year, "年")
b.Groups.AddDef("日期", "月")
b.Groups.AddDef("单位")
b.Totals.AddDef("加工费")
b.Totals.AddDef("投工",AggregateEnum.Average,"月均人数")
b.SamePeriodGrowth = True
b.CircleGrowth = True
b.Build()
MainTable = Tables("按月分析")
Dim r As Table = Tables("按月分析")
r.DataTable.DataCols.Add("月人均加工费", Gettype(Double),"iif(月均人数=0,null,加工费/月均人数)")
DataTables("按月分析").DataCols("加工费").SetFormat("0.00")
DataTables("按月分析").DataCols("月均人数").SetFormat("0.00")
DataTables("按月分析").DataCols("月人均加工费").SetFormat("0.00")
Tables("按月分析").Cols("年").TextAlign = TextAlignEnum.Center
Tables("按月分析").Cols("月").TextAlign = TextAlignEnum.Center
Tables("按月分析").Cols("单位").TextAlign = TextAlignEnum.Center
Tables("按月分析").AutoSizeCols()
Case "按年分析"
Dim sql As String
If _UserGroup = "填报" Then '定义用户组
sql = "Select 报表年月,日期,单位,Sum(加工费) As 加工费,Sum(投工) As 投工 FROM {日报源表} WHERE 单位 = '" & _UserName & "' Group By 报表年月,日期,单位 ORDER BY 单位,日期,报表年月"
Else
sql = "Select 报表年月,日期,单位,Sum(加工费) As 加工费,Sum(投工) As 投工 FROM {日报源表} Group By 报表年月,日期,单位 ORDER BY 单位,日期,报表年月"
End If
Dim b As New GroupTableBuilder("按年分析",sql,"SCGL")
b.Groups.AddDef("日期", DateGroupEnum.Year, "年")
b.Groups.AddDef("单位")
b.Totals.AddDef("加工费")
b.Totals.AddDef("投工",AggregateEnum.Average,"年均人数")
b.CircleGrowth = True
b.Build()
MainTable = Tables("按年分析")
Dim r As Table = Tables("按年分析")
r.DataTable.DataCols.Add("年人均加工费", Gettype(Double),"iif(年均人数=0,null,加工费/年均人数)")
DataTables("按年分析").DataCols("加工费").SetFormat("0.00")
DataTables("按年分析").DataCols("年均人数").SetFormat("0.00")
DataTables("按年分析").DataCols("年人均加工费").SetFormat("0.00")
Tables("按年分析").Cols("年").TextAlign = TextAlignEnum.Center
Tables("按年分析").Cols("单位").TextAlign = TextAlignEnum.Center
Tables("按年分析").AutoSizeCols()
order by 必须配合top语句使用。
既然没有top语句,请删除order by语句。
Access和SQL Server对于sql的语法要求是不一样的,一个报错,一个不报错,是正常的。
谢谢狐爸老师的指教。考虑到排序要求,在狐爸老师的提示下,在代码中加了top语句,使该段代码在SQL Server2005环境下正常运转,达到预期效果。再次感谢狐爸老师的热情帮助。
sql = "Select TOP 100 PERCENT
报表年月,日期,单位,Sum(加工费) As 加工费,Sum(投工) As 投工 FROM {日报源表} Group By 报表年月,日期,单位 ORDER BY 单位,日期,报表年月"