WICHTIG: Der Betrieb von goMatlab.de wird privat finanziert fortgesetzt. - Mehr Infos...

Mein MATLAB Forum - goMatlab.de

Mein MATLAB Forum

 
Gast > Registrieren       Autologin?   

Partner:




Forum
      Option
[Erweitert]
  • Diese Seite per Mail weiterempfehlen
     


Gehe zu:  
Neues Thema eröffnen Neue Antwort erstellen

Database Toolbox: 2 Variablen in einem sql-query

 

maxtob
Forum-Anfänger

Forum-Anfänger


Beiträge: 13
Anmeldedatum: 13.06.09
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 10.07.2009, 11:26     Titel: Database Toolbox: 2 Variablen in einem sql-query
  Antworten mit Zitat      
Hallo,
ich versuche gerade mit Hilfe der Database Toolbox Daten in Matlab einzulesen, wobei im sql-query bei der WHERE-Abfrage zwei variablen auftauchen. Die Abfrage steht innerhalb zwei Schleifen (i,j):

Code:
cursorB = exec(connA, ['SELECT * FROM TestSet WHERE Pt_Id =' num2str(Patient_data{i,1}) 'AND Comments ='  Memos(j,1)]);


Die Abfrage gelingt allein mit der ersten WHERE-Abfrage (WHERE Pt_Id =' num2str(Patient_data{i,1}) problemlos. Aber mit der zweiten WHERE-Abfrage funktioniert das ganze nicht mehr. Dabei ist Memos ein cell-array mit lauter strings in der ersten Spalte.

Weiß jemand wie ich die beiden Abfragen korrekt einbauen kann?

Danke,
mfg Max
Private Nachricht senden Benutzer-Profile anzeigen


Titus
Forum-Meister

Forum-Meister


Beiträge: 871
Anmeldedatum: 19.07.07
Wohnort: Aachen
Version: ---
     Beitrag Verfasst am: 10.07.2009, 12:22     Titel:
  Antworten mit Zitat      
Hallo,

bin mir nicht sicher, wo der Fehler steck. Allerdings würde ich Memos auch auf das Cell-Element zugreifen, d.h.,
Code:
Memos{j,1}
(geschweifte Klammern). Wie gesagt, ob das hilft habe ich keine Ahnung Wink.

Titus
Private Nachricht senden Benutzer-Profile anzeigen
 
Dagnabit
Forum-Century

Forum-Century


Beiträge: 244
Anmeldedatum: 23.04.09
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 10.07.2009, 14:41     Titel:
  Antworten mit Zitat      
Servus maxtob

Titus hat mit seinem Beitrag den ersten Fehler aufgedeckt.

Mir fallen aber noch zwei weitere Dinge auf:

1. Wenn Du einen string mit eckigen Klammern zusammenfügst, werden Leerzeichen ignoriert.
Code:
['SELECT * FROM TestSet WHERE Pt_Id =' num2str(Patient_data{i,1})]

ergibt
Zitat:
SELECT * FROM TestSet WHERE Pt_Id =1


Wenn Du hingegen ein Leerzeichen innerhalb eines Teilstrings einfügst, bekommst Du auch ein Leerzeichen im Gesamtstring:
Code:
['SELECT * FROM TestSet WHERE Pt_Id = ' num2str(Patient_data{i,1})]

ergibt
Zitat:
SELECT * FROM TestSet WHERE Pt_Id = 1



2. Die zweite Sache bezieht sich auf die Übergabe verschiedener Datentypen.
Wenn Du z.B. "WHERE Pt_Id = 1" angibst, sendest Du dem SQLServer eine Zahl.
Mit "AND Comments ='String1'" übergibst Du aber einen String, und Strings müssen (zumindest beim Microsoft SQLServer) unter Anführungsstrichen stehen.
Das Problem mit dem Zeichen " ' " ist, dass es ein von Matlab reserviertes Zeichen ist (z.B. zum Kennzeichnen eines Strings). Um nun ein " ' " in Deinen String zu bringen, musst Du mehrere " ' " eingeben:
Code:
['SELECT * FROM TestSet WHERE Pt_Id = ' num2str(Patient_data{i,1}) ' AND Comments = '''  Memos{j,1} '''']


ergibt
Zitat:
SELECT * FROM TestSet WHERE Pt_Id = 1 AND Comments = 'String1'


Ich denke so sollte Deine Abfrage dann funktionieren.



Edit: Memos{j,1} wird in obigen Code nicht richtig dargestellt (es dürfte nicht violett sein!!)
_________________

lg
Martin

Zuletzt bearbeitet von Dagnabit am 10.07.2009, 14:45, insgesamt einmal bearbeitet
Private Nachricht senden Benutzer-Profile anzeigen
 
maxtob
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 13
Anmeldedatum: 13.06.09
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 10.07.2009, 14:44     Titel:
  Antworten mit Zitat      
Danke für den Tipp,

bin mittlerweile selbst drauf gekommen wies funktioniert:

Code:
   cursorB = exec(connA, ['SELECT Velocity, NormVelocity, Cadence, Swing_Time_L, Swing_Time_R FROM TestSet WHERE Pt_Id = ' num2str(Patient_data{i,1}) ' AND Comments=''' Memos{j,1} '''']);
Private Nachricht senden Benutzer-Profile anzeigen
 
Neues Thema eröffnen Neue Antwort erstellen



Einstellungen und Berechtigungen
Beiträge der letzten Zeit anzeigen:

Du kannst Beiträge in dieses Forum schreiben.
Du kannst auf Beiträge in diesem Forum antworten.
Du kannst deine Beiträge in diesem Forum nicht bearbeiten.
Du kannst deine Beiträge in diesem Forum nicht löschen.
Du kannst an Umfragen in diesem Forum nicht mitmachen.
Du kannst Dateien in diesem Forum posten
Du kannst Dateien in diesem Forum herunterladen
.





 Impressum  | Nutzungsbedingungen  | Datenschutz | FAQ | goMatlab RSS Button RSS

Hosted by:


Copyright © 2007 - 2024 goMatlab.de | Dies ist keine offizielle Website der Firma The Mathworks

MATLAB, Simulink, Stateflow, Handle Graphics, Real-Time Workshop, SimBiology, SimHydraulics, SimEvents, and xPC TargetBox are registered trademarks and The MathWorks, the L-shaped membrane logo, and Embedded MATLAB are trademarks of The MathWorks, Inc.