MariaDB - Guide rapide

Une application de base de données existe séparément de l'application principale et stocke les collections de données. Chaque base de données utilise une ou plusieurs API pour la création, l'accès, la gestion, la recherche et la réplication des données qu'elle contient.

Les bases de données utilisent également des sources de données non relationnelles telles que des objets ou des fichiers. Cependant, les bases de données s'avèrent la meilleure option pour les grands ensembles de données, qui souffriraient d'une récupération et d'une écriture lentes avec d'autres sources de données.

Les systèmes de gestion de bases de données relationnelles, ou SGBDR, stockent les données dans différentes tables. Les relations entre ces tables sont établies à l'aide de clés primaires et de clés étrangères.

Le SGBDR offre les fonctionnalités suivantes -

  • Ils vous permettent d'implémenter une source de données avec des tables, des colonnes et des index.

  • Ils garantissent l'intégrité des références sur les lignes de plusieurs tables.

  • Ils mettent à jour automatiquement les index.

  • Ils interprètent les requêtes et les opérations SQL lors de la manipulation ou de l'extraction de données à partir de tables.

Terminologie du SGBDR

Avant de commencer notre discussion sur MariaDB, passons en revue quelques termes liés aux bases de données.

  • Database - Une base de données est une source de données constituée de tables contenant des données associées.

  • Table - Un tableau, c'est-à-dire une feuille de calcul, est une matrice contenant des données.

  • Column- Une colonne, signifiant élément de données, est une structure contenant des données d'un type; par exemple, les dates d'expédition.

  • Row- Une ligne est une structure regroupant des données associées; par exemple, les données d'un client. Il est également appelé tuple, entrée ou enregistrement.

  • Redundancy - Ce terme fait référence au stockage des données deux fois afin d'accélérer le système.

  • Primary Key- Il s'agit d'une valeur d'identification unique. Cette valeur ne peut pas apparaître deux fois dans une table et une seule ligne y est associée.

  • Foreign Key - Une clé étrangère sert de lien entre deux tables.

  • Compound Key- Une clé composée, ou clé composite, est une clé qui fait référence à plusieurs colonnes. Il fait référence à plusieurs colonnes en raison d'une colonne manquant d'une qualité unique.

  • Index - Un index est pratiquement identique à l'index d'un livre.

  • Referential Integrity - Ce terme signifie que toutes les valeurs de clé étrangère pointent vers des lignes existantes.

Base de données MariaDB

MariaDB est un fork populaire de MySQL créé par les développeurs originaux de MySQL. Il est né d'inquiétudes liées à l'acquisition de MySQL par Oracle. Il prend en charge à la fois les petites tâches de traitement de données et les besoins de l'entreprise. Il vise à être un remplacement instantané de MySQL ne nécessitant qu'une simple désinstallation de MySQL et une installation de MariaDB. MariaDB offre les mêmes fonctionnalités que MySQL et bien plus encore.

Principales caractéristiques de MariaDB

Les caractéristiques importantes de MariaDB sont -

  • Tout MariaDB est sous GPL, LGPL ou BSD.

  • MariaDB comprend une large sélection de moteurs de stockage, y compris des moteurs de stockage hautes performances, pour travailler avec d'autres sources de données SGBDR.

  • MariaDB utilise un langage de requête standard et populaire.

  • MariaDB fonctionne sur un certain nombre de systèmes d'exploitation et prend en charge une grande variété de langages de programmation.

  • MariaDB prend en charge PHP, l'un des langages de développement Web les plus populaires.

  • MariaDB propose la technologie de cluster Galera.

  • MariaDB propose également de nombreuses opérations et commandes non disponibles dans MySQL, et élimine / remplace les fonctionnalités ayant un impact négatif sur les performances.

Commencer

Avant de commencer ce didacticiel, assurez-vous d'avoir des connaissances de base sur PHP et HTML, en particulier les éléments abordés dans nos didacticiels PHP et HTML.

Ce guide se concentre sur l'utilisation de MariaDB dans un environnement PHP, nos exemples seront donc très utiles pour les développeurs PHP.

Nous vous recommandons vivement de consulter notre didacticiel PHP si vous manquez de connaissances ou avez besoin de le réviser.

Tous les téléchargements pour MariaDB se trouvent dans la section Téléchargement du site officiel de la fondation MariaDB. Cliquez sur le lien de la version souhaitée et une liste de téléchargements pour plusieurs systèmes d'exploitation, architectures et types de fichiers d'installation s'affiche.

Installation sous LINUX / UNIX

Si vous avez une connaissance approfondie des systèmes Linux / Unix, téléchargez simplement la source pour construire votre installation. Notre méthode d'installation recommandée est d'utiliser les packages de distribution. MariaDB propose des packages pour les distributions Linux / Unix suivantes -

  • RedHat/CentOS/Fedora
  • Debian/Ubuntu

Les distributions suivantes incluent un package MariaDB dans leurs référentiels -

  • openSUSE
  • Arch Linux
  • Mageia
  • Mint
  • Slackware

Suivez ces étapes pour installer dans un environnement Ubuntu -

Step 1 - Connectez-vous en tant qu'utilisateur root.

Step 2 - Accédez au répertoire contenant le package MariaDB.

Step 3 - Importez la clé de signature GnuPG avec le code suivant -

sudo apt-key adv --recv-keys --keyserver keyserver.ubuntu.com 0xcbcb082a1bb943db

Step 4 - Ajouter MariaDB au sources.listfichier. Ouvrez le fichier et ajoutez le code suivant -

sudo add-apt-repository 'deb http://ftp.osuosl.org/pub/mariadb/repo/5.5/ubuntuprecise main'

Step 5 - Actualisez le système avec les éléments suivants -

sudo apt-get update

Step 6 - Installez MariaDB avec ce qui suit -

sudo apt-get install mariadb-server

Installation sous Windows

Après avoir localisé et téléchargé un fichier d'installation automatisée (MSI), double-cliquez simplement sur le fichier pour démarrer l'installation. L'assistant d'installation vous guidera à travers chaque étape de l'installation et les paramètres nécessaires.

Testez l'installation en la démarrant à partir de l'invite de commande. Accédez à l'emplacement de l'installation, généralement dans le répertoire, et tapez ce qui suit à l'invite -

mysqld.exe --console

Si l'installation réussit, vous verrez des messages liés au démarrage. Si cela n'apparaît pas, vous pouvez avoir des problèmes d'autorisation. Assurez-vous que votre compte utilisateur peut accéder à l'application. Des clients graphiques sont disponibles pour l'administration MariaDB dans l'environnement Windows. Si vous trouvez la ligne de commande inconfortable ou encombrante, assurez-vous de les expérimenter.

Test de l'installation

Effectuez quelques tâches simples pour confirmer le fonctionnement et l'installation de MariaDB.

Use the Admin Utility to Get Server Status

Affichez la version du serveur avec le binaire mysqladmin.

[root@host]# mysqladmin --version

Il doit afficher la version, la distribution, le système d'exploitation et l'architecture. Si vous ne voyez pas la sortie de ce type, examinez votre installation pour les problèmes.

Execute Simple Commands with a Client

Affichez l'invite de commande pour MariaDB. Cela devrait vous connecter à MariaDB et permettre l'exécution de commandes. Entrez une commande simple comme suit -

mysql> SHOW DATABASES;

Post-installation

Une fois l'installation réussie de MariaDB, définissez un mot de passe root. Une nouvelle installation aura un mot de passe vide. Entrez ce qui suit pour définir le nouveau mot de passe -

mysqladmin -u root password "[enter your password here]";

Entrez ce qui suit pour vous connecter au serveur avec vos nouvelles informations d'identification -

mysql -u root -p
Enter password:*******

Mise à jour sous Windows

Si MySQL est déjà installé sur votre système Windows et que vous souhaitez passer à MariaDB; ne désinstallez pas MySQL et installez MariaDB. Cela entraînera un conflit avec la base de données existante. Vous devez à la place installer MariaDB, puis utiliser l'assistant de mise à niveau dans le fichier d'installation Windows.

Les options de votre fichier MySQL my.cnf devraient fonctionner avec MariaDB. Cependant, MariaDB a de nombreuses fonctionnalités, qui ne se trouvent pas dans MySQL.

Considérez les conflits suivants dans votre fichier my.cnf -

  • MariaDB utilise le moteur de stockage Aria par défaut pour les fichiers temporaires. Si vous avez beaucoup de fichiers temporaires, modifiez la taille du tampon de clé si vous n'utilisez pas les tables MyISAM.

  • Si vos applications se connectent / se déconnectent fréquemment, modifiez la taille du cache des threads.

  • Si vous utilisez plus de 100 connexions, utilisez le pool de threads.

Compatibilité

MySQL et MariaDB sont essentiellement identiques. Cependant, il existe suffisamment de différences pour créer des problèmes de mise à niveau. Passez en revue plus de ces différences clés dans la base de connaissances MariaDB.

Avant d'essayer d'exécuter MariaDB, commencez par déterminer son état actuel, en cours d'exécution ou à l'arrêt. Il existe trois options pour démarrer et arrêter MariaDB -

  • Exécutez mysqld (le binaire MariaDB).
  • Exécutez le script de démarrage mysqld_safe.
  • Exécutez le script de démarrage mysql.server.

Si vous avez installé MariaDB dans un emplacement non standard, vous devrez peut-être modifier les informations d'emplacement dans les fichiers de script. Arrêtez MariaDB en ajoutant simplement un paramètre «stop» avec le script.

Si vous souhaitez le démarrer automatiquement sous Linux, ajoutez des scripts de démarrage à votre initsystème. Chaque distribution a une procédure différente. Reportez-vous à la documentation de votre système.

Créer un compte utilisateur

Créez un nouveau compte utilisateur avec le code suivant -

CREATE USER 'newusername'@'localhost' IDENTIFIED BY 'userpassword';

Ce code ajoute une ligne à la table des utilisateurs sans privilèges. Vous avez également la possibilité d'utiliser une valeur de hachage pour le mot de passe. Accordez les privilèges utilisateur avec le code suivant -

GRANT SELECT, INSERT, UPDATE, DELETE ON database1 TO 'newusername'@'localhost';

Les autres privilèges incluent à peu près toutes les commandes ou opérations possibles dans MariaDB. Après avoir créé un utilisateur, exécutez une commande «FLUSH PRIVILEGES» afin de rafraîchir les tables d'octroi. Cela permet d'utiliser le compte utilisateur.

Le fichier de configuration

Après une compilation sous Unix / Linux, le fichier de configuration «/etc/mysql/my.cnf» doit être édité pour apparaître comme suit -

# Example mysql config file.
# You can copy this to one of:
# /etc/my.cnf to set global options,
# /mysql-data-dir/my.cnf to get server specific options or
# ~/my.cnf for user specific options.

#

# One can use all long options that the program supports.
# Run the program with --help to get a list of available options

# This will be passed to all mysql clients
[client]
#password = my_password
#port = 3306
#socket = /tmp/mysql.sock

# Here is entries for some specific programs
# The following values assume you have at least 32M ram

# The MySQL server
[mysqld]
#port = 3306
#socket = /tmp/mysql.sock
temp-pool

# The following three entries caused mysqld 10.0.1-MariaDB (and possibly other
   versions) to abort...
# skip-locking
# set-variable = key_buffer = 16M
# set-variable = thread_cache = 4

loose-innodb_data_file_path = ibdata1:1000M
loose-mutex-deadlock-detector
gdb

######### Fix the two following paths

# Where you want to have your database
data = /path/to/data/dir

# Where you have your mysql/MariaDB source + sql/share/english
language = /path/to/src/dir/sql/share/english

[mysqldump]
quick
MariaDB
8
set-variable = max_allowed_packet=16M
[mysql]
no-auto-rehash

[myisamchk]
set-variable = key_buffer = 128M

Modifiez les lignes «data =» et «language =» en fonction de votre environnement.

Après la modification du fichier, accédez au répertoire source et exécutez ce qui suit -

./scripts/mysql_install_db --srcdir = $PWD --datadir = /path/to/data/dir -- user = $LOGNAME

Omettez le "$PWD” variable if you added datadir to the configuration file. Ensure “$LOGNAME »est utilisé lors de l'exécution de la version 10.0.1 de MariaDB.

Commandes d'administration

Consultez la liste suivante des commandes importantes que vous utiliserez régulièrement lorsque vous travaillerez avec MariaDB -

  • USE [database name] - Définit la base de données par défaut actuelle.

  • SHOW DATABASES - Répertorie les bases de données actuellement sur le serveur.

  • SHOW TABLES - Répertorie toutes les tables non temporaires.

  • SHOW COLUMNS FROM [table name] - Fournit des informations de colonne relatives à la table spécifiée.

  • SHOW INDEX FROM TABLENAME [table name] - Fournit des informations d'index de table relatives à la table spécifiée.

  • SHOW TABLE STATUS LIKE [table name]\G – - Fournit aux tables des informations sur les tables non temporaires et le modèle qui apparaît après la clause LIKE est utilisé pour récupérer les noms de table.

MariaDB s'associe bien avec une grande variété de langages de programmation et de frameworks tels que PHP, C #, JavaScript, Ruby on Rails, Django, etc. PHP reste le plus populaire de tous les langages disponibles en raison de sa simplicité et de son empreinte historique. Ce guide se concentrera sur PHP en partenariat avec MariaDB.

PHP fournit une sélection de fonctions pour travailler avec la base de données MySQL. Ces fonctions effectuent des tâches telles que l'accès ou l'exécution d'opérations, et elles sont entièrement compatibles avec MariaDB. Appelez simplement ces fonctions comme vous appelleriez n'importe quelle autre fonction PHP.

Les fonctions PHP que vous utiliserez pour MariaDB sont conformes au format suivant -

mysql_function(value,value,...);

La deuxième partie de la fonction spécifie son action. Deux des fonctions utilisées dans ce guide sont les suivantes:

mysqli_connect($connect); mysqli_query($connect,"SQL statement");

L'exemple suivant montre la syntaxe générale d'un appel PHP à une fonction MariaDB -

<html>
   <head>
      <title>PHP and MariaDB</title>
   </head>

   <body>
      <?php
         $retval = mysql_function(value, [value,...]); if( !$retval ) {
            die ( "Error: Error message here" );
         }
         // MariaDB or PHP Statements
      ?>
   </body>
</html>

Dans la section suivante, nous examinerons les tâches essentielles de MariaDB, en utilisant les fonctions PHP.

Une façon d'établir une connexion avec MariaDB consiste à utiliser le binaire mysql à l'invite de commande.

Binaire MYSQL

Passez en revue un exemple donné ci-dessous.

[root@host]# mysql -u root -p

Enter password:******

Le code donné ci-dessus se connecte à MariaDB et fournit une invite de commande pour exécuter des commandes SQL. Après avoir entré le code, un message de bienvenue devrait apparaître indiquant une connexion réussie, avec le numéro de version affiché.

Welcome to the MariaDB monitor. Commands end with ; or \g. 
Your MariaDB connection id is 122323232 
Server version: 5.5.40-MariaDB-log
  
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.  
mysql>

L'exemple utilise un accès root, mais tout utilisateur avec des privilèges peut bien sûr accéder à l'invite MariaDB et effectuer des opérations.

Déconnectez-vous de MariaDB via le exit commande comme suit -

mysql> exit

Script de connexion PHP

Une autre façon de se connecter et de se déconnecter de MariaDB consiste à utiliser un script PHP. PHP fournit lemysql_connect()fonction d'ouverture d'une connexion à une base de données. Il utilise cinq paramètres facultatifs et renvoie un identifiant de lien MariaDB après une connexion réussie, ou un false en cas d'échec de la connexion. Il fournit également lemysql_close() fonction de fermeture des connexions à la base de données, qui utilise un seul paramètre.

Syntaxe

Vérifiez la syntaxe du script de connexion PHP suivante -

connection mysql_connect(server,user,passwd,new_link,client_flag);

La description des paramètres est donnée ci-dessous -

Sr.Non Paramètre et description
1

server

Ce paramètre facultatif spécifie le nom d'hôte exécutant le serveur de base de données. Sa valeur par défaut est «localhost: .3036».

2

user

Ce paramètre facultatif spécifie le nom d'utilisateur accédant à la base de données. Sa valeur par défaut est le propriétaire du serveur.

3

passwd

Ce paramètre facultatif spécifie le mot de passe de l'utilisateur. Sa valeur par défaut est vide.

4

new_link

Ce paramètre facultatif spécifie que lors d'un deuxième appel à mysql_connect() avec des arguments identiques, plutôt qu'une nouvelle connexion, l'identifiant de la connexion actuelle sera renvoyé.

5

client flags

Ce paramètre facultatif utilise une combinaison des valeurs constantes suivantes -

  • MYSQL_CLIENT_SSL - Il utilise le cryptage SSL.

  • MYSQL_CLIENT_COMPRESS - Il utilise le protocole de compression.

  • MYSQL_CLIENT_IGNORE_SPACE - Il permet de l'espace après les noms de fonction.

  • MYSQL_CLIENT_INTERACTIVE - Il permet un délai d'attente interactif en secondes d'inactivité avant la fermeture de la connexion.

Consultez la syntaxe du script de déconnexion PHP donnée ci-dessous -

bool mysql_close ( resource $link_identifier );

Si vous omettez la ressource, la ressource ouverte la plus récente se fermera. Il renvoie la valeur true en cas de fermeture réussie ou false.

Essayez l'exemple de code suivant pour vous connecter à un serveur MariaDB -

<html>
   <head>
      <title>Connect to MariaDB Server</title>
   </head>

   <body>
      <?php
         $dbhost = 'localhost:3036';
         $dbuser = 'guest1'; $dbpass = 'guest1a';
         $conn = mysql_connect($dbhost, $dbuser, $dbpass);
      
         if(! $conn ) { die('Could not connect: ' . mysql_error()); } echo 'Connected successfully'; mysql_close($conn);
      ?>
   </body>
</html>

En cas de connexion réussie, vous verrez la sortie suivante -

mysql> Connected successfully

La création ou la suppression de bases de données dans MariaDB nécessite des privilèges généralement accordés uniquement aux utilisateurs root ou aux administrateurs. Sous ces comptes, vous avez deux options pour créer une base de données - le binaire mysqladmin et un script PHP.

mysqladmin binaire

L'exemple suivant illustre l'utilisation du binaire mysqladmin dans la création d'une base de données avec le nom Products -

[root@host]# mysqladmin -u root -p create PRODUCTS
Enter password:******

PHP Créer un script de base de données

PHP utilise le mysql_queryfonction en créant une base de données MariaDB. La fonction utilise deux paramètres, un facultatif, et renvoie la valeur «true» en cas de succès, ou «false» si ce n'est pas le cas.

Syntaxe

Revoir ce qui suit create database script syntaxe -

bool mysql_query( sql, connection );

La description des paramètres est donnée ci-dessous -

S. Non Paramètre et description
1

sql

Ce paramètre obligatoire se compose de la requête SQL nécessaire pour effectuer l'opération.

2

connection

Lorsqu'il n'est pas spécifié, ce paramètre facultatif utilise la connexion la plus récente utilisée.

Essayez l'exemple de code suivant pour créer une base de données -

<html>
   <head>
      <title>Create a MariaDB Database</title>
   </head>

   <body>
      <?php
         $dbhost = 'localhost:3036'; $dbuser = 'root';
         $dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
            die('Could not connect: ' . mysql_error());
         }

         echo 'Connected successfully<br />';
         $sql = 'CREATE DATABASE PRODUCTS'; $retval = mysql_query( $sql, $conn );
      
         if(! $retval ) { die('Could not create database: ' . mysql_error()); } echo "Database PRODUCTS created successfully\n"; mysql_close($conn);
      ?>
   </body>
</html>

En cas de suppression réussie, vous verrez la sortie suivante -

mysql> Database PRODUCTS created successfully 
mysql> SHOW DATABASES; 
+-----------------------+ 
| Database              | 
+-----------------------+ 
| PRODUCTS              | 
+-----------------------+

La création ou la suppression de bases de données dans MariaDB nécessite des privilèges, généralement accordés uniquement aux utilisateurs root ou aux administrateurs. Sous ces comptes, vous avez deux options pour supprimer une base de données: le binaire mysqladmin et un script PHP.

Notez que les bases de données supprimées sont irrécupérables, soyez donc prudent en effectuant cette opération. De plus, les scripts PHP utilisés pour la suppression fontnot vous invite avec une confirmation avant la suppression.

mysqladmin binaire

L'exemple suivant montre comment utiliser le binaire mysqladmin pour supprimer une base de données existante -

[root@host]# mysqladmin -u root -p drop PRODUCTS
Enter password:******
mysql> DROP PRODUCTS
ERROR 1008 (HY000): Can't drop database 'PRODUCTS'; database doesn't exist

Script de suppression de base de données PHP

PHP utilise le mysql_queryfonction de suppression des bases de données MariaDB. La fonction utilise deux paramètres, un facultatif, et renvoie la valeur «true» en cas de succès, ou «false» si ce n'est pas le cas.

Syntaxe

Passez en revue la syntaxe de script de base de données de dépôt suivante -

bool mysql_query( sql, connection );

La description des paramètres est donnée ci-dessous -

Sr.Non Paramètre et description
1

sql

Ce paramètre obligatoire se compose de la requête SQL nécessaire pour effectuer l'opération.

2

connection

Lorsqu'il n'est pas spécifié, ce paramètre facultatif utilise la connexion la plus récente utilisée.

Essayez l'exemple de code suivant pour supprimer une base de données -

<html>
   <head>
      <title>Delete a MariaDB Database</title>
   </head>

   <body>
      <?php
         $dbhost = 'localhost:3036'; $dbuser = 'root';
         $dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
            die('Could not connect: ' . mysql_error());
         }
         echo 'Connected successfully<br />';
         
         $sql = 'DROP DATABASE PRODUCTS'; $retval = mysql_query( $sql, $conn );
         
         if(! $retval ){ die('Could not delete database: ' . mysql_error()); } echo "Database PRODUCTS deleted successfully\n"; mysql_close($conn);
      ?>
   </body>
</html>

En cas de suppression réussie, vous verrez la sortie suivante -

mysql> Database PRODUCTS deleted successfully

Après vous être connecté à MariaDB, vous devez sélectionner une base de données avec laquelle travailler car de nombreuses bases de données peuvent exister. Il existe deux manières d'effectuer cette tâche: à partir de l'invite de commande ou via un script PHP.

L'invite de commande

En choisissant une base de données à l'invite de commande, utilisez simplement la commande SQL ‘use’ -

[root@host]# mysql -u root -p

Enter password:******

mysql> use PRODUCTS;

Database changed

mysql> SELECT database();  
+-------------------------+ 
| Database                | 
+-------------------------+ 
| PRODUCTS                | 
+-------------------------+

Une fois que vous avez sélectionné une base de données, toutes les commandes suivantes fonctionneront sur la base de données choisie.

Note- Tous les noms (par exemple, base de données, table, champs) sont sensibles à la casse. Assurez-vous que les commandes sont conformes au cas approprié.

Script de base de données PHP Select

PHP fournit le mysql_select_dbfonction de sélection de base de données. La fonction utilise deux paramètres, l'un facultatif, et renvoie la valeur «true» en cas de sélection réussie ou false en cas d'échec.

Syntaxe

Vérifiez la syntaxe de script de base de données de sélection suivante.

bool mysql_select_db( db_name, connection );

La description des paramètres est donnée ci-dessous -

S. Non Paramètre et description
1

db_name

Ce paramètre obligatoire spécifie le nom de la base de données à utiliser.

2

connection

Lorsqu'il n'est pas spécifié, ce paramètre facultatif utilise la connexion la plus récente utilisée.

Essayez l'exemple de code suivant pour sélectionner une base de données -

<html>
   <head>
      <title>Select a MariaDB Database</title>
   </head>

   <body>
      <?php
         $dbhost = 'localhost:3036'; $dbuser = 'guest1';
         $dbpass = 'guest1a'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
            die('Could not connect: ' . mysql_error());
         }
         echo 'Connected successfully';
         
         mysql_select_db( 'PRODUCTS' );
         mysql_close($conn);
      ?>
   </body>
</html>

En cas de sélection réussie, vous verrez la sortie suivante -

mysql> Connected successfully

De bonnes définitions de champs sont essentielles pour l'optimisation de votre base de données. L'approche idéale exige que vous utilisiez exclusivement un champ du type et de la taille nécessaires. Par exemple, si vous n'utilisez qu'un champ de cinq caractères de large, ne définissez pas de champ de 20 caractères. Les types de champ (ou de colonne) sont également appelés types de données compte tenu des types de données stockés dans le champ.

Les types de données MariaDB peuvent être classés en valeurs numériques, de date et d'heure et de chaîne.

Types de données numériques

Les types de données numériques pris en charge par MariaDB sont les suivants -

  • TINYINT - Ce type de données représente de petits entiers compris dans la plage signée de -128 à 127 et la plage non signée de 0 à 255.

  • BOOLEAN - Ce type de données associe une valeur 0 à «faux» et une valeur 1 à «vrai».

  • SMALLINT - Ce type de données représente des nombres entiers dans la plage signée de -32768 à 32768 et la plage non signée de 0 à 65535.

  • MEDIUMINT - Ce type de données représente des entiers dans la plage signée de -8388608 à 8388607 et la plage non signée de 0 à 16777215.

  • INT(also INTEGER)- Ce type de données représente un entier de taille normale. Lorsqu'elle est marquée comme non signée, la plage s'étend de 0 à 4294967295. Lorsqu'elle est signée (paramètre par défaut), la plage s'étend de -2147483648 à 2147483647. Lorsqu'une colonne est définie sur ZEROFILL (un état non signé), toutes ses valeurs sont précédées de zéros à placer M chiffres dans la valeur INT.

  • BIGINT - Ce type de données représente des nombres entiers dans la plage signée de 9223372036854775808 à 9223372036854775807 et la plage non signée de 0 à 18446744073709551615.

  • DECIMAL(également DEC, NUMERIC, FIXED) - Ce type de données représente des nombres à virgule fixe précis, avec M spécifiant ses chiffres et D spécifiant les chiffres après la décimale. La valeur M n'ajoute ni «-» ni le point décimal. Si D est défini sur 0, aucune partie décimale ou fractionnaire n'apparaît et la valeur sera arrondie au DECIMAL le plus proche sur INSERT. Le nombre maximum de chiffres autorisé est de 65 et le maximum pour les décimales est 30. La valeur par défaut pour M en cas d'omission est 10 et 0 pour D en cas d'omission.

  • FLOAT - Ce type de données représente un petit nombre à virgule flottante de la valeur 0 ou un nombre dans les plages suivantes -

    • -3.402823466E + 38 à -1.175494351E-38

    • 1.175494351E-38 à 3.402823466E + 38

  • DOUBLE (également REAL et DOUBLE PRECISION) - Ce type de données représente des nombres à virgule flottante de taille normale de la valeur 0 ou dans les plages suivantes -

    • -1,7976931348623157E + 308 à -2,2250738585072014E-308

    • 2.2250738585072014E-308 à 1.7976931348623157E + 308

  • BIT- Ce type de données représente des champs de bits avec M spécifiant le nombre de bits par valeur. En cas d'omission de M, la valeur par défaut est 1. Les valeurs de bit peuvent être appliquées avec «b '[valeur]» »dans laquelle la valeur représente la valeur de bit en 0 et 1. Le remplissage à zéro se produit automatiquement à partir de la gauche sur toute la longueur; par exemple, «10» devient «0010».

Types de données de date et d'heure

Les types de données de date et d'heure pris en charge par MariaDB sont les suivants:

  • DATE - Ce type de données représente une plage de dates allant de «1000-01-01» à «9999-12-31» et utilise le format de date «AAAA-MM-JJ».

  • TIME - Ce type de données représente une plage de temps comprise entre «-838: 59: 59,999999» et «838: 59: 59,999999».

  • DATETIME- Ce type de données représente la plage «1000-01-01 00: 00: 00.000000» à «9999-12-31 23: 59: 59.999999». Il utilise le format «AAAA-MM-JJ HH: MM: SS».

  • TIMESTAMP- Ce type de données représente un horodatage au format «AAAA-MM-JJ HH: MM: JJ». Il trouve principalement son utilité pour détailler l'heure des modifications de la base de données, par exemple l'insertion ou la mise à jour.

  • YEAR- Ce type de données représente une année au format à 4 chiffres. Le format à quatre chiffres autorise des valeurs comprises entre 1901 et 2155 et 0000.

DataTypes de chaîne

Les valeurs de type de chaîne prises en charge par MariaDB sont les suivantes -

  • String literals - Ce type de données représente des séquences de caractères entre guillemets.

  • CHAR- Ce type de données représente une chaîne de longueur fixe complétée à droite contenant des espaces de longueur spécifiée. M représente la longueur de colonne de caractères dans une plage de 0 à 255, sa valeur par défaut est 1.

  • VARCHAR - Ce type de données représente une chaîne de longueur variable, avec une plage M (longueur de colonne maximale) de 0 à 65535.

  • BINARY - Ce type de données représente des chaînes d'octets binaires, avec M comme longueur de colonne en octets.

  • VARBINARY - Ce type de données représente des chaînes d'octets binaires de longueur variable, avec M comme longueur de colonne.

  • TINYBLOB- Ce type de données représente une colonne blob d'une longueur maximale de 255 (28 - 1) octets. Dans le stockage, chacun utilise un préfixe de longueur d'un octet indiquant la quantité d'octets dans la valeur.

  • BLOB- Ce type de données représente une colonne blob d'une longueur maximale de 65 535 (216 - 1) octets. Dans le stockage, chacun utilise un préfixe de longueur de deux octets indiquant la quantité d'octets dans la valeur.

  • MEDIUMBLOB- Ce type de données représente une colonne blob d'une longueur maximale de 16 777 215 (2 24 - 1) octets. Dans le stockage, chacun utilise un préfixe de longueur de trois octets indiquant la quantité d'octets dans la valeur.

  • LONGBLOB- Ce type de données représente une colonne blob d'une longueur maximale de 4 294 967 295 (2 32 - 1) octets. Dans le stockage, chacun utilise un préfixe de longueur de quatre octets indiquant la quantité d'octets dans la valeur.

  • TINYTEXT- Ce type de données représente une colonne de texte d'une longueur maximale de 255 (2 8 - 1) caractères. Dans le stockage, chacun utilise un préfixe de longueur d'un octet indiquant la quantité d'octets dans la valeur.

  • TEXT- Ce type de données représente une colonne de texte d'une longueur maximale de 65 535 (2 16 - 1) caractères. Dans le stockage, chacun utilise un préfixe de longueur de deux octets indiquant la quantité d'octets dans la valeur.

  • MEDIUMTEXT- Ce type de données représente une colonne de texte d'une longueur maximale de 16 777 215 (2 24 - 1) caractères. Dans le stockage, chacun utilise un préfixe de longueur de trois octets indiquant la quantité d'octets dans la valeur.

  • LONGTEXT- Ce type de données représente une colonne de texte d'une longueur maximale de 4 294 967 295 ou 4 Go (2 32 - 1) caractères. Dans le stockage, chacun utilise un préfixe de longueur de quatre octets indiquant la quantité d'octets dans la valeur.

  • ENUM - Ce type de données représente un objet chaîne n'ayant qu'une seule valeur dans une liste.

  • SET- Ce type de données représente un objet chaîne ayant zéro ou plusieurs valeurs dans une liste, avec un maximum de 64 membres. Les valeurs SET sont présentées en interne sous forme de valeurs entières.

Dans ce chapitre, nous allons apprendre à créer des tables. Avant de créer une table, déterminez d'abord son nom, les noms de champ et les définitions de champ.

Voici la syntaxe générale pour la création de table -

CREATE TABLE table_name (column_name column_type);

Vérifiez la commande appliquée à la création d'une table dans la base de données PRODUCTS -

databaseproducts_ tbl(
   product_id INT NOT NULL AUTO_INCREMENT,
   product_name VARCHAR(100) NOT NULL,
   product_manufacturer VARCHAR(40) NOT NULL,
   submission_date DATE,
   PRIMARY KEY ( product_id )
);

L'exemple ci-dessus utilise «NOT NULL» comme attribut de champ pour éviter les erreurs causées par une valeur nulle. L'attribut «AUTO_INCREMENT» demande à MariaDB d'ajouter la prochaine valeur disponible au champ ID. Le mot-clé clé primaire définit une colonne commeprimary key. Plusieurs colonnes séparées par des virgules peuvent définir une clé primaire.

Les deux principales méthodes de création de tables utilisent l'invite de commande et un script PHP.

L'invite de commande

Utilisez la commande CREATE TABLE pour effectuer la tâche comme indiqué ci-dessous -

root@host# mysql -u root -p
Enter password:*******
mysql> use PRODUCTS;
Database changed
mysql> CREATE TABLE products_tbl(
   -> product_id INT NOT NULL AUTO_INCREMENT,
   -> product_name VARCHAR(100) NOT NULL,
   -> product_manufacturer VARCHAR(40) NOT NULL,
   -> submission_date DATE,
   -> PRIMARY KEY ( product_id )
   -> );
mysql> SHOW TABLES;
+------------------------+
| PRODUCTS               |
+------------------------+
| products_tbl           |
+------------------------+

Assurez-vous que toutes les commandes se terminent par un point-virgule.

Script de création de table PHP

PHP fournit mysql_query()pour la création de table. Son deuxième argument contient la commande SQL nécessaire -

<html>
   <head>
      <title>Create a MariaDB Table</title>
   </head>

   <body>
      <?php
         $dbhost = 'localhost:3036';
         $dbuser = 'root'; $dbpass = 'rootpassword';
         $conn = mysql_connect($dbhost, $dbuser, $dbpass);
      
         if(! $conn ){ die('Could not connect: ' . mysql_error()); } echo 'Connected successfully<br />'; $sql = "CREATE TABLE products_tbl( ".
            "product_id INT NOT NULL AUTO_INCREMENT, ".
            "product_name VARCHAR(100) NOT NULL, ".
            "product_manufacturer VARCHAR(40) NOT NULL, ".
            "submission_date DATE, ".
            "PRIMARY KEY ( product_id )); ";
      
         mysql_select_db( 'PRODUCTS' );
         $retval = mysql_query( $sql, $conn ); if(! $retval ) {
            die('Could not create table: ' . mysql_error());
         }
         echo "Table created successfully\n";
         
         mysql_close($conn);
      ?>
   </body>
</html>

Une fois la création de la table réussie, vous verrez la sortie suivante -

mysql> Table created successfully

Dans ce chapitre, nous allons apprendre à supprimer des tables.

La suppression de table est très simple, mais rappelez-vous que toutes les tables supprimées sont irrécupérables. La syntaxe générale pour la suppression de table est la suivante -

DROP TABLE table_name ;

Deux options existent pour effectuer une suppression de table: utilisez l'invite de commande ou un script PHP.

L'invite de commande

À l'invite de commande, utilisez simplement le DROP TABLE Commande SQL -

root@host# mysql -u root -p
Enter password:*******
mysql> use PRODUCTS;
Database changed
mysql> DROP TABLE products_tbl

mysql> SELECT * from products_tbl
ERROR 1146 (42S02): Table 'products_tbl' doesn't exist

Script de suppression de table PHP

PHP fournit mysql_query()pour déposer des tables. Passez simplement son deuxième argument la commande SQL appropriée -

<html>
   <head>
      <title>Create a MariaDB Table</title>
   </head>

   <body>
      <?php
         $dbhost = 'localhost:3036';
         $dbuser = 'root'; $dbpass = 'rootpassword';
         $conn = mysql_connect($dbhost, $dbuser, $dbpass);
         
         if(! $conn ) { die('Could not connect: ' . mysql_error()); } echo 'Connected successfully<br />'; $sql = "DROP TABLE products_tbl";
         mysql_select_db( 'PRODUCTS' );
         $retval = mysql_query( $sql, $conn ); if(! $retval ) {
            die('Could not delete table: ' . mysql_error());
         }
         echo "Table deleted successfully\n";
         
         mysql_close($conn);
      ?>
   </body>
</html>

En cas de suppression réussie de la table, vous verrez la sortie suivante -

mysql> Table deleted successfully

Dans ce chapitre, nous allons apprendre à insérer des données dans un tableau.

L'insertion de données dans une table nécessite la commande INSERT. La syntaxe générale de la commande est INSERT suivi du nom de la table, des champs et des valeurs.

Revoyez sa syntaxe générale donnée ci-dessous -

INSERT INTO tablename (field,field2,...) VALUES (value, value2,...);

L'instruction nécessite l'utilisation de guillemets simples ou doubles pour les valeurs de chaîne. Les autres options de l'instruction incluent les instructions «INSERT ... SET», les instructions «INSERT ... SELECT» et plusieurs autres options.

Note - La fonction VALUES () qui apparaît dans l'instruction, s'applique uniquement aux instructions INSERT et renvoie NULL si elle est utilisée ailleurs.

Deux options existent pour effectuer l'opération: utiliser la ligne de commande ou utiliser un script PHP.

L'invite de commande

À l'invite, il existe de nombreuses façons d'effectuer une opération de sélection. Une déclaration standard est donnée ci-dessous -

belowmysql>
INSERT INTO products_tbl (ID_number, Nomenclature) VALUES (12345,“Orbitron 4000”);
mysql> SHOW COLUMNS FROM products_tbl;
+-------------+-------------+------+-----+---------+-------+
| Field       | Type        | Null | Key | Default | Extra |
+-------------+-------------+------+-----+---------+-------+
| ID_number   | int(5)      |      |     |         |       |
| Nomenclature| char(13)    |      |     |         |       |
+-------------+-------------+------+-----+---------+-------+

Vous pouvez insérer plusieurs lignes -

INSERT INTO products VALUES (1, “first row”), (2, “second row”);

Vous pouvez également utiliser la clause SET -

INSERT INTO products SELECT * FROM inventory WHERE status = 'available';

Script d'insertion PHP

Utilisez la même instruction «INSERT INTO ...» dans une fonction PHP pour effectuer l'opération. Vous utiliserez lemysql_query() fonctionner à nouveau.

Revoyez l'exemple ci-dessous -

