AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken FB: Unique Index auf Datum und Uhrzeit
Thema durchsuchen
Ansicht
Themen-Optionen

FB: Unique Index auf Datum und Uhrzeit

Ein Thema von hoika · begonnen am 31. Jan 2018 · letzter Beitrag vom 3. Feb 2018
 
Benutzerbild von himitsu
himitsu
Online

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.505 Beiträge
 
Delphi 12 Athens
 
#6

AW: FB: Unique Index auf Datum und Uhrzeit

  Alt 3. Feb 2018, 07:38
In Oracle kann Date Type auch Uhrzeiten enthalten.
Das wäre auch besser, denn sein Uhrzeit-Feld ist ja auch als DATE und nicht als TIME deklariert.

Jupp, also theoretisch würde der Index ja funktionieren. (aber wie bereits genannt wurde, gibt es das Hindernis mit den ungenauen Werten)
CREATE UNIQUE INDEX DeineTabelle_id_datetime ON DeineTabelle (PersonalId, Datum, Uhrzeit)

Aber zur Sicherheit kannst du deine Zeit-Werte auch im Index umrechnen/casten, zusammenfassen und vor allem auf ein gewünschtes Maß "runden".
z.B. beim Datum die eventuelle Uhrzeit entfernen und die Uhrzeit auf Sekunden runden. (Trunc/Extract)
SQL-Code:
CREATE UNIQUE INDEX DeineTabelle_id_datetime ON DeineTabelle COMPUTED BY (PersonalId, CAST(Datum AS DATE), CAST(Uhrzeit AS TIME)); -- Cast geht wohl nicht, wenn DATE = DATETIME
CREATE UNIQUE INDEX DeineTabelle_id_datetime ON DeineTabelle COMPUTED BY (PersonalId, Trunc(Datum) + (Uhrzeit - Trunc(Uhrzeit)));
CREATE UNIQUE INDEX DeineTabelle_id_datetime ON DeineTabelle COMPUTED BY (PersonalId, DateAdd(Trunc(Datum), Uhrzeit));
...
Einen Cast/Round um Uhrzeit auf Sekunden zu runden oder ein Cast(Extract(Uhrzeit, SecondOfDay) AS INTEGER) gibt es wohl nicht?

Zitat:
Aus der DB-Exception herauszufinden, warum der Datensatz nicht angelegt werden konnte, ist schwerer.
Gut, man könnte auch über einen BeforeInsert-Trigger alles "nochmals" prüfen und eine bessere Fehlermeldung ausgeben.
Genauso kann man aber dem UniqueIndex auch einen sprechenden Namen geben, da er doch in der Fehlermeldung genannt wird.
Man könnte sich auch in die Error-Events der Connection/Querykomponente hängen und da den Triggernamen übersetzen, bzw. die Fehlermeldung um etwas Verständlicheres ergänzen.
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu ( 3. Feb 2018 um 07:57 Uhr)
  Mit Zitat antworten Zitat
 


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 12:52 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz