Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

SQL-Abfrage - how2do

Frage Entwicklung Datenbanken

Mitglied: Ravers

Ravers (Level 2) - Jetzt verbinden

05.04.2007, aktualisiert 06.04.2007, 3396 Aufrufe, 3 Kommentare

Hallo liebe Gemeinde,

ich habe da ein kleines Prob mit einer Abfrage (MSSQL2005).

Ich möchte:
SELECT *
FROM DOKUMENT
WHERE (NOT (DICKE = 1)) AND
WHERE (NOT (DICKE = 5))

jedoch gibt er mir hier kein Ergebniss raus, Hinweis Fehler in Nähe von der Where-Klausel.
(Ich möchte ein varchar-Feld in Float ändern, das lässt er jedoch nicht zu. Ich denke das hier NichtZahlen in der Spalte Dicke sind. Evtl. kann man es auch anders lösen?!?!)

How2do???


Thanks4help !
Mitglied: AndreasHoster
05.04.2007 um 12:08 Uhr
Daist eindeutig ein Where zuviel:
SELECT *
FROM DOKUMENT
WHERE (NOT (DICKE = 1)) AND (NOT (DICKE = 5))

Und wenn Dicke kein Zahlenfeld ist, dann klappt das so auch nicht. Dann fehlen einfache Anführungszeichen.
Für Ändern gibts cast und convert.
Bitte warten ..
Mitglied: pi314
06.04.2007 um 12:20 Uhr
es geht auch noch ein bisschen einfacher:

01.
SELECT * 
02.
  FROM DOKUMENT 
03.
 WHERE dicke NOT IN ( 1, 5 )
greetz,
pi
Bitte warten ..
Mitglied: Biber
06.04.2007 um 13:28 Uhr
Moin Ravers,

Ich möchte ein varchar-Feld in Float ändern, das lässt er jedoch nicht zu.
Ich denke das hier NichtZahlen in der Spalte Dicke sind.

Wenn das so ist, würde ich grundsatzlich über die Sinnhaftigkeit der Tabellenstruktur nachdenken brziehungsweise darüber, wie ich von den Benutzern verwertbare Eingaben erzwingen kann.

Wenn es denn tatsächlich so sein sollte wie beschrieben, dann müsstest Du eigentlich zwei Sachverhalte abprüfen:
1) Ist der Inhalt numerisch?
2) Falls ja, ist es 1 oder 5?

Das würde einem
01.
SELECT * 
02.
FROM DOKUMENT 
03.
WHERE isNumeric( Dicke)  AND (cast(dicke as float) in (1, 5))
..entsprechen. Das sieht aber nicht nur shice aus, sondern kann auch nur zum gewünschten Ergebnis führen, wenn in dem Feld DICKE nur (von Leerzeichen abgesehen) "1" ode "5" enthalten ist.
Also weder "1.5" noch "5 cm" oder ähnliches.

In diesem Fall kannst Du aber sinnvoller pi314's Statement leicht variiert übernehmen.
01.
SELECT Dokument.*, fltDicke as cast(DICKE as float) 
02.
FROM DOKUMENT 
03.
WHERE (DICKE in ("1", "5"));
Ich verschiebe den Beitrag mal von "Entwicklung" nach "Datenbanken".

Gruß
Biber
Bitte warten ..
Ähnliche Inhalte
Entwicklung
gelöst SQL Abfrage Zeit: JETZT - 30 Sekunden (17)

Frage von Andinistrator1 zum Thema Entwicklung ...

Datenbanken
gelöst Hilfe bei SQL-Abfrage (5)

Frage von emeriks zum Thema Datenbanken ...

Datenbanken
gelöst SQL-Abfrage mit "kleiner gleich" funktioniert nicht (2)

Frage von derSESO zum Thema Datenbanken ...

Neue Wissensbeiträge
Windows 10

Windows 8.x oder 10 Lizenz-Key aus dem ROM auslesen mit Linux

(6)

Tipp von Lochkartenstanzer zum Thema Windows 10 ...

Tipps & Tricks

Wie Hackt man sich am besten in ein Computernetzwerk ein

(38)

Erfahrungsbericht von Herbrich19 zum Thema Tipps & Tricks ...

Heiß diskutierte Inhalte
Windows 10
gelöst Windows 10 Home "Netzlaufwerk nicht bereit" (19)

Frage von Oggy01 zum Thema Windows 10 ...

SAN, NAS, DAS
+100tb Storagelösung (12)

Frage von Data-Fabi zum Thema SAN, NAS, DAS ...

LAN, WAN, Wireless
Cisco W-Lan Controller als Applicance oder Software (11)

Frage von Herbrich19 zum Thema LAN, WAN, Wireless ...

DNS
gelöst Komplette TLD Überschreiben bzw eigene Definieren (10)

Frage von Herbrich19 zum Thema DNS ...