<?php
   if(isset($_POST['add'])) {
      $dbhost = 'localhost:3036'; $dbuser = 'root';
      $dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
         die('Could not connect: ' . mysql_error());
      }

      if(! get_magic_quotes_gpc() ) {
         $product_name = addslashes ($_POST['product_name']);
         $product_manufacturer = addslashes ($_POST['product_name']);
      } else {
         $product_name = $_POST['product_name'];
         $product_manufacturer = $_POST['product_manufacturer'];
      }
      $ship_date = $_POST['ship_date'];
      $sql = "INSERT INTO products_tbl ". "(product_name,product_manufacturer, ship_date) ". "VALUES"."('$product_name','$product_manufacturer','$ship_date')";

      mysql_select_db('PRODUCTS');
      $retval = mysql_query( $sql, $conn ); if(! $retval ) {
         die('Could not enter data: ' . mysql_error());
      }

      echo "Entered data successfully\n";
      mysql_close($conn);
   }
?>

Lors de l'insertion de données réussie, vous verrez la sortie suivante -

mysql> Entered data successfully

Vous collaborerez également des déclarations de validation avec des instructions d'insertion telles que la vérification pour garantir une saisie correcte des données. MariaDB inclut un certain nombre d'options à cet effet, dont certaines sont automatiques.

Dans ce chapitre, nous allons apprendre à sélectionner des données dans une table.

Les instructions SELECT récupèrent les lignes sélectionnées. Ils peuvent inclure des instructions UNION, une clause de tri, une clause LIMIT, une clause WHERE, une clause GROUP BY ... HAVING et des sous-requêtes.

Passez en revue la syntaxe générale suivante -

SELECT field, field2,... FROM table_name, table_name2,... WHERE...

Une instruction SELECT fournit plusieurs options pour spécifier la table utilisée -

  • database_name.table_name

  • table_name.column_name

  • database_name.table_name.column_name

Toutes les instructions select doivent contenir une ou plusieurs select expressions. Les expressions Select se composent de l'une des options suivantes -

  • Un nom de colonne.

  • Une expression employant des opérateurs et des fonctions.

  • La spécification «nom_table. *» Pour sélectionner toutes les colonnes de la table donnée.

  • Le caractère «*» pour sélectionner toutes les colonnes de toutes les tables spécifiées dans la clause FROM.

L'invite de commande ou un script PHP peut être utilisé pour exécuter une instruction select.

L'invite de commande

À l'invite de commande, exécutez les instructions comme suit -

root@host# mysql -u root -p password;
Enter password:*******
mysql> use PRODUCTS;
Database changed
mysql> SELECT * from products_tbl
+-------------+---------------+
| ID_number   | Nomenclature  |
+-------------+---------------+
| 12345       | Orbitron 4000 |
+-------------+---------------+

Script de sélection PHP

Employez la ou les mêmes instructions SELECT dans une fonction PHP pour effectuer l'opération. Vous utiliserez lemysql_query()fonctionner à nouveau. Passez en revue un exemple donné ci-dessous -

<?php
   $dbhost = 'localhost:3036';
   $dbuser = 'root'; $dbpass = 'rootpassword';
   $conn = mysql_connect($dbhost, $dbuser, $dbpass);
   
   if(! $conn ) { die('Could not connect: ' . mysql_error()); } $sql = 'SELECT product_id, product_name,product_manufacturer, ship_date FROM products_tbl';
   mysql_select_db('PRODUCTS');
   $retval = mysql_query( $sql, $conn ); if(! $retval ) {
      die('Could not get data: ' . mysql_error());
   }

   while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) {
      echo "Product ID :{$row['product_id']} <br> ". "Name: {$row['product_name']} <br> ".
         "Manufacturer: {$row['product_manufacturer']} <br> ". "Ship Date : {$row['ship_date']} <br>".
         "--------------------------------<br>";
   }

   echo "Fetched data successfully\n";
   mysql_close($conn);
?>

Lors de la récupération des données réussie, vous verrez la sortie suivante -

Product ID: 12345
Nomenclature: Orbitron 4000
Manufacturer: XYZ Corp
Ship Date: 01/01/17
----------------------------------------------
Product ID: 12346
Nomenclature: Orbitron 3000
Manufacturer: XYZ Corp
Ship Date: 01/02/17
----------------------------------------------
mysql> Fetched data successfully

Les meilleures pratiques suggèrent de libérer la mémoire du curseur après chaque instruction SELECT. PHP fournit lemysql_free_result()fonction à cet effet. Vérifiez son utilisation comme indiqué ci-dessous -

<?php
   $dbhost = 'localhost:3036';
   $dbuser = 'root'; $dbpass = 'rootpassword';
   $conn = mysql_connect($dbhost, $dbuser, $dbpass);
   
   if(! $conn ) { die('Could not connect: ' . mysql_error()); } $sql = 'SELECT product_id, product_name, product_manufacturer, ship_date FROM products_tbl';
   mysql_select_db('PRODUCTS');
   $retval = mysql_query( $sql, $conn ); if(! $retval ) {
      die('Could not get data: ' . mysql_error());
   }

   while($row = mysql_fetch_array($retval, MYSQL_NUM)) {
      echo "Product ID :{$row[0]} <br> ". "Name: {$row[1]} <br> ".
         "Manufacturer: {$row[2]} <br> ". "Ship Date : {$row[3]} <br> ".
         "--------------------------------<br>";
   }

   mysql_free_result($retval); echo "Fetched data successfully\n"; mysql_close($conn);
?>

WHEREles clauses filtrent diverses instructions telles que SELECT, UPDATE, DELETE et INSERT. Ils présentent les critères utilisés pour spécifier l'action. Ils apparaissent généralement après un nom de table dans une instruction et leur condition suit. La clause WHERE fonctionne essentiellement comme une instruction if.

Passez en revue la syntaxe générale de la clause WHERE donnée ci-dessous -

[COMMAND] field,field2,... FROM table_name,table_name2,... WHERE [CONDITION]

Notez les qualités suivantes de la clause WHERE -

  • C'est facultatif.

  • Il permet de spécifier n'importe quelle condition.

  • Il permet de spécifier plusieurs conditions en utilisant un opérateur AND ou OR.

  • Le respect de la casse ne s'applique qu'aux instructions utilisant des comparaisons LIKE.

La clause WHERE autorise l'utilisation des opérateurs suivants -

Opérateur
=! =
> <
> = <=

Les clauses WHERE peuvent être utilisées à l'invite de commande ou dans un script PHP.

L'invite de commande

À l'invite de commande, utilisez simplement une commande standard -

root@host# mysql -u root -p password;
Enter password:*******
mysql> use PRODUCTS;
Database changed
mysql> SELECT * from products_tbl WHERE product_manufacturer = 'XYZ Corp';
+-------------+----------------+----------------------+
| ID_number   | Nomenclature   | product_manufacturer |
+-------------+----------------+----------------------+
| 12345       | Orbitron 4000  | XYZ Corp             |
+-------------+----------------+----------------------+
| 12346       | Orbitron 3000  | XYZ Corp             |
+-------------+----------------+----------------------+
| 12347       | Orbitron 1000  | XYZ Corp             |
+-------------+----------------+----------------------+

Passez en revue un exemple utilisant le AND état -

SELECT *
FROM products_tbl
WHERE product_name = 'Bun Janshu 3000';
AND product_id <= 344;

Cet exemple combine les conditions ET et OU

SELECT *
FROM products_tbl
WHERE (product_name = 'Bun Janshu 3000' AND product_id < 344)
OR (product_name = 'Bun Janshu 3000');

Scripts PHP utilisant la clause Where

Employer le mysql_query() fonction dans les opérations utilisant une clause WHERE -

<?php
   $dbhost = 'localhost:3036'; $dbuser = 'root';
   $dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
      die('Could not connect: ' . mysql_error());
   }

   $sql = 'SELECT product_id, product_name, product_manufacturer, ship_date FROM products_tbl WHERE product_manufacturer = "XYZ Corp"'; mysql_select_db('PRODUCTS'); $retval = mysql_query( $sql, $conn );
   
   if(! $retval ) { die('Could not get data: ' . mysql_error()); } while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) { echo "Product ID :{$row['product_id']} <br> ".
         "Name: {$row['product_name']} <br> ". "Manufacturer: {$row['product_manufacturer']} <br> ".
         "Ship Date: {$row['ship_date']} <br> ". "--------------------------------<br>"; } echo "Fetched data successfully\n"; mysql_close($conn);
?>

Lors de la récupération des données réussie, vous verrez la sortie suivante -

Product ID: 12345
Nomenclature: Orbitron 4000
Manufacturer: XYZ Corp
Ship Date: 01/01/17
----------------------------------------------
Product ID: 12346
Nomenclature: Orbitron 3000
Manufacturer: XYZ Corp
Ship Date: 01/02/17
----------------------------------------------
Product ID: 12347
Nomenclature: Orbitron 1000
Manufacturer: XYZ Corp
Ship Date: 01/02/17
----------------------------------------------
mysql> Fetched data successfully

le UPDATELa commande modifie les champs existants en changeant les valeurs. Il utilise la clause SET pour spécifier les colonnes à modifier et pour spécifier les nouvelles valeurs affectées. Ces valeurs peuvent être une expression ou la valeur par défaut du champ. La définition d'une valeur par défaut nécessite l'utilisation du mot clé DEFAULT. La commande peut également utiliser une clause WHERE pour spécifier les conditions d'une mise à jour et / ou une clause ORDER BY à mettre à jour dans un certain ordre.

Passez en revue la syntaxe générale suivante -

UPDATE table_name SET field=new_value, field2=new_value2,...
[WHERE ...]

Exécutez une commande UPDATE à partir de l'invite de commande ou à l'aide d'un script PHP.

L'invite de commande

À l'invite de commande, utilisez simplement une racine de commande standard -

root@host# mysql -u root -p password;
Enter password:*******
mysql> use PRODUCTS;
Database changed
mysql> UPDATE products_tbl
   SET nomenclature = 'Fiber Blaster 300Z' WHERE ID_number = 112;
mysql> SELECT * from products_tbl WHERE ID_number='112';
+-------------+---------------------+----------------------+
| ID_number   | Nomenclature        | product_manufacturer |
+-------------+---------------------+----------------------+
| 112         | Fiber Blaster 300Z  | XYZ Corp             |
+-------------+---------------------+----------------------+

Script de requête de mise à jour PHP

Employer le mysql_query() fonction dans les instructions de commande UPDATE -

<?php
   $dbhost = ‘localhost:3036’; $dbuser = ‘root’;
   $dbpass = ‘rootpassword’; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
      die(‘Could not connect: ‘ . mysql_error());
   }

   $sql = ‘UPDATE products_tbl SET product_name = ”Fiber Blaster 300z” WHERE product_id = 112’; mysql_select_db(‘PRODUCTS’); $retval = mysql_query( $sql, $conn );

   if(! $retval ) { die(‘Could not update data: ‘ . mysql_error()); } echo “Updated data successfully\n”; mysql_close($conn);
?>

Une fois la mise à jour des données réussie, vous verrez la sortie suivante -

mysql> Updated data successfully

La commande DELETE supprime les lignes de table de la table spécifiée et renvoie la quantité supprimée. Accédez à la quantité supprimée avec la fonction ROW_COUNT (). Une clause WHERE spécifie des lignes, et en son absence, toutes les lignes sont supprimées. Une clause LIMIT contrôle le nombre de lignes supprimées.

Dans une instruction DELETE pour plusieurs lignes, elle supprime uniquement les lignes satisfaisant à une condition; et les clauses LIMIT et WHERE ne sont pas autorisées. Les instructions DELETE permettent de supprimer des lignes de tables dans différentes bases de données, mais n'autorisent pas la suppression d'une table, puis la sélection à partir de la même table dans une sous-requête.

Vérifiez la syntaxe DELETE suivante -

DELETE FROM table_name [WHERE …]

Exécutez une commande DELETE à partir de l'invite de commande ou à l'aide d'un script PHP.

L'invite de commande

À l'invite de commande, utilisez simplement une commande standard -

root@host# mysql –u root –p password;
Enter password:*******
mysql> use PRODUCTS;
Database changed
mysql> DELETE FROM products_tbl WHERE product_id=133;
mysql> SELECT * from products_tbl WHERE ID_number='133';
ERROR 1032 (HY000): Can't find record in 'products_tbl'

Script de requête de suppression PHP

Utilisez le mysql_query() fonction dans les instructions de commande DELETE -

<?php
   $dbhost = 'localhost:3036'; $dbuser = 'root';
   $dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
      die('Could not connect: ' . mysql_error());
   }

   $sql = 'DELETE FROM products_tbl WHERE product_id = 261'; mysql_select_db('PRODUCTS'); $retval = mysql_query( $sql, $conn );

   if(! $retval ) { die('Could not delete data: ' . mysql_error()); } echo "Deleted data successfully\n"; mysql_close($conn);
?>

En cas de suppression des données réussie, vous verrez la sortie suivante -

mysql> Deleted data successfully
mysql> SELECT * from products_tbl WHERE ID_number='261';
ERROR 1032 (HY000): Can't find record in 'products_tbl'

La clause WHERE fournit un moyen de récupérer des données lorsqu'une opération utilise une correspondance exacte. Dans les situations nécessitant des résultats multiples avec des caractéristiques communes, leLIKE la clause accepte une large correspondance de motifs.

Une clause LIKE teste une correspondance de modèle, renvoyant un vrai ou un faux. Les modèles utilisés pour la comparaison acceptent les caractères génériques suivants: «%», qui correspond à des nombres de caractères (0 ou plus); et «_», qui correspond à un seul caractère. Le caractère générique «_» correspond uniquement aux caractères de son ensemble, ce qui signifie qu'il ignorera les caractères latins lors de l'utilisation d'un autre ensemble. Les correspondances sont insensibles à la casse par défaut, ce qui nécessite des paramètres supplémentaires pour la sensibilité à la casse.

Une clause NOT LIKE permet de tester la condition opposée, un peu comme la not opérateur.

Si l'expression d'instruction ou le modèle est évalué à NULL, le résultat est NULL.

Passez en revue la syntaxe générale de la clause LIKE donnée ci-dessous -

SELECT field, field2,... FROM table_name, table_name2,...
WHERE field LIKE condition

Utilisez une clause LIKE à l'invite de commande ou dans un script PHP.

L'invite de commande

À l'invite de commande, utilisez simplement une commande standard -

root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed
mysql> SELECT * from products_tbl
   WHERE product_manufacturer LIKE 'XYZ%';
+-------------+----------------+----------------------+
| ID_number   | Nomenclature   | product_manufacturer |
+-------------+----------------+----------------------+
| 12345       | Orbitron 4000  | XYZ Corp             |
+-------------+----------------+----------------------+
| 12346       | Orbitron 3000  | XYZ Corp             |
+-------------+----------------+----------------------+
| 12347       | Orbitron 1000  | XYZ Corp             |
+-------------+----------------+----------------------+

Script PHP utilisant la clause Like

Utilisez le mysql_query() fonction dans les instructions utilisant la clause LIKE

<?php
   $dbhost = 'localhost:3036'; $dbuser = 'root';
   $dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
      die('Could not connect: ' . mysql_error());
   }

   $sql = 'SELECT product_id, product_name, product_manufacturer, ship_date FROM products_tbl WHERE product_manufacturer LIKE "xyz%"'; mysql_select_db('PRODUCTS'); $retval = mysql_query( $sql, $conn );
   
   if(! $retval ) { die('Could not get data: ' . mysql_error()); } while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) { echo "Product ID:{$row['product_id']} <br> ".
         "Name: {$row['product_name']} <br> ". "Manufacturer: {$row['product_manufacturer']} <br> ".
         "Ship Date: {$row['ship_date']} <br> ". "--------------------------------<br>"; } echo "Fetched data successfully\n"; mysql_close($conn);
?>

Lors de la récupération des données réussie, vous verrez la sortie suivante -

Product ID: 12345
Nomenclature: Orbitron 4000
Manufacturer: XYZ Corp
Ship Date: 01/01/17
----------------------------------------------
Product ID: 12346
Nomenclature: Orbitron 3000
Manufacturer: XYZ Corp
Ship Date: 01/02/17
----------------------------------------------
Product ID: 12347
Nomenclature: Orbitron 1000
Manufacturer: XYZ Corp
Ship Date: 01/02/17
----------------------------------------------
mysql> Fetched data successfully

le ORDER BYcomme mentionné dans les discussions précédentes, trie les résultats d'une déclaration. Il spécifie l'ordre des données opérées et inclut la possibilité de trier par ordre croissant (ASC) ou décroissant (DESC). En cas d'omission de la spécification de commande, l'ordre par défaut est croissant.

Les clauses ORDER BY apparaissent dans une grande variété d'instructions telles que DELETE et UPDATE. Ils apparaissent toujours à la fin d'une instruction, pas dans une sous-requête ou avant une fonction set, car ils opèrent sur la table finale résultante. Vous ne pouvez pas non plus utiliser un entier pour identifier une colonne.

Passez en revue la syntaxe générale de la clause ORDER BY donnée ci-dessous -

SELECT field, field2,... [or column] FROM table_name, table_name2,...
ORDER BY field, field2,... ASC[or DESC]

Utilisez une clause ORDER BY à l'invite de commande ou dans un script PHP.

L'invite de commande

À l'invite de commande, utilisez simplement une commande standard -

root@ host# mysql -u root -p password;
Enter password:*******
mysql> use PRODUCTS;
Database changed

mysql> SELECT * from products_tbl ORDER BY product_manufacturer ASC
+-------------+----------------+----------------------+
| ID_number   | Nomenclature   | product_manufacturer |
+-------------+----------------+----------------------+
| 56789       | SuperBlast 400 | LMN Corp             |
+-------------+----------------+----------------------+
| 67891       | Zoomzoom 5000  | QFT Corp             |
+-------------+----------------+----------------------+
| 12347       | Orbitron 1000  | XYZ Corp             |
+-------------+----------------+----------------------+

Script PHP utilisant la clause Order By

Utilisez le mysql_query() fonction, encore une fois, dans les instructions employant la clause ORDER BY -

<?php
   $dbhost = 'localhost:3036'; $dbuser = 'root';
   $dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
      die('Could not connect: ' . mysql_error());
   }

   $sql = 'SELECT product_id, product_name, product_manufacturer, ship_date FROM products_tbl ORDER BY product_manufacturer DESC'; mysql_select_db('PRODUCTS'); $retval = mysql_query( $sql, $conn );

   if(! $retval ) { die('Could not get data: ' . mysql_error()); } while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) { echo "Product ID :{$row['product_id']} <br> ".
         "Name: {$row['product_name']} <br> ". "Manufacturer: {$row['product_manufacturer']} <br> ".
         "Ship Date : {$row['ship_date']} <br> ". "--------------------------------<br>"; } echo "Fetched data successfully\n"; mysql_close($conn);
?>

Lors de la récupération des données réussie, vous verrez la sortie suivante -

Product ID: 12347
Nomenclature: Orbitron 1000
Manufacturer: XYZ Corp
Ship Date: 01/01/17
----------------------------------------------
Product ID: 67891
Nomenclature: Zoomzoom 5000
Manufacturer: QFT Corp
Ship Date: 01/01/17
----------------------------------------------
Product ID: 56789
Nomenclature: SuperBlast 400
Manufacturer: LMN Corp
Ship Date: 01/04/17
----------------------------------------------
mysql> Fetched data successfully

Dans les discussions et exemples précédents, nous avons examiné la récupération à partir d'une seule table ou la récupération de plusieurs valeurs à partir de plusieurs sources. La plupart des opérations de données réelles sont beaucoup plus complexes et nécessitent une agrégation, une comparaison et une extraction à partir de plusieurs tables.

JOINsautorise la fusion de deux ou plusieurs tables en un seul objet. Ils sont utilisés via les instructions SELECT, UPDATE et DELETE.

Passez en revue la syntaxe générale d'une instruction employant un JOIN comme indiqué ci-dessous -

SELECT column
FROM table_name1
INNER JOIN table_name2
ON table_name1.column = table_name2.column;

Notez que l'ancienne syntaxe de JOINS utilisait des jointures implicites et aucun mot clé. Il est possible d'utiliser une clause WHERE pour réaliser une jointure, mais les mots clés fonctionnent le mieux pour la lisibilité, la maintenance et les meilleures pratiques.

Les jointures se présentent sous de nombreuses formes, telles qu'une jointure gauche, une jointure droite ou une jointure interne. Différents types de jointure offrent différents types d'agrégation basés sur des valeurs ou des caractéristiques partagées.

Utilisez un JOIN soit à l'invite de commande ou avec un script PHP.

L'invite de commande

À l'invite de commande, utilisez simplement une instruction standard -

root@host# mysql -u root -p password;
Enter password:*******
mysql> use PRODUCTS;
Database changed

mysql> SELECT products.ID_number, products.Nomenclature, inventory.inventory_ct
   FROM products
   INNER JOIN inventory
   ON products.ID_numbeer = inventory.ID_number;
+-------------+----------------+-----------------+
| ID_number   | Nomenclature   | Inventory Count |
+-------------+----------------+-----------------+
| 12345       | Orbitron 4000  | 150             |
+-------------+----------------+-----------------+
| 12346       | Orbitron 3000  | 200             |
+-------------+----------------+-----------------+
| 12347       | Orbitron 1000  | 0               |
+-------------+----------------+-----------------+

Script PHP utilisant JOIN

Utilisez le mysql_query() fonction pour effectuer une opération de jointure -

<?php
   $dbhost = 'localhost:3036'; $dbuser = 'root';
   $dbpass = 'rootpassword'; $conn = mysql_connect($dbhost, $dbuser, $dbpass); if(! $conn ) {
      die('Could not connect: ' . mysql_error());
   }

   $sql = 'SELECT a.product_id, a.product_manufacturer, b.product_count FROM products_tbl a, pcount_tbl b WHERE a.product_manufacturer = b.product_manufacturer'; mysql_select_db('PRODUCTS'); $retval = mysql_query( $sql, $conn );

   if(! $retval ) { die('Could not get data: ' . mysql_error()); } while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) { echo "Manufacturer:{$row['product_manufacturer']} <br> ".
         "Count: {$row['product_count']} <br> ". "Product ID: {$row['product_id']} <br> ".
         "--------------------------------<br>";
   }

   echo "Fetched data successfully\n";
   mysql_close($conn);
?>

Lors de la récupération des données réussie, vous verrez la sortie suivante -

ID Number: 12345
Nomenclature: Orbitron 4000
Inventory Count: 150
--------------------------------------
ID Number: 12346
Nomenclature: Orbitron 3000
Inventory Count: 200
--------------------------------------
ID Number: 12347
Nomenclature: Orbitron 1000
Inventory Count: 0
--------------------------------------
mysql> Fetched data successfully

Lorsque vous travaillez avec des valeurs NULL, n'oubliez pas qu'il s'agit de valeurs inconnues. Ce ne sont pas des chaînes vides ou zéro, qui sont des valeurs valides. Lors de la création de table, les spécifications de colonne permettent de les définir pour accepter des valeurs nulles ou de les rejeter. Utilisez simplement une clause NULL ou NOT NULL. Cela a des applications en cas d'informations d'enregistrement manquantes comme un numéro d'identification.

Les variables définies par l'utilisateur ont une valeur NULL jusqu'à une affectation explicite. Les paramètres de routine stockés et les variables locales permettent de définir une valeur NULL. Lorsqu'une variable locale n'a pas de valeur par défaut, elle a la valeur NULL.

NULL est insensible à la casse et possède les alias suivants -

  • INCONNU (une valeur booléenne)
  • \N

Opérateurs NULL

Les opérateurs de comparaison standard ne peuvent pas être utilisés avec NULL (par exemple, =,>,> =, <=, <ou! =) Car toutes les comparaisons avec une valeur NULL renvoient NULL, ni vrai ni faux. Les comparaisons avec NULL ou le contenant éventuellement doivent utiliser l'opérateur «<=>» (NULL-SAFE).

Les autres opérateurs disponibles sont -

  • IS NULL - Il teste une valeur NULL.

  • IS NOT NULL - Il confirme l'absence d'une valeur NULL.

  • ISNULL - Il renvoie une valeur de 1 lors de la découverte d'une valeur NULL et de 0 en son absence.

  • COALESCE - Il renvoie la première valeur non-NULL d'une liste, ou il renvoie une valeur NULL en l'absence d'un.

Tri des valeurs NULL

Dans les opérations de tri, les valeurs NULL ont la valeur la plus basse, donc l'ordre DESC se traduit par des valeurs NULL en bas. MariaDB permet de définir une valeur plus élevée pour les valeurs NULL.

Il y a deux façons de le faire, comme indiqué ci-dessous -

SELECT column1 FROM product_tbl ORDER BY ISNULL(column1), column1;

L'autre façon -

SELECT column1 FROM product_tbl ORDER BY IF(column1 IS NULL, 0, 1), column1 DESC;

Fonctions NULL

Les fonctions affichent généralement NULL lorsque l'un des paramètres est NULL. Cependant, il existe des fonctions spécialement conçues pour gérer les valeurs NULL. Ils sont -

  • IFNULL()- Si la première expression n'est pas NULL, elle la renvoie. Lorsqu'il est évalué à NULL, il renvoie la deuxième expression.

  • NULLIF() - Il renvoie NULL lorsque les expressions comparées sont égales, sinon, il renvoie la première expression.

Les fonctions telles que SUM et AVG ignorent les valeurs NULL.

Insertion de valeurs NULL

Lors de l'insertion d'une valeur NULL dans une colonne déclarée NOT NULL, une erreur se produit. En mode SQL par défaut, une colonne NOT NULL insérera à la place une valeur par défaut basée sur le type de données.

Lorsqu'un champ est une colonne TIMESTAMP, AUTO_INCREMENT ou virtuelle, MariaDB gère les valeurs NULL différemment. L'insertion dans une colonne AUTO_INCREMENT entraîne l'insertion du numéro suivant de la séquence à sa place. Dans un champ TIMESTAMP, MariaDB affecte à la place l'horodatage actuel. Dans les colonnes virtuelles, un sujet abordé plus loin dans ce didacticiel, la valeur par défaut est attribuée.

