2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
En tant que système de gestion de bases de données relationnelles largement utilisé, MySQL offre de riches fonctionnalités pour prendre en charge différents types d'applications. Voici quelques fonctions courantes de MySQL :
MySQL fournit des instructions SQL flexibles pour créer, modifier et supprimer des bases de données et leurs tables.
CREATE DATABASE mydatabase;
CREATE TABLE mytable (id INT PRIMARY KEY, name VARCHAR(50));
Utilisez des instructions SQL standard pour la manipulation des données.
INSERT INTO mytable (id, name) VALUES (1, 'Alice');
UPDATE mytable SET name = 'Bob' WHERE id = 1;
DELETE FROM mytable WHERE id = 1;
Récupération de données via des instructions SELECT, y compris des JOIN complexes, des sous-requêtes, le tri et le regroupement.
SELECT * FROM mytable WHERE name = 'Alice';
SELECT name, COUNT(*) FROM mytable GROUP BY name;
MySQL fournit un contrôle précis des autorisations, permettant aux administrateurs d'attribuer différentes autorisations à différents utilisateurs.
CREATE USER 'user1'@'localhost' IDENTIFIED BY 'password';
GRANT SELECT, INSERT ON mydatabase.* TO 'user1'@'localhost';
À partir de MySQL 8.0, la gestion des rôles est prise en charge, simplifiant l'attribution et la gestion des autorisations.
CREATE ROLE 'developer';
GRANT SELECT, INSERT, UPDATE ON mydatabase.* TO 'developer';
GRANT 'developer' TO 'user1'@'localhost';
MySQL prend en charge plusieurs types d'index, tels que l'index B-Tree, l'index de texte intégral et l'index spatial, pour améliorer les performances des requêtes.
CREATE INDEX idx_name ON mytable(name);
MySQL fournit une fonction de mise en cache des requêtes, qui peut mettre en cache les résultats des requêtes et améliorer l'efficacité d'exécution de la même requête (supprimée dans MySQL 8.0).
Un ensemble de tables et d'outils sont fournis pour surveiller et analyser les performances de la base de données.
SELECT * FROM performance_schema.events_statements_summary_by_digest;
MySQL prend en charge la réplication maître-esclave pour la distribution des données et la haute disponibilité.
CHANGE MASTER TO MASTER_HOST='master_host', MASTER_USER='replication_user', MASTER_PASSWORD='password';
START SLAVE;
Fournir des solutions de cluster de bases de données à haute disponibilité pour garantir la haute disponibilité et la cohérence des données.
utiliser mysqldump
Outils de sauvegarde logique.
mysqldump -u root -p mydatabase > mydatabase.sql
utiliser mysqlbackup
(Sauvegarde MySQL Enterprise) ou xtrabackup
(Percona XtraBackup) pour la sauvegarde physique.
Code SQL qui s'exécute automatiquement lorsque des événements spécifiques (tels que INSERT, UPDATE, DELETE) se produisent sur une table spécifique.
CREATE TRIGGER mytrigger BEFORE INSERT ON mytable FOR EACH ROW SET NEW.name = UPPER(NEW.name);
Encapsulez un ensemble d'instructions SQL afin qu'elles puissent être appelées plusieurs fois afin d'améliorer la réutilisabilité et la maintenabilité du code.
CREATE PROCEDURE myprocedure(IN param1 INT)
BEGIN
SELECT * FROM mytable WHERE id = param1;
END;
Créez des tables virtuelles pour les requêtes complexes afin d'améliorer la lisibilité et la réutilisabilité des requêtes.
CREATE VIEW myview AS SELECT name FROM mytable WHERE id > 10;
Grâce à ces fonctions, MySQL fournit un ensemble d'outils puissants pour répondre aux besoins de divers scénarios d'application.