|
|
Database Toolbox: 2 Variablen in einem sql-query |
|
maxtob |
Forum-Anfänger
|
|
Beiträge: 13
|
|
|
|
Anmeldedatum: 13.06.09
|
|
|
|
Wohnort: ---
|
|
|
|
Version: ---
|
|
|
|
|
|
Verfasst am: 10.07.2009, 11:26
Titel: Database Toolbox: 2 Variablen in einem sql-query
|
|
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):
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
|
|
|
|
|
Titus |
Forum-Meister
|
|
Beiträge: 871
|
|
|
|
Anmeldedatum: 19.07.07
|
|
|
|
Wohnort: Aachen
|
|
|
|
Version: ---
|
|
|
|
|
|
Verfasst am: 10.07.2009, 12:22
Titel:
|
|
Hallo,
bin mir nicht sicher, wo der Fehler steck. Allerdings würde ich Memos auch auf das Cell-Element zugreifen, d.h.,
(geschweifte Klammern). Wie gesagt, ob das hilft habe ich keine Ahnung .
Titus
|
|
|
Dagnabit |
Forum-Century
|
|
Beiträge: 244
|
|
|
|
Anmeldedatum: 23.04.09
|
|
|
|
Wohnort: ---
|
|
|
|
Version: ---
|
|
|
|
|
|
Verfasst am: 10.07.2009, 14:41
Titel:
|
|
|
|
|
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.
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:
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:
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
|
|
|
maxtob |
Themenstarter
Forum-Anfänger
|
|
Beiträge: 13
|
|
|
|
Anmeldedatum: 13.06.09
|
|
|
|
Wohnort: ---
|
|
|
|
Version: ---
|
|
|
|
|
|
Verfasst am: 10.07.2009, 14:44
Titel:
|
|
Danke für den Tipp,
bin mittlerweile selbst drauf gekommen wies funktioniert:
|
|
|
|
|
Einstellungen und Berechtigungen
|
|
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
| 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.
|
|