Les index UNIQUE peuvent contenir de nombreuses valeurs NULL, cependant, les clés primaires ne peuvent pas être NULL.

Valeurs NULL et la commande Alter

Lorsque vous utilisez la commande ALTER pour modifier une colonne, en l'absence de spécifications NULL, MariaDB affecte automatiquement des valeurs.

Au-delà de la correspondance de modèle disponible à partir des clauses LIKE, MariaDB propose une correspondance basée sur des expressions régulières via l'opérateur REGEXP. L'opérateur effectue une correspondance de modèle pour une expression de chaîne basée sur un modèle donné.

MariaDB 10.0.5 a introduit les expressions régulières PCRE, ce qui augmente considérablement la portée de la correspondance dans des domaines tels que les modèles récursifs, les assertions d'anticipation, etc.

Passez en revue l'utilisation de la syntaxe d'opérateur REGEXP standard donnée ci-dessous -

SELECT column FROM table_name WHERE column REGEXP '[PATTERN]';

REGEXP renvoie 1 pour une correspondance de modèle ou 0 en l'absence d'un.

Une option pour le contraire existe sous la forme de NOT REGEXP. MariaDB propose également des synonymes de REGEXP et NOT REGEXP, RLIKE et NOT RLIKE, qui ont été créés pour des raisons de compatibilité.

Le modèle comparé peut être une chaîne littérale ou autre chose comme une colonne de table. Dans les chaînes, il utilise la syntaxe d'échappement C, donc doublez tous les caractères «\». REGEXP est également insensible à la casse, à l'exception des chaînes binaires.

Un tableau des modèles possibles, qui peuvent être utilisés est donné ci-dessous -

Sr.Non Modèle et description
1

^

Il correspond au début de la chaîne.

2

$

Il correspond à la fin de la chaîne.

3

.

Il correspond à un seul caractère.

4

[...]

Il correspond à n'importe quel caractère entre crochets.

5

[^...]

Il correspond à tout caractère non répertorié entre crochets.

6

p1|p2|p3

Il correspond à n'importe lequel des modèles.

sept

*

Il correspond à 0 ou plusieurs instances de l'élément précédent.

8

+

Il correspond à une ou plusieurs instances de l'élément précédent.

9

{n}

Il correspond à n instances de l'élément précédent.

dix

{m,n}

Il fait correspondre m à n instances de l'élément précédent.

Passez en revue les exemples de correspondance de modèles donnés ci-dessous -

Produits commençant par «pr» -

SELECT name FROM product_tbl WHERE name REGEXP '^pr';

Produits se terminant par «na» -

SELECT name FROM product_tbl WHERE name REGEXP 'na$';

Produits commençant par une voyelle -

SELECT name FROM product_tbl WHERE name REGEXP '^[aeiou]';

Les transactions sont des opérations de groupe séquentielles. Ils fonctionnent comme une seule unité et ne se terminent que lorsque toutes les opérations du groupe s'exécutent avec succès. Un seul échec dans le groupe entraîne l'échec de la transaction entière et la fait n'avoir aucun impact sur la base de données.

Les transactions sont conformes à ACID (atomicité, cohérence, isolation et durabilité) -

  • Atomicity - Il assure le succès de toutes les opérations en annulant en cas de panne et en annulant les modifications.

  • Consistency - Il garantit que la base de données applique les modifications à une transaction réussie.

  • Isolation - Il permet un fonctionnement indépendant des transactions des transactions.

  • Durability - Il assure la persistance d'une transaction réussie en cas de panne du système.

En tête d'une instruction de transaction se trouve l'instruction START TRANSACTION suivie des instructions COMMIT et ROLLBACK -

  • START TRANSACTION commence la transaction.

  • COMMIT enregistre les modifications apportées aux données.

  • ROLLBACK met fin à la transaction, détruisant toutes les modifications.

Sur une transaction réussie, COMMIT agit. En cas d'échec, ROLLBACK agit.

Note- Certaines instructions provoquent une validation implicite et provoquent également une erreur lorsqu'elles sont utilisées dans des transactions. Les exemples de telles instructions incluent, mais sans s'y limiter, CREATE, ALTER et DROP.

Les transactions MariaDB incluent également des options telles que SAVEPOINT et LOCK TABLES. SAVEPOINT définit un point de restauration à utiliser avec ROLLBACK. LOCK TABLES permet de contrôler l'accès aux tables pendant les sessions pour éviter les modifications pendant certaines périodes.

La variable AUTOCOMMIT permet de contrôler les transactions. Un paramètre de 1 force toutes les opérations à être considérées comme des transactions réussies, et un paramètre de 0 entraîne la persistance des modifications uniquement sur une instruction COMMIT explicite.

Structure d'une transaction

La structure générale d'une instruction de transaction consiste à commencer par START TRANSACTION. L'étape suivante consiste à insérer une ou plusieurs commandes / opérations, à insérer des instructions qui vérifient les erreurs, à insérer des instructions ROLLBACK pour gérer les erreurs découvertes et enfin à insérer une instruction COMMIT pour appliquer les modifications aux opérations réussies.

Revoyez l'exemple ci-dessous -

START TRANSACTION;
SELECT name FROM products WHERE manufacturer = 'XYZ Corp';
UPDATE spring_products SET item = name;
COMMIT;

La commande ALTER fournit un moyen de modifier la structure d'une table existante, ce qui signifie des modifications telles que la suppression ou l'ajout de colonnes, la modification d'index, la modification des types de données ou la modification des noms. ALTER attend également d'appliquer les modifications lorsqu'un verrou de métadonnées est actif.

Utilisation d'ALTER pour modifier les colonnes

ALTER associé à DROP supprime une colonne existante. Cependant, il échoue si la colonne est la seule colonne restante.

Revoyez l'exemple ci-dessous -

mysql> ALTER TABLE products_tbl DROP version_num;

Utilisez une instruction ALTER ... ADD pour ajouter des colonnes -

mysql> ALTER TABLE products_tbl ADD discontinued CHAR(1);

Utilisez les mots clés FIRST et AFTER pour spécifier l'emplacement de la colonne -

ALTER TABLE products_tbl ADD discontinued CHAR(1) FIRST;
ALTER TABLE products_tbl ADD discontinued CHAR(1) AFTER quantity;

Notez que les mots clés FIRST et AFTER s'appliquent uniquement aux instructions ALTER ... ADD. De plus, vous devez supprimer une table, puis l'ajouter afin de la repositionner.

Modifiez une définition ou un nom de colonne à l'aide de la clause MODIFY ou CHANGE dans une instruction ALTER. Les clauses ont des effets similaires, mais utilisent une syntaxe sensiblement différente.

Passez en revue un exemple CHANGE donné ci-dessous -

mysql> ALTER TABLE products_tbl CHANGE discontinued status CHAR(4);

Dans une instruction utilisant CHANGE, spécifiez la colonne d'origine, puis la nouvelle colonne qui la remplacera. Consultez un exemple MODIFY ci-dessous -

mysql> ALTER TABLE products_tbl MODIFY discontinued CHAR(4);

La commande ALTER permet également de modifier les valeurs par défaut. Revoir un exemple -

mysql> ALTER TABLE products_tbl ALTER discontinued SET DEFAULT N;

Vous pouvez également l'utiliser pour supprimer les contraintes par défaut en l'associant à une clause DROP -

mysql> ALTER TABLE products_tbl ALTER discontinued DROP DEFAULT;

Utilisation d'ALTER pour modifier les tables

Changer le type de table avec la clause TYPE -

mysql> ALTER TABLE products_tbl TYPE = INNODB;

Renommer une table avec le mot clé RENAME -

mysql> ALTER TABLE products_tbl RENAME TO products2016_tbl;

Les index sont des outils pour accélérer la récupération des enregistrements. Un index génère une entrée pour chaque valeur dans une colonne indexée.

Il existe quatre types d'index -

  • Primary (un enregistrement représente tous les enregistrements)

  • Unique (un enregistrement représente plusieurs enregistrements)

  • Plain

  • Full-Text (permet de nombreuses options dans les recherches de texte).

Les termes «clé» et «index» sont identiques dans cet usage.

Les index s'associent à une ou plusieurs colonnes et prennent en charge des recherches rapides et une organisation efficace des enregistrements. Lors de la création d'un index, tenez compte des colonnes fréquemment utilisées dans vos requêtes. Créez ensuite un ou plusieurs index sur eux. En outre, affichez les index comme essentiellement des tables de clés primaires.

Bien que les index accélèrent les recherches ou les instructions SELECT, ils font glisser les insertions et les mises à jour en raison de l'exécution des opérations sur les tables et les index.

Créer un index

Vous pouvez créer un index via une instruction CREATE TABLE ... INDEX ou une instruction CREATE INDEX. La meilleure option prenant en charge la lisibilité, la maintenance et les meilleures pratiques est CREATE INDEX.

Passez en revue la syntaxe générale de l'index donnée ci-dessous -

CREATE [UNIQUE or FULLTEXT or...] INDEX index_name ON table_name column;

Passez en revue un exemple de son utilisation -

CREATE UNIQUE INDEX top_sellers ON products_tbl product;

Supprimer un index

Vous pouvez supprimer un index avec DROP INDEX ou ALTER TABLE ... DROP. La meilleure option prenant en charge la lisibilité, la maintenance et les meilleures pratiques est DROP INDEX.

Passez en revue la syntaxe générale de Drop Index donnée ci-dessous -

DROP INDEX index_name ON table_name;

Passez en revue un exemple de son utilisation -

DROP INDEX top_sellers ON product_tbl;

Renommer un index

Renommez un index avec l'instruction ALTER TABLE. Revoyez sa syntaxe générale donnée ci-dessous -

ALTER TABLE table_name DROP INDEX index_name, ADD INDEX new_index_name;

Passez en revue un exemple de son utilisation -

ALTER TABLE products_tbl DROP INDEX top_sellers, ADD INDEX top_2016sellers;

Gestion des index

Vous devrez examiner et suivre tous les index. Utilisez SHOW INDEX pour répertorier tous les index existants associés à une table donnée. Vous pouvez définir le format du contenu affiché en utilisant une option telle que «\ G», qui spécifie un format vertical.

Examinez l'exemple suivant -

mysql > SHOW INDEX FROM products_tbl\G

Statistiques de table

Les index sont largement utilisés pour optimiser les requêtes en raison de l'accès plus rapide aux enregistrements et aux statistiques fournies. Cependant, de nombreux utilisateurs trouvent la maintenance des index fastidieuse. MariaDB 10.0 a mis à disposition des tables de statistiques indépendantes du moteur de stockage, qui calculent des statistiques de données pour chaque table de chaque moteur de stockage, et même des statistiques pour les colonnes non indexées.

Certaines opérations peuvent bénéficier de tables temporaires en raison de la vitesse ou des données jetables. La vie d'une table temporaire se termine à la fin d'une session, que vous l'utilisiez depuis l'invite de commande, avec un script PHP ou via un programme client. Il n'apparaît pas non plus dans le système de manière typique. La commande SHOW TABLES ne révélera pas une liste contenant des tables temporaires.

Créer une table temporaire

Le mot clé TEMPORARY dans une instruction CREATE TABLE génère une table temporaire. Passez en revue un exemple donné ci-dessous -

mysql>CREATE TEMPORARY TABLE order (
   item_name VARCHAR(50) NOT NULL
   , price DECIMAL(7,2) NOT NULL DEFAULT 0.00
   , quantity INT UNSIGNED NOT NULL DEFAULT 0
);

En créant une table temporaire, vous pouvez cloner des tables existantes, c'est-à-dire toutes leurs caractéristiques générales, avec la clause LIKE. L'instruction CREATE TABLE utilisée pour générer la table temporaire ne validera pas les transactions en raison du mot clé TEMPORARY.

Bien que les tables temporaires se distinguent des tables non temporaires et disparaissent à la fin d'une session, elles peuvent avoir certains conflits -

  • Ils sont parfois en conflit avec les tables temporaires fantômes de sessions expirées.

  • Ils sont parfois en conflit avec les noms d'ombre de tables non temporaires.

Note - Les tables temporaires peuvent avoir le même nom qu'une table non temporaire existante car MariaDB la considère comme une référence de différence.

Administration

MariaDB nécessite l'octroi de privilèges aux utilisateurs pour créer des tables temporaires. Utilisez une instruction GRANT pour accorder ce privilège aux utilisateurs non administrateurs.

GRANT CREATE TEMPORARY TABLES ON orders TO 'machine122'@'localhost';

Supprimer une table temporaire

Bien que les tables temporaires soient essentiellement supprimées à la fin des sessions, vous avez la possibilité de les supprimer. La suppression d'une table temporaire nécessite l'utilisation du mot clé TEMPORARY et les meilleures pratiques suggèrent de supprimer les tables temporaires avant toute table non temporaire.

mysql> DROP TABLE order;

