![]() |
Datenbank: mySQL • Version: 5.5 • Zugriff über: mySQL Query Browser
mySQL Datenbank für einen Benutzer readonly
Auf einem entfernten Rechner möchte ich gerne dass ein Benutzer auf einer Datenbank nur Leserechte und auf allen anderen Datenbanken Schreibrechte hat. Im Moment hat dieser Benutzer Schreibrechte auf allen Datenbanken (Eintrag in der Tabelle User mit Host = '%'). Leider habe auf dem entfernten Rechner keine mySQLAdministrator.exe oder WorkBench drauf. Von meiner lokalen mySQLAdministrator.exe aus darf ich die Zugriffsrechte auf diesem Server leider nicht ändern.
Das Handbuch bzgl. des Grant-Befehls, verstehe ich irgendwie nicht und im Suchen bin ich heute nicht gut. Wer kann mir den (die) richtigen GRANT-Befehl(e) (oder insert into mysql.User?) nennen? |
AW: mySQL Datenbank für einen Benutzer readonly
Eigentlich läuft sowas doch in jeder DB gleich, oder?
Grant [INSERT],[UPDATE],[DELETE],[SELECT] on <Tablename> to <auser>; für alle Tabellen versteht sich oder hier ist was Konkretes, Pauschales auf Englisch, passt wahrscheinlich nicht ganz zu Deinen Zugriffsmöglichkeiten. mySQL Reference sollte sicher mehr Details liefern: ![]() |
AW: mySQL Datenbank für einen Benutzer readonly
Wäre es vllt. überlegenswert statt die Rechte jedem einzelnen Benutzer zu geben, erst einmal eine Rolle zu definieren und dem Benutzer diese zu geben?
Bei mehreren Benutzern sollte das unter dem Strich effizenter sein. Gruß K-H |
AW: mySQL Datenbank für einen Benutzer readonly
Es handelt sich genau um 1 einzigen Benutzer, der Schreibzugriff auf alle Datenbanken haben soll, nur bei einer einziger Datenbank soll genau dieser eine Benutzer nur Leserechte haben. Wie ich das löse ist eigentlich egal, ob über Rollen oder Rechte. Wichtig ist nur, dass sich die Anmeldung dieses Benutzers an die verschiedenen Datenbanken nicht ändern darf (also keinen anderen Namen).
Wie ist es eigentlich wenn ich einen weiteren Datensatz in die Users-Tabelle aufnehme, z.B. Im Moment vorhanden: Host : % User : MeinBenutzer Lese-Rechte : Y Schreib-Rechte : Y Neu: Host : %.DBName User : MeinBenutzer Lese-Rechte : Y Schreib-Rechte : N würde das gehen? |
AW: mySQL Datenbank für einen Benutzer readonly
|
AW: mySQL Datenbank für einen Benutzer readonly
Kann ich DeddyH nur zustimmen.
Systemtabellen selbst anfassen ist böse. Was hindert Dich, das mal eben mit XAMPP auszuprobieren? Revoke / Grant / flush privileges. Das sieht recht übersichtlich aus. |
AW: mySQL Datenbank für einen Benutzer readonly
Danke für eure Antworten.
@jobo: auf dem Rechner kann ich von hier aus nichts installieren, also kein XAMPP oder was immer das ist. @DeddyH : Das Handbuch habe ich schon wie oben gesagt gelesen, allerdings nicht verstanden, aber ich versuche mich einfach nochmals es zu kapieren. |
AW: mySQL Datenbank für einen Benutzer readonly
jobo meinte wahrscheinlich, Du sollst auf Deinem Rechner
![]() |
AW: mySQL Datenbank für einen Benutzer readonly
Ich habe hier bei mir im Haus einen mysql-Server laufen auf dem ich das natürlich zuerst ausprobieren werde. Da kann ich das auch ganz leicht über der mySQLAdministrator.exe machen. Beim entfernten Rechner kann ich das halt nicht mit der exe machen, dort ist der Benutzer-Rechte-Bereich ausgegraut. Deswegen denke ich dass ich mit einer anderen Software (wie XAMPP) ebenfalls den Benutzerrechte-Bereich von hier aus nicht ändern darf.
Deswegen brauche ich die GRANT und was weiß ich noch alles Befehle. Ich mach mich jetzt nochmal ans mysql-Handbuch, oder ich finde ich ja doch noch Beispiele in den Weiten des Internets. |
AW: mySQL Datenbank für einen Benutzer readonly
Wenn mich nicht alles täuscht (ich bin nicht so der mySQL-Experte), müsste es so gehen:
SQL-Code:
Damit hat der Benutzer zwar Server-global immer noch alle Rechte, auf der angegebenen DB aber keine mehr. Die müssen nun erteilt werden:
REVOKE ALL ON DBName.* FROM Benutzername
SQL-Code:
Welche Rechte genau benötigt werden, hängt von der DB-Struktur ab, ggf. muss da z.B. noch EXECUTE mit in die Liste, zusätzlich zum SELECT.
GRANT SELECT ON DBName.* TO Benutzername
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:47 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 by Thomas Breitkreuz