在oracle中怎么查一个表中的的一个字段的重复数据

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在oracle中怎么查一个表中的的一个字段的重复数据相关的知识,希望对你有一定的参考价值。

在线等着呢

select testid,count(1) from testtable group by testid having count(1)>1

count(1)就是重复在数量

如何查询重复的数据

select 字段1,字段2,count(*) from 表名 group by 字段1,字段2 having count(*) > 1

PS:将上面的>号改为=号就可以查询出没有重复的数据了。

Oracle删除重复数据的SQL(删除所有):

删除重复数据的基本结构写法:

想要删除这些重复的数据,可以使用下面语句进行删除

delete from 表名 a where 字段1,字段2 in
(select 字段1,字段2,count(*) from 表名 group by 字段1,字段2 having count(*) > 1)

上面的SQL注意:语句非常简单,就是将查询到的数据删除掉。不过这种删除执行的效率非常低,对于大数据量来说,可能会将数据库吊死。

建议先将查询到的重复的数据插入到一个临时表中,然后对进行删除,这样,执行删除的时候就不用再进行一次查询了。如下:

CREATE TABLE 临时表 AS  (select 字段1,字段2,count(*) from 表名 group by 字段1,字段2 having count(*) > 1)

上面这句话就是建立了临时表,并将查询到的数据插入其中。

下面就可以进行这样的删除操作了:

delete from 表名 a where 字段1,字段2 in (select 字段1,字段2 from 临时表);

参考技术A select testid,count(1) from testtable group by testid having count(1)>1

count(1)就是重复在数量

追问

其实我想要的是这个样子的,就是重复的数量也有,然后假如有个标签号,每个标签号是不同的,查出来的是这样的 标签号 id 数量 这样的重复的数据也显示出来,谢谢

追答select testid,count(1) from testtable group by testid

testid就是你的标签号,count(1)就是id数量,若大於1说明有重复。

本回答被提问者和网友采纳
参考技术B 根据感觉重复的字段分区,加上一个row_number,如果row_number>1,那么就找到了重复的数据了
SELECT * FROM
(
select T.OWNER,T.TABLE_NAME,T.CNT,T.CREATE_TIME
,ROW_NUMBER() OVER(PARTITION BY T.TABLE_NAME ORDER BY T.TABLE_NAME) row_num
from etluser.t99_qa_table_rowcnt t
)T
WHERE T.row_num>1

oracle 数据库 怎么把一个表中的一个字段按规律拆分,并显示出来

oracle 数据库有一个表
ID 名字
1 张三_北京
2 李四_上海
有没有什么函数,可以在数据库把名字那个以-分割 展示出来是
1 张三 北京
就是要求用SQL的,前几天下载资料分用完了。。实在是没有了。。那个大神帮忙出手一下。。谢了

1、首先需要sys或system权限操作

2、查询需要更改表的ID

select object_id  from all_objects where owner = 'ITHOME'
and object_name = 'TEST';1234

注:ITHOME为用户,TEST是要更改的表,表名要大写

3、通过ID查出该表所有字段的顺序

select obj#, col#, name
from sys.col$
where obj# = '103756' order by col#123

4、修改顺序

update sys.col$ set col#=2 where obj#=103756 and name='AGE';update sys.col$ set col#=3 where obj#=103756 and name='NAME';12

或直接在第三步的语句后面加 for update 进行修改

最后commit提交 并且重启Oracle服务

参考技术A oracle 数据库拆分字段的实现方法:
用正则表达式拆分某一个字段,比如有a,b,c,d,e

sql写法如下:
select regexp_substr('a,b,c,d,e,','[^,]+',1,rownum)
from dual connect by rownum<=length(regexp_replace('a,b,c,', '[^,]', null))
结果:
执行结果如下:
1 a
2 b
3 c
4 d
5 e
参考技术B select id,replace(name ,'_',' ') from 表名 参考技术C select id,substr(name,1,instr(name,'_')-1) as 名字,substr(name,instr(name,'_')+1) as 地名 from tableName 参考技术D select id,substr(name,1,instr(name,'_')-1),substr(name,instr(name,'_')+1) from tableName本回答被提问者采纳

以上是关于在oracle中怎么查一个表中的的一个字段的重复数据的主要内容,如果未能解决你的问题,请参考以下文章

oracle中V$session 表中各个字段的中文说明是啥?

oracle查询重复数据方法

oracle 数据库 怎么把一个表中的一个字段按规律拆分,并显示出来

用oracle如何查询出一个表中的一个字段内容包含另一个表中的某个字段的值呢

怎么查看数据库表中某个字段的值都有哪些重复记录

如何根据oracle中另一个表中的值更新一个表中的字段[重复]