Heim > Datenbank > MySQL-Tutorial > Warum erhalte ich beim Abfragen meiner Oracle-Tabelle ORA-00904: „Ungültiger Bezeichner'?

Warum erhalte ich beim Abfragen meiner Oracle-Tabelle ORA-00904: „Ungültiger Bezeichner'?

Susan Sarandon
Freigeben: 2024-12-23 13:06:12
Original
189 Leute haben es durchsucht

Why Am I Getting ORA-00904:

ORA-00904-Fehler: Ungültiger Bezeichner

Problem:

Beim Versuch, Daten abzurufen Aus einer Tabelle mithilfe einer einfachen Abfrage, bei der die WHERE-Klausel eine Bedingung für einen Spaltenwert enthält, stoßen Sie auf ORA-00904 Fehler, der auf eine ungültige Kennung hinweist.

Zum Beispiel haben Sie eine Tabelle namens reg1 mit den folgenden Spalten erstellt:

create table reg1 (
  fname varchar2(30),
  lname varchar2(30),
  addr varchar2(30),
  mail varchar2(30),
  occu varchar2(30),
  uname varchar2(30),
  passwd varchar2(30)
);
Nach dem Login kopieren

Beim Ausführen einer Abfrage zum Abrufen des Vornamens (fname) und Nachname (lname) eines Benutzers mit dem Benutzernamen „bbb“ wie:

select fname, lname
  from reg1
 where uname="bbb";
Nach dem Login kopieren

Sie erhalten die Fehlermeldung ORA-00904: „bbb“: ungültiger Bezeichner.

Antwort:

Der Fehler tritt auf, weil der Wert, mit dem Sie in der WHERE-Klausel vergleichen, nicht in einfache Anführungszeichen gesetzt ist. Wenn Sie in Oracle Zeichenfolgenwerte vergleichen, müssen Sie diese in einfache Anführungszeichen setzen, um anzuzeigen, dass es sich um Literale handelt.

Um das Problem zu beheben, fügen Sie einfach einfache Anführungszeichen um den Wert „bbb“ ein:

select fname, lname
  from reg1
 where uname='bbb';
Nach dem Login kopieren

Mit dieser Korrektur ruft die Abfrage erfolgreich die Daten für den Benutzer mit dem Benutzernamen „bbb“ ab, da der Vergleich nun korrekt als Literal-String-Vergleich behandelt wird.

Das obige ist der detaillierte Inhalt vonWarum erhalte ich beim Abfragen meiner Oracle-Tabelle ORA-00904: „Ungültiger Bezeichner'?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage