DELPHI盒子
!实时搜索: 盒子论坛 | 注册用户 | 修改信息 | 退出
检举帖 | 全文检索 | 关闭广告 | 捐赠
技术论坛
 用户名
 密  码
自动登陆(30天有效)
忘了密码
≡技术区≡
DELPHI技术
lazarus/fpc/Free Pascal
移动应用开发
Web应用开发
数据库专区
报表专区
网络通讯
开源项目
论坛精华贴
≡发布区≡
发布代码
发布控件
文档资料
经典工具
≡事务区≡
网站意见
盒子之家
招聘应聘
信息交换
论坛信息
最新加入: snarv
今日帖子: 12
在线用户: 9
导航: 论坛 -> DELPHI技术 斑竹:liumazi,sephil  
作者:
男 over (over) ★☆☆☆☆ -
普通会员
2003/12/28 11:23:52
标题:
请问怎样用SQL取出一个字段中不重复的值啊?? 浏览:1318
加入我的收藏
楼主: 请问怎样用SQL取出一个字段中不重复的值啊??
请高手帮忙!
----------------------------------------------
-
作者:
男 zsredmoon (=^@^=) ★☆☆☆☆ -
盒子活跃会员
2003/12/28 11:31:52
1楼: sql server 帮助内容

使用 DISTINCT 消除重复项
DISTINCT 关键字可从 SELECT 语句的结果中除去重复的行。如果没有指定 DISTINCT,那么将返回所有行,包括重复的行。例如,如果在 titleauthor 中选择所有作者 ID 时未使用 DISTINCT,那么将会返回下列行(其中包括一些重复的行):

USE pubs
SELECT au_id
FROM titleauthor

下面是结果集:

au_id       
----------- 
172-32-1176 
213-46-8915 
213-46-8915 
238-95-7766 
267-41-2394 
267-41-2394 
274-80-9391 
409-56-7008 
427-17-2319 
472-27-2349 
486-29-1786 
486-29-1786 
648-92-1872 
672-71-3249 
712-45-1867 
722-51-5454 
724-80-9391 
724-80-9391 
756-30-7391 
807-91-6654 
846-92-7186 
899-46-2035 
899-46-2035 
998-72-3567 
998-72-3567 

(25 row(s) affected)

而使用了 DISTINCT 后,就能够除去重复项,而只查看唯一的作者 ID:

USE pubs
SELECT DISTINCT au_id
FROM titleauthor

下面是结果集:

au_id       
----------- 
172-32-1176 
213-46-8915 
238-95-7766 
267-41-2394 
274-80-9391 
409-56-7008 
427-17-2319 
472-27-2349 
486-29-1786 
648-92-1872 
672-71-3249 
712-45-1867 
722-51-5454 
724-80-9391 
756-30-7391 
807-91-6654 
846-92-7186 
899-46-2035 
998-72-3567 

(19 row(s) affected)

----------------------------------------------
按此在新窗口浏览图片
=^@^=
作者:
男 over (over) ★☆☆☆☆ -
普通会员
2003/12/28 12:06:37
2楼: 谢谢1楼
学习中!
----------------------------------------------
-
作者:
男 over (over) ★☆☆☆☆ -
普通会员
2003/12/28 12:08:13
3楼: 但如果我只要字段中前几个字符不重复呢怎么实现啊?

----------------------------------------------
-
作者:
男 zsredmoon (=^@^=) ★☆☆☆☆ -
盒子活跃会员
2003/12/28 12:24:06
4楼: DISTINCT 后边继续加嘛:)
----------------------------------------------
按此在新窗口浏览图片
=^@^=
作者:
男 over (over) ★☆☆☆☆ -
普通会员
2003/12/28 12:30:10
5楼: au_id          au_id
010609         0106
010601  变成   0107
010702
010706
只要前面4个字符不重复啊,怎么才能实现啊??

----------------------------------------------
-
作者:
男 zsredmoon (=^@^=) ★☆☆☆☆ -
盒子活跃会员
2003/12/28 18:16:16
6楼: select DISTINCT left(au_id,4) from 表名
----------------------------------------------
按此在新窗口浏览图片
=^@^=
作者:
男 over (over) ★☆☆☆☆ -
普通会员
2003/12/28 21:16:14
7楼: 谢谢!
学习中!
----------------------------------------------
-
作者:
男 bios (阿贡) ★☆☆☆☆ -
盒子中级会员
2003/12/28 21:20:13
8楼: 按此在新窗口浏览图片
----------------------------------------------
按此在新窗口浏览图片
按此在新窗口浏览图片
信息
登陆以后才能回复
Copyright © 2CCC.Com 盒子论坛 v3.0.1 版权所有 页面执行62.5毫秒 RSS