Datenbank



  • Hallo !

    Vielleicht ist ja die MSDE was für Dich. Die MSDE basiert auf der gleichen
    Engine wie der SQL Server 2000. Hat allerdings eine Beschränkung von
    2GB pro Instanz und nur 5 gleichzeitige Verbindungen.

    Kannst ja mal unter
    [url]http://www.microsoft.com/sql/techinfo/development/2000/MSDE2000.asp [/url]
    nachgucken.



  • Ich würde den MS SQL Server empfehlen, da er leicht zu administrieren ist(im Vergleich zu Oracle).

    Außerdem ist er mit ca. 1500 € pro Server-Lizenz nicht sehr teuer.



  • Cache 5.0 von Intersystems!! www.intersystems.com
    Ist objektorientiert kann aber trotzdem über ODBC,JDBC mit SQL gefüttert werden.
    Verfügt über ein SQL-Gateway womit die Daten aus bestehenden relationalen Datenbanken genutzt werden können. Und,was den Namen angeht, Cache ist die führende DB im Medizinbereich.(natürlich nicht umsonst 😞 )

    MfG Spacelord 🙂



  • Viele Kunden wollen (auch wenn sie meist keine Ahnung haben und es Ihnen eigentlich auch egal sein könnte) irgend einen "bekannten" Namen hören.

    Wenn da nicht SAP DB punkten kann ("ja, von SAP!" :D)

    da man ja keinen Anspruch auf irgendwelchen Support hat oder irre ich da?

    Anspruch hat man doch auch nicht unbedingt bei kommerziellen Produkten aber zu den meisten freien Datenbanken gibt es Support Verträge (die kosten dann aber was)

    (BTW: ist PostgreSQL auch noch eine freie DB, die zwar nicht ganz so viel kann wie SAP DB aber ISO SQL schon besser unterstützt als MySQL)



  • Hier ein Ausschnitt aus der c't 5/2003, S. 142: Open-Source-Datenbanken:
    http://www.heise.de/ct/03/05/142/default.shtml

    Hier kurz was aus dem Fazit:

    "Letztendlich sind alle hier betrachteten Datenbanken für den täglichen Einsatz geeignet und alles andere als nur Spielzeuge spinnerter Open-Source-Verfechter. MySQL hinkt weiterhin hinter seinen Mitbewerbern her, sobald etwas anspruchsvollere Dinge ins Spiel kommen, etwa Trigger, Subselects etc. ..."

    "... Für Anwendungen, die einer Desktop-Datenbank entwachsen sind, eignen sich PostgresSQL, Firebird und SAP DB gleich gut."

    Da ihr denke ich mal keine Cluster u.ä. braucht (vermute ich mal, wenn ihr eigentlich mit Access ausgekommen seid) brauch ihr auch kein Oracle oder DB2. Weil das können die OpenSource-DBs natürlich nicht.

    Hier noch die wichtigsten URLs: www.mysql.de www.postgresql.org www.firebirdsql.org www.sapdb.org

    [ Dieser Beitrag wurde am 08.04.2003 um 21:26 Uhr von Artchi editiert. ]



  • ich würde SAP DB vorschlagen hab bis jetzt gute erfahrungen gemacht! relativ schnell sehr stabiel und kostenlos aber achtung der support kostet. die engine basiert auf Oracle und is von SAP en bissle umgestrickt worden.



  • Laut c't basiert die SAP DB auf AdabasD, da es Ex-Software AG Mitarbeiter sind, die vor ein paar Jahren das Projekt begonnen haben. Weiterhin handelt es sich nicht um die "alte" SAP DB (DDB/4) von 1992, sondern wurde 1997 begonnen und 2000 unter GPL gestellt.



  • Danke euch allen,

    SapDb liest sich auch erstmal ziemlich gut, zumal die angebotenen Schnittstellen recht umfangreich scheinen. Spricht eigentlich irgendwas dagegen erstmal eine ODBC Schnittstelle zu verwenden, und dann einfach mal alle DBs (so sie einen ODBC Treiber haben) auf Ihre Eignung durchzutesten?

    Wie realisiert Ihr DB Zugrife? Mittels ODBC oder über sonstige SDK - Interfaces?



  • ODBC an sich ist nicht falsch. 😉 Wir benutzen für DB2-Zugriffe JDBC (das ODBC für Java) und einem Gateway das vor der Datenbank hängt, weil DB2 sonst einen zus. Client unter Windows verlangt (zu viel Installieraufwand, also klemmen wir nen Dual-P3-Gateway vor den DB2-Host). Rein von der Performance klappt das alles noch recht gut.

    Aber bedenke, das ODBC nicht heißt das alle Datenbanken das gleiche Verhalten ausweisen. Die haben alle so ihre Eigenheiten. Aber zum Testen und Research auf jeden Fall i.O. alle durch zu probieren und sich dann für ein zu entscheiden.

    Ansonst halt nen Wrapper coden damit man später evtl. auf eine spezielle DB-API umsteigen kann. Kommt darauf an wieviel User so auf der DB aktiv sind.



  • Spricht eigentlich irgendwas dagegen erstmal eine ODBC Schnittstelle zu verwenden

    ja, die ODBC Schnitstelle 😉 Naja, aber wenn man sich dadurch quält, dann ist das natürlich eine Möglichkeit (warum macht eigentlich niemand mal ein ODBC 2, mit einem vernünftigen Interface (und bitte nicht wieder MS, die uns schon das aktuelle Interface eingebrockt haben 😡 ))

    Wie realisiert Ihr DB Zugrife? Mittels ODBC oder über sonstige SDK - Interfaces?

    Ich hab mal einen Wrapper für Datenbank Zugriffe geschrieben, der ODBC genutzt hat und MySQL und PostgreSQL aber auch direkt über die eigenen APIs angesprochen hat (ist aber nie ganz fertig geworden, da das Projekt für dass der Wrapper geschrieben wurde nicht vorran kam)

    @Artchi

    brauch ihr auch kein Oracle oder DB2. Weil das können die OpenSource-DBs natürlich nicht.

    Ich dachte SAP DB wär in dem Bereich gut



  • Nimm PostgreSQL oder MYSQL.
    IMHO sind dies bekannte DB und eigentlich auch nicht kostenlos.
    SUBSELECTS kommen in die MYSQL-DB rein. Fraglich warum man die brauchen sollte!

    Mysql unterstützt auch Transaction



  • Ich hab gestern abend SAP DB auf mein Win2000pro installiert, war ganz easy. Erste Datenbank angelegt, Selects, Creates usw. per WebTools von SAP durchgeführt. Kann man nicht meckern. Auch ODBC usw. gleich alles im System eingetragen.



  • SUBSELECTS kommen in die MYSQL-DB rein. Fraglich warum man die brauchen sollte!

    Jo und falls ich mich nicht irre, gibt es laut Standard gar keine Subselects,
    oder liege ich da falsch? Wenn nich, verstehe ich nicht, dass solche Dinge, die
    nicht im Standard sind immer als contra-Argument genommen werden.

    Sollte ich falsch liegen, beuge ich mich der Wahrheit, aber ich meine Subselects
    gehoeren nicht zum SQL Standard.

    mfg
    v R



  • Danke euch allen,

    Dann werde ich wohl erstmal ein bisschen mit ODBC rumspielen und die finale Entscheidung noch ein bisschen vertagen - Bis ODBC für mich ein bisschen mehr als nur ein Wort ist 🙂 .



  • Relationale DB und OOP passt einfach nicht,egal für welche du dich entscheidest.
    Da entwirfst du die tollsten Klassen um die Attribute nachher wieder auf 150 normalisierte Tabellen zu verteilen 🙄 .
    Das dauert und kostet 😞 .

    MfG Spacelord 🙂



  • Und zusätzlich bemerkt. Wenn du Performance willst lass die finger von ODBC



  • hihi, aber jeder Kluge Geschäftsmann lässt sich Performance später extra bezahlen! 😃 Erst alles mit ODBC ansprechen, wenns später knapp mit Performance wird und der Kunde nörgelt, dann sagen "Wir können da ne Lösung ausarbeiten." und dann stellt man alles auf DB-API um (natürlich vorher an nen Wrapper denken, sonst macht es mehr Arbeit als wieder Kohle reinfliesst). Find ich nur legetim, da der Kunde zu Anfang eh immer nur den minimalsten Preis zahlen will und auch alles immer am liebsten gestern fertig haben will.

    [ Dieser Beitrag wurde am 12.04.2003 um 13:53 Uhr von Artchi editiert. ]



  • HiHi,du kennst den Geschäftsführer der Firma wo ich (noch) arbeite???
    Der will sich jetzt auch nen SAP für Arme anschaffen.Nen Arbeitskollegen von mir der Adminmässig wirklich was auf den Kasten hat,hat er letztens gesagt dass er zu doof ist (weil er nicht studiert hat) um den Job zu machen.Hat sich aber vorher von dem "Doofen" das komplette Netzwerk auf Vordermann bringen lassen. Nur als der Kollege dann ne angemessene Bezahlung haben wollte war er auf einmal zu doof dazu 😡(wir arbeiten da beide regulär als Werkzeugmacher).
    Naja,seit dem haben wir viel zu lachen!Die Inkompetenz der Studierten(nichts gegen Studierte,ich studiere selber nebenbei Informatik) ist wirklich allererster Güte.Letztens haben zwei Schlaue 1Woche(!!) gebraucht um im Netzwerk ne Datei von einem Rechner auf den anderen zu kopieren!!Und dann haben die sich,von der Firma die unseren Server wartet,nen Techniker kommen lassen um nen Rechner ins Internet zu bringen.Der gute Mann hat knapp 2 Stunden gebraucht die IP des Proxyservers im IE einzugeben 😃 .Das war ein teurer Spass aber,aus der Sicht vom Boss,immer noch besser als dem Kollegen von mir 1000 Euro mehr zu zahlen! Naja auf jeden Fall arbeitet das Armen-SAP mit jeder(!) DB zusammen,kann also auch nur irgend ne Standardschnittstelle sein die von der Performance her auch nix dolles sein kann.Mal abgesehen davon dass die Schlauen seit 4 Jahren 😃 am überlegen sind welche Daten die denn überhaupt verwalten wollen,glaubt der Alte allen Ernstes dass das ganze System nach 3 Monaten reibungslos läuft und dass er dafür auch keinerlei Administratoren braucht.Das ganze Softwarepaket soll so um 500000 Euro kosten und es ist echt keine Sau da(zumindest niemand der gefragt wird,weil der Mob ja doof ist)der auch nur annähernd beurteilen kann ob dass überhaupt was taugt!?
    Wo Firma X mitbekommen hat dass der Kollege von mir nicht mehr für die EDV zuständig ist haben die erstmal die Korken knallen lassen!!
    Wirklich cool,so nen Kunden kann man jedem EDV Unternehmen nur wünschen ;).

    MfG Spacelord 🙂 🙂



  • hi all

    @Unix Tom:

    Fraglich warum man die brauchen sollte!

    also ich moechte mal sehen wie du komplexe auswertungen ohne sub selects zusammenstellst
    ich hab bei meinem letzten projekt mich entschieden MySQL zu benutzen und diesen fehler werde ich nie wieder machen
    dabei ist unsere datenbank (design von mir entwickelt) gar nicht so komplex - ich habe gerade einmal 100 tabellen und ein paar tausend datensaetze - was aber rapid ansteigend ist und wenn ich dann eine auswertung machen will dann schauts bloed aus mit der funktionalitaet von MySQL - jedesmal die ganzen sub selects vorher ausfuehren und dann nen String zusammenstellen um das ganze dann in einem simplen select laufen zu lassen - das ist es einfach nicht wert
    ganz zu schweigen von dem kommunikationsaufwand - hin und herschicken von resultsets --- sowas gehoert sich nicht
    zu dem transaktionsmechanismus sag ich jetzt nichts
    ich hab mir das nur einmal angeschaut und so ganz sicher kommt mir das nicht vor
    muss mich mal einarbeiten und schauen wie das im hintergrund funktioniert
    aber transaktionen sind ja auf jedem rdbms ein graus - man denke nur an die verschiedenen implementierungen der isolation levels

    @virtuell Realisticer:

    Jo und falls ich mich nicht irre, gibt es laut Standard gar keine Subselects,
    oder liege ich da falsch? Wenn nich, verstehe ich nicht, dass solche Dinge, die
    nicht im Standard sind immer als contra-Argument genommen werden.

    ich glaube da hast du was nicht wirklich mitbekommen
    im SQL-1 standard (ueberarbeitung 89) gibt es keine sub selects
    da gibt es nur:
    Create Table,Create View, Grant, Revoke, Select, Update, Insert, Delete
    allerdings ist dieser standard schon etwas veraltet
    sub selects sind standard ab SQL-2 (SQL-92)
    dieser standard stellt heutzutage das dar was jedes datenbank system koennen sollte (ist auch schon 11 jahre alt) und dort sind folgende dinge inbegriffen:
    (je nach Conformance Level - Intermediate sollte pflicht fuer ein DB System sein)
    E-SQL, Dynamic SQL,SQL 92 Join (explicit Join),Column Constraints,Sub Selects
    und noch ein paar andere kleinigkeiten
    wenn du dann den SQL-3 Standard hernimmst (99) dann bekommst du die ganze palette von trigger, stored procedures und so weiter
    aber der ist nicht so wichtig (auch wenn mein liebster)

    @TheBigW:
    ich hab auch schon ueber das SAP DBMS gelesen - schaut ganz gut aus
    PostGRE ist auch nicht so schlecht - skalliert besser als MySQL
    ansonsten ist der MS SQL Server keine schlechte entscheidung - kommerziell gesehen
    mach nicht meinen fehler - entscheide dich fuer das DB System nachdem du eine genaue spezifikation dafuer geschrieben hast
    es gibt soviele systeme in der zwischenzeit - alle mit staerken und schwaechen

    mysql solltest du nicht nehmen -- alleine schon wegen der fehlenden referentiellen integritaet - da stellen sich bei mir alle nackenhaare auf

    wuensch euch noch was

    gomberl



  • gomberl:

    Du hast nicht den Fehler gemacht MYSQL zu verwenden sondern den SQL-Syntax auszunutzen.

    Schon mal was von JOIN gehört.
    Sind in der Mehrzahl der Fälle sogar effizienter als SUBSELECT.
    Also bitte hier keine Falschmeldungen verbreiten.

    @all: Jeder sollte die DB verwenden, die er für richtig,seinem Zweck geeignet und seiner Geldbörse angepasst hält.

    [ Dieser Beitrag wurde am 13.04.2003 um 13:16 Uhr von Unix-Tom editiert. ]


Anmelden zum Antworten