http://www.sufeinet.com/plugin.php?id=keke_group

苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper爬虫框架(V2.7-含.netcore) HttpHelper官方出品,爬虫框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 开源的爬虫类,支持多种模式和属性 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 5568|回复: 5

[其他] 求教.如何用Select语句筛选datatable中某一字段的不重复记录?

[复制链接]
发表于 2015-1-20 22:28:26 | 显示全部楼层 |阅读模式
1金钱
本帖最后由 nmcfab 于 2015-1-20 22:30 编辑

假定一个表(table1)结构如下
列1 列2 列3
1     a1   b1
2     a2   b2
3     a2   b3
4     a3   b4

现在想select出 列2 中不重复的所有值
Sql Select 中有如下的语句
Select distince 列2 from table1

但在C#中该效果如何实现呢?

[C#] 纯文本查看 复制代码
private void button2_Click(object sender, EventArgs e)
        {
            //根据指定的列数,从da表里取出该列的不重复值到临时表
            string conString = this.txtFileName.Text;
            string strSource = @"Provider =Microsoft.ACE.OLEDB.12.0;" + "data source=" + conString + ";Extended Properties='Excel 8.0; HDR=NO; IMEX=1'";
            OleDbConnection conn = new OleDbConnection(strSource);
            var myCell = "F" + this.textBox1.Text;
            string sqlString = @"Select " + myCell + "   from[Sheet1$]";
            OleDbDataAdapter adapter = new OleDbDataAdapter(sqlString, conn);
            DataSet da = new DataSet();
            adapter.Fill(da);
            this.dataGridView2.DataSource = da.Tables[0];
                        
        }

无 distince 关键字时,select语句可以执行,全选myCell列全部记录,
但如果加上
报错如图
捕获.JPG



1. 开通SVIP会员,免费下载本站所有源码,不限次数据,不限时间
2. 加官方QQ群,加官方微信群获取更多资源和帮助
3. 找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
 楼主| 发表于 2015-1-20 23:38:35 | 显示全部楼层
本帖最后由 nmcfab 于 2015-1-20 23:43 编辑

[C#] 纯文本查看 复制代码
private void button2_Click(object sender, EventArgs e)
        {
            //根据指定的列数,从da表里取出该列的不重复值到临时表
            string conString = this.txtFileName.Text;
            string strSource = @"Provider =Microsoft.ACE.OLEDB.12.0;" + "data source=" + conString + ";Extended Properties='Excel 8.0; HDR=NO; IMEX=1'";
            OleDbConnection conn = new OleDbConnection(strSource);
            var myCell = "F" + this.textBox1.Text;
            string sqlString = @"Select " + myCell + "   from[Sheet1$]";
            OleDbDataAdapter adapter = new OleDbDataAdapter(sqlString, conn);
            DataSet da = new DataSet();
            adapter.Fill(da);
            DataView myView = da.Tables[0].DefaultView;
            DataTable myTable = myView.ToTable(true, myCell); //其中ToTable()的第一个参数为是否DISTINCT

            this.dataGridView2.DataSource = myTable;
                        
        }
解决了,mark下
回复

使用道具 举报

 楼主| 发表于 2015-1-20 23:40:07 | 显示全部楼层
求删除...论坛还有点不会玩.
回复

使用道具 举报

发表于 2015-1-21 08:26:49 | 显示全部楼层
删除干什么,这么好的帖子,帖子是不允许删除的。记录了之前方便你看,也方便后人查阅多好的事情
回复

使用道具 举报

发表于 2015-1-21 10:13:13 | 显示全部楼层
留个脚印表示我来过!
回复

使用道具 举报

发表于 2015-1-21 19:40:26 | 显示全部楼层
在下才疏学浅没看懂!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备18043678号-2)

GMT+8, 2024-5-10 20:23

© 2014-2021

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