Certaines situations nécessitent de produire une copie exacte d'une table existante. L'instruction CREATE ... SELECT ne peut pas produire cette sortie car elle néglige des éléments tels que les index et les valeurs par défaut.

La procédure de duplication d'une table est la suivante -

  • Utilisez SHOW CREATE TABLE pour produire une instruction CREATE TABLE qui détaille la structure entière de la table source.

  • Modifiez l'instruction pour donner un nouveau nom à la table et exécutez-la.

  • Utilisez une instruction INSERT INTO ... SELECT si vous avez également besoin de copier les données de la table.

mysql> INSERT INTO inventory_copy_tbl (
   product_id,product_name,product_manufacturer,ship_date)
   
   SELECT product_id,product_name,product_manufacturer,ship_date,
   FROM inventory_tbl;

Une autre méthode pour créer un doublon utilise une instruction CREATE TABLE AS. L'instruction copie toutes les colonnes, les définitions de colonne et remplit la copie avec les données de la table source.

Revoyez sa syntaxe donnée ci-dessous -

CREATE TABLE clone_tbl AS
   SELECT columns
   FROM original_tbl
   WHERE conditions];

Examinez un exemple de son utilisation ci-dessous -

CREATE TABLE products_copy_tbl AS
   SELECT *
   FROM products_tbl;

Dans la version 10.0.3, MariaDB a introduit un moteur de stockage appelé séquence. Son ad hoc génère une séquence d'entiers pour les opérations, puis il se termine. La séquence contient des entiers positifs par ordre décroissant ou croissant et utilise une valeur de début, de fin et d'incrémentation.

Il n'autorise pas l'utilisation dans plusieurs requêtes, uniquement dans sa requête d'origine en raison de sa nature virtuelle (non écrite sur le disque). Cependant, les tables de séquence peuvent être converties en tables standard via une commande ALTER. Si une table convertie est supprimée, la table de séquence existe toujours. Les séquences ne peuvent pas non plus produire de nombres négatifs ou tourner au minimum / maximum.

Installation du moteur de séquence

L'utilisation de séquences nécessite l'installation du moteur de séquence, que MariaDB distribue sous forme de plugin plutôt que binaire. Installez-le avec la commande suivante -

INSTALL SONAME "ha_sequence";

Après l'installation, vérifiez-le -

SHOW ENGINES\G

N'oubliez pas qu'après l'installation du moteur, vous ne pouvez pas créer une table standard avec un nom qui utilise la syntaxe de séquence, mais vous pouvez créer une table temporaire avec un nom de syntaxe de séquence.

Créer une séquence

Il existe deux méthodes de création de séquence -

  • Créez une table et utilisez l'attribut AUTO_INCREMENT pour définir une colonne comme incrémentation automatique.

  • Utilisez une base de données existante et utilisez une requête SELECT de séquence pour produire une séquence. La requête utilise la syntaxe seq_ [FROM] _to_ [TO] ou seq_ [FROM] _to_ [TO] _step_STEP.

Les meilleures pratiques préfèrent l'utilisation de la deuxième méthode. Passez en revue un exemple de création de séquence donné ci-dessous -

SELECT * FROM seq_77_to_99;

Les séquences ont de nombreuses utilisations -

  • Localisez les valeurs manquantes dans une colonne pour vous protéger contre les problèmes liés aux opérations -

SELECT myseq.seq FROM seq_22_to_28 myseq LEFT JOIN table1 t ON myseq.seq
   = x.y WHERE x.y IS NULL;
  • Construire une combinaison de valeurs -

SELECT x1.seq, x2.seq FROM seq_5_to_9 x1 JOIN seq_5_to_9 x2 ORDER BY 5, 6;
  • Trouver des multiples d'un nombre -

SELECT seq FROM seq_3_to_100_step_4;
  • Construisez une séquence de dates à utiliser dans des applications telles que les systèmes de réservation.
  • Construisez une séquence temporelle.

MariaDB, comme indiqué dans les leçons précédentes, autorise la duplication des enregistrements et des tables dans certaines situations. Certains de ces doublons ne sont en fait pas des doublons en raison de données ou de types d'objet distincts, ou en raison de la durée de vie ou du stockage unique de l'objet d'opération. Ces doublons ne posent généralement aucun problème.

Dans certaines situations, les doublons posent des problèmes et ils apparaissent souvent en raison d'actions implicites ou de la politique indulgente d'une commande MariaDB. Il existe des moyens de contrôler ce problème, de rechercher les doublons, de supprimer les doublons et d'empêcher la création de doublons.

Stratégies et outils

Il existe quatre méthodes principales pour gérer les doublons:

  • Cherchez-les avec JOIN et supprimez-les avec une table temporaire.

  • Utilisez INSERT ... ON DUPLICATE KEY UPDATE pour mettre à jour lors de la découverte d'un doublon.

  • Utilisez DISTINCT pour élaguer les résultats d'une instruction SELECT et supprimer les doublons.

  • Utilisez INSERT IGNORE pour arrêter l'insertion de doublons.

Utilisation de la jointure avec une table temporaire

Effectuez simplement une semi-jointure comme une jointure interne, puis supprimez les doublons trouvés avec une table temporaire.

Utilisation de INSERT

Lorsque INSERT ... ON DUPLICATE KEY UPDATE découvre une clé unique ou primaire en double, il effectue une mise à jour. Lors de la découverte de plusieurs clés uniques, il ne met à jour que la première. Par conséquent, ne l'utilisez pas sur des tables avec plusieurs index uniques.

Consultez l'exemple suivant, qui révèle ce qui se passe dans une table contenant des valeurs indexées lors de l'insertion dans un champ rempli -

INSERT INTO add_dupl VALUES (1,'Apple');
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'

Note - S'il ne trouve aucune clé, une instruction INSERT ... ON DUPLICATE KEY UPDATE s'exécute comme une instruction d'insertion normale.

Utilisation de DISTINCT

Les clauses DISTINCT suppriment les doublons des résultats. La syntaxe générale d'une clause DISTINCT est la suivante -

SELECT DISTINCT fields
FROM table
[WHERE conditions];

Note - Les résultats d'une instruction avec une clause DISTINCT -

  • Lorsque vous utilisez une expression, elle renvoie des valeurs uniques.

  • Lors de l'utilisation de plusieurs expressions, il renvoie des combinaisons uniques.

  • Il n'ignore pas les valeurs NULL; ainsi, les résultats contiennent également des valeurs NULL comme valeurs uniques.

Passez en revue l'instruction suivante à l'aide d'une clause DISTINCT pour une seule expression -

SELECT DISTINCT product_id
FROM products
WHERE product_name = 'DustBlaster 5000';

Examinez l'exemple suivant en utilisant plusieurs expressions -

SELECT DISTINCT product_name, product_id
FROM products
WHERE product_id < 30

Utilisation de INSERT IGNORE

Une instruction INSERT IGNORE indique à MariaDB d'annuler l'insertion lors de la découverte d'un enregistrement en double. Passez en revue un exemple de son utilisation ci-dessous -

mysql> INSERT IGNORE INTO customer_tbl (LN, FN)
   VALUES( 'Lex', 'Luther');

Notez également la logique derrière les doublons. Certaines tables nécessitent des doublons en fonction de la nature de ces données de table. Tenez compte de ce besoin dans votre stratégie de gestion des enregistrements en double.

Le simple fait d'accepter l'entrée de l'utilisateur ouvre la porte à des exploits. Le problème vient principalement de la gestion logique des données, mais heureusement, il est assez facile d'éviter ces failles majeures.

Les opportunités d'injection SQL se produisent généralement lorsque les utilisateurs saisissent des données telles qu'un nom et que la logique du code ne parvient pas à analyser cette entrée. Le code, à la place, permet à un attaquant d'insérer une instruction MariaDB, qui s'exécutera sur la base de données.

Tenez toujours compte des données saisies par les utilisateurs, suspectes et ont besoin d'une forte validation avant tout traitement. Effectuez cette validation par correspondance de modèles. Par exemple, si l'entrée attendue est un nom d'utilisateur, limitez les caractères saisis aux caractères alphanumériques et aux traits de soulignement, et à une certaine longueur. Passez en revue un exemple donné ci-dessous -

if(check_match("/^\w{8,20}$/", $_GET['user_name'], $matches)) {
   $result = mysql_query("SELECT * FROM system_users WHERE user_name = $matches[0]");
} else {
   echo "Invalid username";
}

Utilisez également l'opérateur REGEXP et les clauses LIKE pour créer des contraintes d'entrée.

Considérez tous les types de contrôle explicite nécessaire des entrées tels que -

  • Contrôlez les caractères d'échappement utilisés.

  • Contrôlez les types de données appropriés spécifiques pour l'entrée. Limitez l'entrée au type et à la taille de données nécessaires.

  • Contrôlez la syntaxe des données saisies. Ne laissez rien en dehors du modèle requis.

  • Contrôlez les conditions autorisées. Liste noire des mots clés SQL.

Vous ne connaissez peut-être pas les dangers des attaques par injection, ou pouvez les considérer comme insignifiants, mais ils figurent en tête de liste des problèmes de sécurité. En outre, considérez l'effet de ces deux entrées -

1=1
-or-
*

Un code permettant de saisir l'un de ces éléments avec la bonne commande peut entraîner la révélation de toutes les données utilisateur de la base de données ou la suppression de toutes les données de la base de données, et aucune des deux injections n'est particulièrement intelligente. Dans certains cas, les attaquants ne passent même pas de temps à examiner les trous; ils effectuent des attaques aveugles avec une simple entrée.

Pensez également aux outils de correspondance de modèles et d'expression régulière fournis par tout langage de programmation / script associé à MariaDB, qui offrent plus de contrôle et parfois un meilleur contrôle.

Les données servent de base aux activités et aux opérations, et avec diverses menaces possibles (par exemple, les attaquants, les pannes du système, les mauvaises mises à niveau et les erreurs de maintenance), les sauvegardes restent essentielles. Ces sauvegardes prennent de nombreuses formes et de nombreuses options existent pour les créer avec un ensemble encore plus large d'options au sein de ces processus. Les éléments importants à retenir sont le type de base de données, les informations critiques et la structure impliquée. Ces informations déterminent votre meilleure option.

OPTIONS

Les principales options de sauvegarde incluent les sauvegardes logiques et les sauvegardes physiques. Les sauvegardes logiques contiennent des instructions SQL pour la restauration des données. Les sauvegardes physiques contiennent des copies des données.

  • Logical backupsoffrent la flexibilité de restaurer des données sur une autre machine avec une configuration différente contrairement aux sauvegardes physiques, qui sont souvent limitées au même type de machine et de base de données. Les sauvegardes logiques se produisent au niveau de la base de données et de la table, et physiques au niveau du répertoire et du fichier.

  • Physical backupssont plus petites que logiques et prennent moins de temps à exécuter et à restaurer. Les sauvegardes physiques incluent également les fichiers journaux et de configuration, mais pas les sauvegardes logiques.

Outils de sauvegarde

Le principal outil utilisé pour les sauvegardes MariaDB est mysqldump. Il offre des sauvegardes logiques et de la flexibilité. Cela s'avère également une excellente option pour les petites bases de données.Mysqldumpvide les données dans SQL, CSV, XML et de nombreux autres formats. Sa sortie ne conserve pas les procédures stockées, les vues et les événements sans instruction explicite.

Il existe trois options pour mysqldump sauvegardes -

  • Raw data - Vider une table en tant que fichier de données brutes via l'option --tab, qui spécifie également la destination du fichier -

$ mysqldump -u root -p --no-create-info \
   --tab=/tmp PRODUCTS products_tbl
  • Data/Definitions export- Cette option permet d'exporter une ou plusieurs tables vers un fichier et prend en charge la sauvegarde de toutes les bases de données existantes sur la machine hôte. Examiner un exemple d'exportation de contenu ou de définitions vers un fichier

$ mysqldump -u root -p PRODUCTS products_tbl > export_file.txt
  • Transfer - Vous pouvez également exporter des bases de données et des tables vers un autre hôte

$ mysqldump -u root -p database_name \
   | mysql -h other-host.com database_name

Utilisation de l'instruction SELECT ... INTO OUTFILE

Une autre option pour exporter des données utilise l'instruction SELECT ... INTO OUTFILE. Cette option simple génère le tableau dans un simple fichier texte formaté -

mysql> SELECT * FROM products_tbl
   -> INTO OUTFILE '/tmp/products.txt';

Ses attributs permettent de formater le fichier selon vos spécifications préférées.

Notez les qualités suivantes de cette déclaration -

  • Le nom de fichier doit spécifier l'emplacement souhaité pour la sortie.

  • Vous avez besoin des privilèges de fichier MariaDB pour exécuter l'instruction.

  • Le nom du fichier de sortie doit être unique.

  • Vous avez besoin des informations de connexion sur l'hôte.

  • Dans un environnement UNIX, le fichier de sortie est lisible par tout le monde, mais la propriété de son serveur affecte votre capacité à le supprimer. Assurez-vous d'avoir des privilèges.

