Heim Datenbank MySQL-Tutorial oracle数据库中由于没有做任何约束,如何删掉表中重复的记录

oracle数据库中由于没有做任何约束,如何删掉表中重复的记录

Jun 07, 2016 pm 05:36 PM
oracle 数据库 记录

oracle数据库中由于没有设置任何约束,里面含有很多的重复项。现在的问题是如何删掉这些重复项,重复的记录只保留其中的一条。如下建表语句CREATETABLEmessage_s

oracle数据库中由于没有设置任何约束,里面含有很多的重复项。现在的问题是如何删掉这些重复项,重复的记录只保留其中的一条。如下建表语句

CREATE TABLE message_student3( stu_id INTEGER NOT NULL, --表中没有唯一性约束 stu_number varchar(30), stu_name VARCHAR(10) NOT NULL, stu_age NUMBER(2) NOT NULL ); INSERT INTO message_student3 VALUES(1,'100320036','张珊',18); INSERT INTO message_student3 VALUES(2,'100320037','刘备',19); INSERT INTO message_student3 VALUES(3,'100320038','张飞',19); INSERT INTO message_student3 VALUES(4,'100320039','吕布',19); INSERT INTO message_student3 VALUES(5,'100320040','周瑜',19); INSERT INTO message_student3 VALUES(6,'100320041','孙权',19); INSERT INTO message_student3 VALUES(7,'100320042','张辽',19); INSERT INTO message_student3 VALUES(1,'100320036','张珊',18); INSERT INTO message_student3 VALUES(2,'100320037','刘备',19); INSERT INTO message_student3 VALUES(3,'100320038','张飞',19); INSERT INTO message_student3 VALUES(4,'100320039','吕布',19); INSERT INTO message_student3 VALUES(5,'100320040','周瑜',19); INSERT INTO message_student3 VALUES(6,'100320041','孙权',19); INSERT INTO message_student3 VALUES(7,'100320042','张辽',19);


分析:由于表没有做约束,所以重复记录的各个字段必然是相等的,然而对于删除操作要么是全部删除要么是根据一个条件删除,前者肯定是不行,后者呢,一删除就重复的都删除了。所以要删掉其中重复项的切入点必须要有一个可以区别不同记录的量。想想在做oracle的分页的时候,用到了rownum,于是想用rownum来试一下。但是每一个新的select语句都有一个新的rownum,用别名就是无法之前的,这么写可能有些含糊,于是在网上找了一些有关这方面的资料,发现其实我应该要用的是rowid。rownum和rowid有什么不同呢?下面是摘抄的内容:原地址是:

rownum和rowid都是伪列,但是两者的根本是不同的,rownum是根据sql查询出的结果给每行分配一个逻辑编号,所以你的sql不同也就会导致最终rownum不同,

但是rowid是物理结构上的,在每条记录insert到数据库中时,都会有一个唯一的物理记录 (不会变),,
例如  AAAMgzAAEAAAAAgAAB 7499 ALLEN SALESMAN 7698 1981/2/20 1600.00 300.00 30
这里的AAAMgzAAEAAAAAgAAB物理位置对应了这条记录,这个记录是不会随着sql的改变而改变。
因此,这就导致了他们的使用场景不同了,通常在sql分页时或是查找某一范围内的记录时,我们会使用rownum。
1、rownum
例如:
查找2到10范围内的记录(这里包括2和10的记录)

select * from (select rownum rn, a.* from emp a) t where t.rn between 2 and 10;


查找前三名的记录
select * from emp a where rownum 例如:

select * from (select rownum rn, a.* from emp a) t where t.rn > 2;


2、rowid
我们在处理一张表中重复记录时经常用到他
因此我们可以根据rowid来处理,rowid具有唯一性,查询时效率是很高的,
回到最开始的问题,要删掉其中重复的使用下面的语句就可了

delete from message_student3 a where rowid > (select min(rowid) from message_student3 b where a.stu_id = b.stu_id); commit;

这样就可以了。

当然你也可以用一个很原始的方法,就是将有重复记录的表中的数据导到另外一张表中,最后再倒回去。

create table stu_tmp as select distinct* from stu; truncate table sut; //清空表记录 insert into stu select * from stu_tmp; //将临时表中的数据添加回原表但是要是stu的表

这种只适合数量级不大的情况下。

本文出自 “菜鸟也想飞” 博客,请务必保留此出处

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

MySQL: Eine Einführung in die beliebteste Datenbank der Welt MySQL: Eine Einführung in die beliebteste Datenbank der Welt Apr 12, 2025 am 12:18 AM

MySQL ist ein Open Source Relational Database Management -System, das hauptsächlich zum schnellen und zuverlässigen Speicher und Abrufen von Daten verwendet wird. Sein Arbeitsprinzip umfasst Kundenanfragen, Abfragebedingungen, Ausführung von Abfragen und Rückgabergebnissen. Beispiele für die Nutzung sind das Erstellen von Tabellen, das Einsetzen und Abfragen von Daten sowie erweiterte Funktionen wie Join -Operationen. Häufige Fehler umfassen SQL -Syntax, Datentypen und Berechtigungen sowie Optimierungsvorschläge umfassen die Verwendung von Indizes, optimierte Abfragen und die Partitionierung von Tabellen.

Warum MySQL verwenden? Vorteile und Vorteile Warum MySQL verwenden? Vorteile und Vorteile Apr 12, 2025 am 12:17 AM

