经多次测试,发现Datatable的SQLGetValues方法在MSSQL环境中存在Bug,具体测试过程如下:1.创建MSSQL类型的数据表Orders,其中custid列为文本类型,共有4个无重复的值,样式如下
data:image/s3,"s3://crabby-images/775e5/775e5e89d7c2b718cbd26c5b909472eb1a9758e5" alt="dvubb"
此主题相关图片如下:a.png
data:image/s3,"s3://crabby-images/97ec5/97ec5410f58cefb0285c170983408ec853ad7542" alt="dvubb 按此在新窗口浏览图片"
2.获取custid列无重复的内容集合,并按照custid列内容排序:Dim dt As DataTable = DataTables("Orders")
Dim lst As List(of String) = dt.SQLGetValues("custid","custid Is Not Null","custid")
Output.Show(lst.Count)
执行结果为0
data:image/s3,"s3://crabby-images/775e5/775e5e89d7c2b718cbd26c5b909472eb1a9758e5" alt="dvubb"
此主题相关图片如下:b.png
data:image/s3,"s3://crabby-images/5680b/5680be126c442acc874aedb5d58b47f795fcc68c" alt="dvubb 按此在新窗口浏览图片"
3.获取custid列无重复的内容集合,不使用排序参数:
Dim dt As DataTable = DataTables("Orders")
Dim lst As List(of String) = dt.SQLGetValues("custid","custid Is Not Null")
Output.Show(lst.Count)
执行结果为4
data:image/s3,"s3://crabby-images/775e5/775e5e89d7c2b718cbd26c5b909472eb1a9758e5" alt="dvubb"
此主题相关图片如下:c.png
data:image/s3,"s3://crabby-images/99589/995898d20f524ca44801d3c4b409f63cb44c24a3" alt="dvubb 按此在新窗口浏览图片"
结论:SQLGetValues在MSSQL环境中使用第三个参数与第一个参数相同时,会得出错误结果。
备注:Access数据源测试未发现此Bug