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

Datenbank programatisch erstellen

 

joekey
Forum-Century

Forum-Century


Beiträge: 169
Anmeldedatum: 03.04.08
Wohnort: Wien
Version: 2011b
     Beitrag Verfasst am: 13.09.2008, 23:29     Titel: Datenbank programatisch erstellen
  Antworten mit Zitat      
Hallo,

hätte mich interessiert, wie ich Programatisch eine Datenbank (MySQL)
anlegen kann. Einen passenden Befehl habe ich nicht gefunden, nur :

Code:

exec(con, 'CREATE DATABASE `test` DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;')
 


Das Problem ist dass ich so lange die Db nich besteht, kein con Object erstellen kann.

Jemand eine Idee?

Danke Joe
Private Nachricht senden Benutzer-Profile anzeigen


joekey
Themenstarter

Forum-Century

Forum-Century


Beiträge: 169
Anmeldedatum: 03.04.08
Wohnort: Wien
Version: 2011b
     Beitrag Verfasst am: 15.09.2008, 22:07     Titel:
  Antworten mit Zitat      
Also ich habe das Problem folgendermaßen gelößt. Ich erstelle eine .sql file die eine Datenbank erstellt und diese starte ich über ein .bat file.

Code:

 function createDb(dbName, user, pass)
           global dbPath
           dbPath = 'C:\xampp\mysql\bin\';
           if ~exist('createDb.bat', 'file')
               fid = fopen('createDb.bat','w');
               fprintf(fid, '@echo off\n');
               fprintf(fid, 'C: \n');
               fprintf(fid, 'CD %s \n', dbPath);
               fprintf(fid, 'mysql -u root<dbCreation.sql\n');
               fclose(fid);
           end
           
           if exist([ dbPath '\dbCreation.sql' ],'file')
               delete([ dbPath '\dbCreation.sql' ]);
           end
           
           fid = fopen([ dbPath '\dbCreation.sql' ],'w');
           fprintf(fid, '#\n');
           fprintf(fid, '#Create database \n#\n');
           fprintf(fid, '#\n');
           fprintf(fid, 'CREATE DATABASE IF NOT EXISTS %s;\n', dbName);
           fprintf(fid, 'CREATE USER %s@localhost IDENTIFIED BY \''%s\'';\n' , user, pass);
           fprintf(fid, 'GRANT SELECT ON * . *');
           fprintf(fid, 'TO %s@localhost IDENTIFIED BY \''%s\''\n', user, pass);
           fprintf(fid, 'WITH MAX_QUERIES_PER_HOUR 0 \n');
           fprintf(fid, 'MAX_CONNECTIONS_PER_HOUR 0 \n');
           fprintf(fid, 'MAX_UPDATES_PER_HOUR 0 \n');
           fprintf(fid, 'MAX_USER_CONNECTIONS 0 ;\n');
           fclose(fid);
           
           dos('D:\Dokumente\MATLAB\DL1.0\createDb.bat');
       end
 


Auf diese weise wird eine neue Datenbank mit den SELECT rechten für den User auf alle Tabellen dieser Datenbank erstellt.

Ich habe noch 2 Fragen: könnte man folgenden code mittels dos() Befehls umschreiben, damit ich keinen .bat file dynamisch erzeugen muss?
Code:

           if ~exist('createDb.bat', 'file')
               fid = fopen('createDb.bat','w');
               fprintf(fid, '@echo off\n');
               fprintf(fid, 'C: \n');
               fprintf(fid, 'CD %s \n', dbPath);
               fprintf(fid, 'mysql -u root<dbCreation.sql\n');
               fclose(fid);
           end
 


Der Befehl : CREATE DATABASE IF NOT EXISTS NAME, fängt die Möglichkeit ab dass die Db mit diesem Namen bereit existiert. Wie könnte ich das gleiche Verhalten auch bei der Erstellung des USERS anwenden? Also dass es zu keinem Fehler bei dem Versuch, einen bereits Existierenden User zu erstellen kommt.
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.