MySQL wird für seine Leistung, Zuverlässigkeit, Benutzerfreundlichkeit und Unterstützung der Gemeinschaft ausgewählt. 1.MYSQL bietet effiziente Datenspeicher- und Abruffunktionen, die mehrere Datentypen und erweiterte Abfragevorgänge unterstützen. 2. Übernehmen Sie die Architektur der Client-Server und mehrere Speichermotoren, um die Transaktion und die Abfrageoptimierung zu unterstützen. 3. Einfach zu bedienend unterstützt eine Vielzahl von Betriebssystemen und Programmiersprachen. V.

So lösen Sie das Problem des Schließens von Oracle Cursor So lösen Sie das Problem des Schließens von Oracle Cursor Apr 11, 2025 pm 10:18 PM

Die Methode zur Lösung des Oracle Cursor Closeure -Problems umfasst: explizit den Cursor mithilfe der Close -Anweisung schließen. Deklarieren Sie den Cursor in der für Aktualisierungsklausel so, dass er nach Beendigung des Umfangs automatisch schließt. Deklarieren Sie den Cursor in der Verwendung der Verwendung so, dass er automatisch schließt, wenn die zugehörige PL/SQL -Variable geschlossen ist. Verwenden Sie die Ausnahmebehandlung, um sicherzustellen, dass der Cursor in jeder Ausnahmesituation geschlossen ist. Verwenden Sie den Verbindungspool, um den Cursor automatisch zu schließen. Deaktivieren Sie die Automatikübermittlung und Verzögerung des Cursors Schließen.

So erstellen Sie Cursor in Oracle Loop So erstellen Sie Cursor in Oracle Loop Apr 12, 2025 am 06:18 AM

In Oracle kann die For -Loop -Schleife Cursors dynamisch erzeugen. Die Schritte sind: 1. Definieren Sie den Cursortyp; 2. Erstellen Sie die Schleife; 3.. Erstellen Sie den Cursor dynamisch; 4. Führen Sie den Cursor aus; 5. Schließen Sie den Cursor. Beispiel: Ein Cursor kann mit dem Zyklus für Kreislauf erstellt werden, um die Namen und Gehälter der Top 10 Mitarbeiter anzuzeigen.

So erstellen Sie Oracle Dynamic SQL So erstellen Sie Oracle Dynamic SQL Apr 12, 2025 am 06:06 AM

SQL -Anweisungen können basierend auf der Laufzeiteingabe erstellt und ausgeführt werden, indem die dynamische SQL von Oracle verwendet wird. Zu den Schritten gehören: Vorbereitung einer leeren Zeichenfolgenvariable zum Speichern von dynamisch generierten SQL -Anweisungen. Verwenden Sie die sofortige Ausführung oder Vorbereitung, um dynamische SQL -Anweisungen zu kompilieren und auszuführen. Verwenden Sie die Bind -Variable, um die Benutzereingabe oder andere dynamische Werte an dynamische SQL zu übergeben. Verwenden Sie sofortige Ausführung oder führen Sie aus, um dynamische SQL -Anweisungen auszuführen.

Was tun, wenn das Orakel nicht geöffnet werden kann Was tun, wenn das Orakel nicht geöffnet werden kann Apr 11, 2025 pm 10:06 PM

Lösungen für Oracle können nicht geöffnet werden, einschließlich: 1. Starten Sie den Datenbankdienst; 2. Starten Sie den Zuhörer; 3.. Hafenkonflikte prüfen; 4. Umgebungsvariablen korrekt einstellen; 5. Stellen Sie sicher, dass die Firewall- oder Antivirus -Software die Verbindung nicht blockiert. 6. Überprüfen Sie, ob der Server geschlossen ist. 7. Verwenden Sie RMAN, um korrupte Dateien wiederherzustellen. 8. Überprüfen Sie, ob der TNS -Dienstname korrekt ist. 9. Netzwerkverbindung prüfen; 10. Oracle Software neu installieren.

So lesen Sie den Oracle AWR -Bericht So lesen Sie den Oracle AWR -Bericht Apr 11, 2025 pm 09:45 PM

Ein AWR -Bericht ist ein Bericht, in dem die Datenbankleistung und Aktivitätsschnappschüsse angezeigt werden. Zu den Interpretationsschritten gehören: Identifizierung des Datums und der Uhrzeit des Aktivitäts -Snapshots. Sehen Sie sich einen Überblick über Aktivitäten und Ressourcenverbrauch an. Analysieren Sie Sitzungsaktivitäten, um Sitzungsarten, Ressourcenverbrauch und Warteeignisse zu finden. Finden Sie potenzielle Leistungsengpässe wie langsame SQL -Aussagen, Ressourcenbeständigkeit und I/A -Probleme. Wartenereignisse anzeigen, identifizieren und beheben Sie sie für die Leistung. Analysieren Sie die Muster für Latch- und Speichernutzung, um Speicherprobleme zu identifizieren, die Leistungsprobleme verursachen.

So verwenden Sie Trigger für Oracle So verwenden Sie Trigger für Oracle Apr 11, 2025 pm 11:57 PM

Auslöser in Oracle sind gespeicherte Prozeduren, die zur automatischen Durchführung von Vorgängen nach einem bestimmten Ereignis verwendet werden (einfügen, aktualisieren oder löschen). Sie werden in einer Vielzahl von Szenarien verwendet, einschließlich Datenüberprüfung, Prüfung und Datenwartung. Beim Erstellen eines Auslösers müssen Sie den Auslösernamen, die Assoziationstabelle, den Auslöserereignis und die Auslöserzeit angeben. Es gibt zwei Arten von Triggern: Der vor dem Operation abgefeuerte Vorher -Auslöser wird abgefeuert, und der Auslöser wird nach dem Betrieb abgefeuert. Zum Beispiel stellt der Voreinsatzauslöser sicher, dass die Altersspalte der eingefügten Zeile nicht negativ ist.

See all articles