AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Query.sql aber keinen (Schreib)-Zugriff?
Thema durchsuchen
Ansicht
Themen-Optionen

Query.sql aber keinen (Schreib)-Zugriff?

Ein Thema von Taladan · begonnen am 8. Aug 2003 · letzter Beitrag vom 12. Aug 2003
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von Taladan
Taladan

Registriert seit: 5. Aug 2003
Ort: Osnabrück
505 Beiträge
 
Delphi 2005 Professional
 
#1

Query.sql aber keinen (Schreib)-Zugriff?

  Alt 8. Aug 2003, 15:14
hallo. Hab da ein Problem mit meinen Query. Ich weise meinen Query wie folgt während der Laufzeit seinen SQL-String zu. Dies funktioniert auch ohne Probleme.

Delphi-Quellcode:
     query1.sql.clear;
     query1.sql.add('select * from verteilungen where datumderverteilung = '+'"'+combobox1.text+'"');
     query1.sql.add('order by hauptgebiet,nebengebiet');
     query1.active := true;
     query1.RequestLive := true;
     query1.open;
Wenn ich jetzt über ein Query1.delete einen Datensatz lösche, bekomme ich immer folgende Fehlermeldung. "Query1. Eine Datenmenge die nur zum Lesen ist, kann nicht geändert werden." Selbe komme auch bei einen query1.append oder query1.edit. Bei einer anderen Anwendung kann ich über das Query.delete ohne probleme löschen. Warum hier nicht?
Marco
  Mit Zitat antworten Zitat
Benutzerbild von r_kerber
r_kerber

Registriert seit: 11. Feb 2003
Ort: Trittau
3.538 Beiträge
 
Delphi XE Professional
 
#2

Re: Query.sql aber keinen (Schreib)-Zugriff?

  Alt 8. Aug 2003, 15:41
Streiche doch mal die Zeile:
     query1.active := true; raus! Ansonsten solltest Du vielleicht die Änderung von Daten (DELETE, UPDATE, INSERT) über TUpdateSQL durchführen!
  Mit Zitat antworten Zitat
Benutzerbild von MrSpock
MrSpock
(Co-Admin)

Registriert seit: 7. Jun 2002
Ort: Owingen
5.865 Beiträge
 
Delphi 2010 Professional
 
#3

Re: Query.sql aber keinen (Schreib)-Zugriff?

  Alt 8. Aug 2003, 15:42
Hallo Taladan,

mit

Query1.Active := True; wird die Query ja schon ausgeführt. Deshalb ist die anschließende Anweisung "RequestLive := True" hier zu spät. Lösche einmal die Zeile Query1.Active := True;
Albert
Live long and prosper


MrSpock
  Mit Zitat antworten Zitat
Benutzerbild von Taladan
Taladan

Registriert seit: 5. Aug 2003
Ort: Osnabrück
505 Beiträge
 
Delphi 2005 Professional
 
#4

Re: Query.sql aber keinen (Schreib)-Zugriff?

  Alt 8. Aug 2003, 16:09
Ich kann jetzt zwar über query1.delete den datensatz löschen, aber dies ist leider nur im Query der Fall. Nicht der Reelle datensatz. d.h. sobalt ich mir die daten neu anzeigen lasse, sind sie wieder da.
Das query.edit und query.append funktioniert immer noch nicht.
Marco
  Mit Zitat antworten Zitat
Benutzerbild von Taladan
Taladan

Registriert seit: 5. Aug 2003
Ort: Osnabrück
505 Beiträge
 
Delphi 2005 Professional
 
#5

Re: Query.sql aber keinen (Schreib)-Zugriff?

  Alt 8. Aug 2003, 16:14
Ich kann jetzt zwar über query1.delete den datensatz löschen, aber die löschung wird nicht ausgeführt. sie verschwindet zwar im query, aber sobald ich den filter neu setze, sind alle wieder da. query.edit funktioniert immer noch nicht.
Marco
  Mit Zitat antworten Zitat
JoelH
(Gast)

n/a Beiträge
 
#6

Re: Query.sql aber keinen (Schreib)-Zugriff?

  Alt 8. Aug 2003, 16:24
hmm,
mit SELECT kannste nix löschen, dazu musst du
Code:
 DELETE xyz FROM database WHERE lala = 'unfug'
machen.

du speicherst ja auch kein file mit Load oder ?
  Mit Zitat antworten Zitat
Benutzerbild von theomega
theomega

Registriert seit: 18. Jun 2002
684 Beiträge
 
#7

Re: Query.sql aber keinen (Schreib)-Zugriff?

  Alt 8. Aug 2003, 16:48
Also, ihr redet alle um den heißen Brei herum

query1.open verwendest du, wenn dein Query ein Ergebniss zurückliefert (also bei SELECT), query1.execute verwendest du, wenn dein Query kein (!) Ergebniss zurückliefert (DELETE,INSERT)

Also jetzt sollte alles klar sein!
  Mit Zitat antworten Zitat
Benutzerbild von MrSpock
MrSpock
(Co-Admin)

Registriert seit: 7. Jun 2002
Ort: Owingen
5.865 Beiträge
 
Delphi 2010 Professional
 
#8

Re: Query.sql aber keinen (Schreib)-Zugriff?

  Alt 8. Aug 2003, 17:01
Hallo Taladan,

ich hab gerade noch einmal nachgeschaut: eine Query, die eine QRDER BY Klausel enthält ist nicht editierbar! Es gibt zwar auch Ausnahmen, aber grundsätzlich ist die Datenmenge in einem solchen Fall nicht "live", auch wenn RequestLive auf True gesetzt wird.

Du kannst aber eine TUpdateSQL Komponente nutzen, die diese Beschränkung wieder aufhebt.
Albert
Live long and prosper


MrSpock
  Mit Zitat antworten Zitat
Benutzerbild von Taladan
Taladan

Registriert seit: 5. Aug 2003
Ort: Osnabrück
505 Beiträge
 
Delphi 2005 Professional
 
#9

Re: Query.sql aber keinen (Schreib)-Zugriff?

  Alt 8. Aug 2003, 17:02
Juhu. Ich, das mit dem Order By stimmt. Nur wie ordne ich jetzt meine Tabelle?

Edit: Bzw wie benutze ich ein updatesql
Marco
  Mit Zitat antworten Zitat
Benutzerbild von MrSpock
MrSpock
(Co-Admin)

Registriert seit: 7. Jun 2002
Ort: Owingen
5.865 Beiträge
 
Delphi 2010 Professional
 
#10

Re: Query.sql aber keinen (Schreib)-Zugriff?

  Alt 9. Aug 2003, 19:11
Hallo Taladan,

wenn du mit SELECT * FROM ... arbeitest, kannst du in der Regel auch mit einem TTable Objekt arbeiten. Dort kannst du einen (Sekundär)Index erzeugen und diesen auswählen, dann werden die Daten nach dieser Spalte sortiert.

Ein UpdateSQL Objekt funktioniert so: Zunächst ziehst du das Objekt in dein Formular. In deiner Query gibt es eine Eigenschaft UpdateObject, die du auf das neue UpdateSQL Objekt einstellst.

Über das UpdateSQL Objekt teilst du jetzt deiner Query mit, wie Daten der zugrundeliegenden Datenmenge geändert, gelöscht und in diese eingefügt werden. Dazu definierst du einfach die 3 entsprechenden SQL Kommandos und speicherst sie in den Eigenschaften ModifySQL, DeleteSQL und InsertSQL. Schau dir zu diesen 3 Eigenschaften am besten noch einmal die OH an.
Albert
Live long and prosper


MrSpock
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:12 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz