以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.net/bbs/index.asp)
--  专家坐堂  (http://foxtable.net/bbs/list.asp?boardid=2)
----  [求助] 项目连接SQL Server数据库出错(已解决)  (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=11318)

--  作者:yyzlxc
--  发布时间:2011/7/17 20:47:00
--  [求助] 项目连接SQL Server数据库出错(已解决)

项目连接Access正常,但是连接SQL Server(2005和2008)时,在打开项目就出现错误提示,然后出现登录窗口,登录后,数据载入窗口的ComboBox控件没有数据,项目不能运行,不知道问题在哪里?
开始认为是数据库问题,所以重装SQL Server2005和SQL Server2008r2各一次,数据库安装过程都很正常,没有错误提示。新建库后,利用定向在新建的数据库里建新表,然后再用高速合并将数据导入SQL Server中新建的表中,在外部数据源设置窗口中也能预览到表的内容,按理说,SQL Server应该没有问题,所以将有关文件上传,请各位老师帮助在SQL Server上测试一下,看看问题到底出在哪里?谢谢!!

 

 


此主题相关图片如下:a.png
按此在新窗口浏览图片


 

 下载信息  [文件大小:   下载次数: ]
点击浏览该文件:管理项目120.zip

[此贴子已经被作者于2011-7-20 6:50:01编辑过]

--  作者:狐狸爸爸
--  发布时间:2011/7/17 21:14:00
--  

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)

会发现无法执行,至此就找出原因了。

 

 

 

 


--  作者:yyzlxc
--  发布时间:2011/7/19 12:59:00
--  

谢谢狐爸老师的指教,已经解决大部分的问题,部分功能已经能够实现,但是,在点击任务栏窗口“按月分析”和“按年分析”两个节点时,出现错误提示(如下图),看上去像SQL语法问题,但是对SQL语法测试也可以通过,不知道问题出在那里?请各位老师帮助看看,谢谢!!
另外,觉得很纳闷,同样是外部资源,为什么用Access全部正常,而在SQL Server上却有问题?

 

 


图片点击可在新窗口打开查看此主题相关图片如下:a.jpg
图片点击可在新窗口打开查看

另附代码如下:

 

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()


--  作者:狐狸爸爸
--  发布时间:2011/7/19 14:33:00
--  

order by 必须配合top语句使用。

既然没有top语句,请删除order by语句。

Access和SQL Server对于sql的语法要求是不一样的,一个报错,一个不报错,是正常的。


--  作者:yyzlxc
--  发布时间:2011/7/20 6:49:00
--  

谢谢狐爸老师的指教。考虑到排序要求,在狐爸老师的提示下,在代码中加了top语句,使该段代码在SQL Server2005环境下正常运转,达到预期效果。再次感谢狐爸老师的热情帮助。

 

 sql = "Select TOP 100 PERCENT 报表年月,日期,单位,Sum(加工费) As 加工费,Sum(投工) As 投工 FROM {日报源表} Group By 报表年月,日期,单位 ORDER BY 单位,日期,报表年月"