Utilisation de CONNECT dans les sauvegardes

Le gestionnaire CONNECT permet d'exporter des données. Cela s'avère utile principalement dans les situations où l'opération SELECT ... INTO OUTFILE ne prend pas en charge le format de fichier.

Examinez l'exemple suivant -

create table products
engine = CONNECT table_type = XML file_name = 'products.htm' header = yes
option_list = 'name = TABLE,coltype = HTML,attribute = border = 1;cellpadding = 5'

select plugin_name handler, plugin_version version, plugin_author
author, plugin_description description, plugin_maturity maturity
from information_schema.plugins where plugin_type = 'STORAGE ENGINE';

Autres outils

Les autres options de sauvegarde sont les suivantes -

  • XtraBackup- Cette option cible les bases de données XtraDB / InnoDB et fonctionne avec n'importe quel moteur de stockage. En savoir plus sur cet outil sur le site officiel de Percona.

  • Snapshots- Certains systèmes de fichiers autorisent les instantanés. Le processus consiste à vider les tables avec un verrou de lecture, à monter le snapshot, à déverrouiller les tables, à copier le snapshot, puis à démonter le snapshot.

  • LVM- Cette méthode populaire utilise un script Perl. Il obtient un verrou de lecture sur chaque table et vide les caches sur le disque. Ensuite, il obtient un instantané et déverrouille les tables. Consulter le fonctionnairemylvmbackup site Web pour plus d'informations.

  • TokuBackup- Cette solution fournie par Percona fournit des sauvegardes à chaud en tenant compte des problèmes et des limites des options de sauvegarde InnoDB. Il produit une copie sonore transactionnelle des fichiers pendant que les applications continuent à les manipuler. Consultez le site Web de Percona pour plus d'informations.

Considérations sur INNODB

InnoDB utilise un pool de tampons pour l'amélioration des performances. Dans une sauvegarde, configurez InnoDB pour éviter de copier une table entière dans le pool de mémoire tampon car les sauvegardes logiques effectuent généralement des analyses complètes de la table.

Dans ce chapitre, nous découvrirons les différentes méthodes de chargement de sauvegarde. La restauration d'une base de données à partir d'une sauvegarde est un processus simple et parfois terriblement long.

Il existe trois options pour charger les données: l'instruction LOAD DATA, mysqlimport et une simple restauration mysqldump.

Utilisation de LOAD DATA

L'instruction LOAD DATA fonctionne comme un chargeur en bloc. Passez en revue un exemple de son utilisation qui charge un fichier texte -

mysql> LOAD DATA LOCAL INFILE 'products_copy.txt' INTO TABLE empty_tbl;

Notez les qualités suivantes d'une instruction LOAD DATA -

  • Utilisez le mot clé LOCAL pour empêcher MariaDB d'effectuer une recherche approfondie de l'hôte et utilisez un chemin très spécifique.

  • L'instruction suppose un format composé de lignes terminées par des sauts de ligne (retours à la ligne) et des valeurs de données séparées par des tabulations.

  • Utilisez la clause FIELDS pour spécifier explicitement la mise en forme des champs sur une ligne. Utilisez la clause LINES pour spécifier la fin de la ligne. Consultez un exemple ci-dessous.

mysql> LOAD DATA LOCAL INFILE 'products_copy.txt' INTO TABLE empty_tbl
   FIELDS TERMINATED BY '|'
   LINES TERMINATED BY '\n';
  • L'instruction suppose que les colonnes du fichier de données utilisent le même ordre de la table. Si vous devez définir un ordre différent, vous pouvez charger le fichier comme suit -

mysql> LOAD DATA LOCAL INFILE 'products_copy.txt' INTO TABLE empty_tbl (c, b, a);

Utilisation de MYSQLIMPORT

L'outil mysqlimport agit comme un wrapper LOAD DATA permettant les mêmes opérations depuis la ligne de commande.

Chargez les données comme suit -

$ mysqlimport -u root -p --local database_name source_file.txt

Spécifiez le formatage comme suit -

$ mysqlimport -u root -p --local --fields-terminated-by="|" \
   --lines-terminated-by="\n" database_name source_file.txt

Utilisez le --columns option pour spécifier l'ordre des colonnes -

$ mysqlimport -u root -p --local --columns=c,b,a \
   database_name source_file.txt

Utilisation de MYSQLDUMP

Restaurer avec mysqldump nécessite cette simple instruction pour charger le fichier de vidage dans l'hôte -

shell> mysql database_name < source_file.sql

CARACTÈRES SPÉCIAUX ET CITATIONS

Dans une instruction LOAD DATA, les guillemets et les caractères spéciaux peuvent ne pas être interprétés correctement. L'instruction suppose des valeurs sans guillemets et traite les contre-obliques comme des caractères d'échappement. Utilisez la clause FIELDS pour spécifier la mise en forme. Pointez sur les guillemets avec «ENCLOSED BY», ce qui entraîne la suppression des guillemets des valeurs de données. Remplacez les échappements par "ESCAPED BY".

Ce chapitre contient une liste des fonctions les plus fréquemment utilisées, offrant des définitions, des explications et des exemples.

Fonctions d'agrégation MariaDB

Les fonctions d'agrégation les plus fréquemment utilisées sont données ci-dessous -

Sr.Non Nom et description
1

COUNT

Il compte le nombre d'enregistrements.

Example - SELECT COUNT (*) FROM customer_table;

2

MIN

Il révèle la valeur minimale d'un ensemble d'enregistrements.

Example - SELECT organisation, MIN (compte) FROM contrats GROUP BY organisation;

3

MAX

Il révèle la valeur maximale d'un ensemble d'enregistrements.

Example - SELECT organisation, MAX (account_size) FROM contrats GROUP BY organisation;

4

AVG

Il calcule la valeur moyenne d'un ensemble d'enregistrements.

Example - SELECT AVG (account_size) FROM contrats;

5

SUM

Il calcule la somme d'un ensemble d'enregistrements.

Example - SELECT SUM (account_size) FROM contrats;

Calcul de l'âge MariaDB

le TIMESTAMPDIFF La fonction fournit un moyen de calculer l'âge -

SELECT CURDATE() AS today;
SELECT ID, DOB, TIMESTAMPDIFF(YEAR,DOB,'2015-07-01') AS age FROM officer_info;

Concaténation de chaînes MariaDB

le CONCATfunction renvoie la chaîne résultante après une opération de concaténation. Vous pouvez utiliser un ou plusieurs arguments. Revoyez sa syntaxe donnée ci-dessous -

SELECT CONCAT(item, item,...);

Examinez l'exemple suivant -

SELECT CONCAT('Ram', 'bu', 'tan');
Output:Rambutan

Fonctions de date / heure MariaDB

Vous trouverez ci-dessous des fonctions de date importantes -

Sr.Non Nom et description
1

CURDATE()

Il renvoie la date au format aaaa-mm-jj ou aaaammjj.

Example - CHOISIR CURDATE ();

2

DATE()

Il renvoie la date dans plusieurs formats.

Example −CREATE TABLE product_release_tbl (x DATE);

3

CURTIME()

Il renvoie l'heure au format HH: MM: SS ou HHMMSS.uuuuuu.

Example - CHOISIR CURTIME ();

4

DATE_SUB()

Il ajoute ou soustrait un certain nombre de jours à la date spécifiée.

Example - SÉLECTIONNEZ DATE_SUB ('2016-02-08', INTERVALLE 60 JOUR);

5

DATEDIFF()

Il détermine les jours entre deux dates.

Example - CHOISIR DATEDIFF ('2016-01-01 23:59:59', '2016-01-03');

6

DATE ADD()

Il ajoute ou soustrait toute unité de temps à / de la date et de l'heure.

Example - SELECT DATE_ADD ('2016-01-04 23:59:59', INTERVAL 22 SECOND);

sept

EXTRACT()

Il extrait une unité de la date.

Example - SÉLECTIONNER UN EXTRAIT (ANNÉE DU «08/01/2016»);

8

NOW()

Il renvoie la date et l'heure actuelles au format aaaa-mm-jj hh: mm: ss ou aaaammjjhhmmss.uuuuuu.

Example - SÉLECTIONNEZ MAINTENANT ();

9

DATE FORMAT()

Il met en forme la date conformément à la chaîne de format spécifiée.

Example - CHOISIR DATE_FORMAT ('2016-01-09 20:20:00', '% W% M% Y');

Voici quelques fonctions de temps importantes -

Sr.Non Nom et description
1

HOUR()

Il renvoie l'heure du temps ou les heures écoulées.

Example - CHOISIR L'HEURE ('19: 17: 09 ');

2

LOCALTIME()

Il fonctionne exactement comme NOW ().

3

MICROSECOND()

Il renvoie les microsecondes de l'heure.

Example - SÉLECTIONNER MICROSECOND ('16: 30: 00.543876 ');

4

MINUTE()

Il renvoie les minutes de l'heure.

Example - CHOISIR UNE MINUTE ('2016-05-22 17:22:01');

5

SECOND()

Il renvoie les secondes de la date.

Example - CHOISIR LA SECONDE ('2016-03-12 16: 30: 04.000001');

6

TIME_FORMAT()

Il formate l'heure conformément à la chaîne de format spécifiée.

Example - SELECT TIME_FORMAT ('22: 02: 20 ','% H% k% h% I% l ');

sept

TIMESTAMP()

Il fournit un horodatage pour une activité au format aaaa-mm-jj hh: mm: jj.

Example - CREATE TABLE orders_ (ID INT, tmst TIMESTAMP);

Fonctions numériques MariaDB

Vous trouverez ci-dessous quelques fonctions numériques importantes dans MariaDB -

Sr.Non Nom et description
1

TRUNCATE()

Il renvoie un nombre tronqué à la spécification de la décimale.

Example - CHOISIR TRONCATE (101.222, 1);

2

COS()

Il renvoie le cosinus de x radians.

Example - SELECT COS (PI ());

3

CEILING()

Il renvoie le plus petit entier non inférieur à x.

Example - CHOISIR LE PLAFOND (2.11);

4

DEGREES()

Il convertit les radians en degrés.

Example - CHOISIR DEGRÉS (PI ());

5

DIV()

Il effectue une division entière.

Example - SÉLECTIONNEZ 100 DIV 4;

6

EXP()

Il renvoie e à la puissance de x.

Example - SELECT EXP (2);

sept

FLOOR()

Il renvoie le plus grand entier non supérieur à x.

Example - CHOISIR UN PLANCHER (2.01);

8

LN()

Il renvoie le logarithme naturel de x.

Example - CHOISIR LN (3);

9

LOG()

Il renvoie le logarithme naturel ou le logarithme à une base donnée.

Example - SÉLECTIONNER LE JOURNAL (3);

dix

SQRT()

Il renvoie la racine carrée.

Example - SÉLECTIONNER SQRT (16);

Fonctions de chaîne MariaDB

Les fonctions de chaîne importantes sont données ci-dessous -

Sr.Non Nom et description
1

INSTR()

Il renvoie la position de la première instance d'une sous-chaîne.

Example - SELECT INSTR ('ramboutan', 'tan');

2

RIGHT()

Il renvoie les caractères de chaîne les plus à droite.

Example - CHOISIR DROITE ('ramboutan', 3);

3

LENGTH()

Il renvoie la longueur en octets d'une chaîne.

Example - CHOISIR LA LONGUEUR ('ramboutan');

4

LOCATE()

Il renvoie la position de la première instance d'une sous-chaîne.

Example - SELECT LOCATE ('tan', 'ramboutan');

5

INSERT()

Il renvoie une chaîne, avec une sous-chaîne spécifiée à une certaine position, qui a été modifiée.

Example - SELECT INSERT ('ramputan', 4, 1, 'b');

6

LEFT()

Il renvoie les caractères les plus à gauche.

Example - SELECT GAUCHE ('ramboutan', 3);

sept

UPPER()

Il change les caractères en majuscules.

Example - SELECT UPPER (nom);

8

LOWER()

Il change les caractères en minuscules.

Example - SELECT LOWER (nom);

9

STRCMP()

Il compare les chaînes et renvoie 0 lorsqu'elles sont égales.

Example - SELECT STRCMP ('oeuf', 'fromage');

dix

REPLACE()

Il renvoie une chaîne après avoir remplacé les caractères.

Example - CHOISIR REMPLACER ('sully', 'l', 'n');

11

REVERSE()

Il inverse les caractères dans une chaîne.

Example - SELECT REVERSE ('voiture de course');

12

REPEAT()

Il renvoie une chaîne répétant les caractères donnés x fois.

Example - SELECT REPEAT ('ha', 10);

13

SUBSTRING()

Il renvoie une sous-chaîne d'une chaîne, en commençant à la position x.

Example - SELECT SUBSTRING ('ramboutan', 3);

14

TRIM()

Il supprime les caractères de fin / de tête d'une chaîne.

Example - SÉLECTIONNER LA TRIM (EN DIRECTION '_' DE '_rambutan');