Maison >base de données >tutoriel mysql >Comment interroger le type de table dans MySQL

Comment interroger le type de table dans MySQL

青灯夜游
青灯夜游original
2021-12-28 17:50:465922parcourir

Méthode de requête : 1. Utilisez l'instruction "SHOW TABLE STATUS FROM `database name`;" pour répertorier les informations sur toutes les tables de la base de données spécifiée, y compris les types de tables. 2. Utilisez "SHOW CREATE TABLE `data table name`;" instruction pour répertorier les informations sur la table de données spécifiée, y compris le type de table.

Comment interroger le type de table dans MySQL

L'environnement d'exploitation de ce tutoriel : système windows7, version mysql8, ordinateur Dell G3.

Les tables de données MySQL prennent principalement en charge six types, à savoir : BDB, HEAP, ISAM, MERGE, MYISAM et InnoBDB.

Ces six types sont divisés en deux catégories, l'une est « transaction-safe » (transaction-safe), comprenant BDB et InnoDB ; les autres appartiennent à la deuxième catégorie, appelée « non-transaction-safe » (non-transaction-safe). sûr) sûr).

BDB Le nom complet est "Brekeley DB", qui est le premier type de table compatible avec les transactions de Mysql, développé par Sleepycat Software (http://www.sleepycat.com). Il fournit la fonction de capacité de contrôle des transactions, qui garantit qu'un ensemble de commandes est toutes exécutées avec succès, ou que les résultats de toutes les commandes sont annulés lorsqu'une erreur se produit dans une commande. On peut imaginer que la capacité de contrôle des transactions est très importante en électronique. bancaire. Prend en charge COMMIT, ROLLBACK et d'autres fonctionnalités de transaction. La dernière version de Mysql a prévu de supprimer le support de BDB et de se concentrer sur le développement d'InnoDB.

InnoDB est un nouveau moteur de stockage sécurisé pour les transactions pour les applications de traitement des transactions qui prend en charge presque toutes les fonctionnalités de BDB et possède de nombreuses nouvelles fonctionnalités, notamment la prise en charge des transactions ACID.

Caractéristiques :

  • Mécanisme de traitement des transactions

  • Prend en charge les liens externes

  • Peut être restauré immédiatement après un crash

  • Prend en charge la fonction de clé étrangère, la suppression en cascade

  • Prend en charge la conc capacités d'urgence

  • Méthode de stockage sur le disque dur : InnoBDB frm

La dernière version de Mysql a prévu de supprimer le support de BDB et de se concentrer sur le développement d'InnoDB. InnoDB offre une meilleure prise en charge des fonctionnalités pour Mysql et la communauté de développement est active.

MyISAM Le moteur de stockage de plug-in MySQL par défaut, il est basé sur le type ISAM, mais il ajoute de nombreuses extensions utiles. C'est l'un des moteurs de stockage les plus couramment utilisés dans le Web, l'entreposage de données et d'autres environnements d'application. Notez que le moteur de stockage par défaut du serveur MySQL peut être facilement modifié en modifiant la variable de configuration STORAGE_ENGINE.
Avantages :

  • 1. Plus petit que les tables ISAM et occupant moins de ressources

  • 2. Peut être transplanté binaire entre différentes plateformes. Le type de table est spécifié lors de la création de la table.

ISAM est le type par défaut utilisé par les tables MySQL avant l'apparition du type MyISAM, et a maintenant été remplacé par MyISAM.

Memory (HEAP) est la table la plus accessible parmi les tables MySQL, conservant toutes les données dans la RAM, offrant un accès extrêmement rapide dans les environnements où les références et autres données similaires doivent être rapidement trouvées. Notez que les données de ce type ne sont pas conçues pour être persistantes. Elles conviennent généralement aux tables temporaires. Si MySQL ou le serveur tombe en panne, toutes les données de la table seront perdues.

Merge est un nouveau type de table digne d'attention. Il est composé d'un ensemble de tables MyISAM. Il est fusionné principalement pour des raisons de performances car il peut augmenter la vitesse de recherche, améliorer l'efficacité de la réparation et économiser de l'espace disque. Permet à un administrateur de base de données ou à un développeur MySQL de regrouper logiquement une série de tables MyISAM équivalentes et de les référencer en tant qu'objet unique. Il est très adapté aux environnements VLDB tels que l'entreposage de données. Parfois, il apparaît sous le nom MRG_MYISAM.

Archive fournit la solution parfaite pour le stockage et la récupération de grandes quantités d'informations historiques, d'archives ou d'audit de sécurité rarement référencées.

Fédéré Capable de relier plusieurs serveurs MySQL distincts pour créer une base de données logique à partir de plusieurs serveurs physiques. Très approprié pour les environnements distribués ou les environnements de datamart.

NDBCluster/Cluster/NDB Le moteur de base de données en cluster de MySQL est particulièrement adapté aux applications ayant des exigences de recherche hautes performances qui nécessitent également une disponibilité et une disponibilité maximales.

CSV Utilise le format CSV standard, des fichiers texte délimités par des virgules, adaptés à l'échange de données externes

Blackhole Il acceptera les données mais ne les enregistrera pas et renverra un ensemble vide pour toute demande de récupération. Il convient généralement aux conceptions de bases de données distribuées dans lesquelles les données sont automatiquement copiées et non enregistrées localement. (Pas sûr) Il semble qu'il puisse également être utilisé pour supprimer/ignorer temporairement les entrées d'application dans la base de données.

Exemple Ceci est un moteur de test, vous pouvez créer une table comme celle-ci, mais vous ne pouvez ni écrire de données ni récupérer de données. Il semble que ce soit un exemple de moteur pour les développeurs MySql.

La syntaxe de commande pour utiliser et afficher les types de tables est la suivante

--
-- 创建表时指定表类型的方法
CREATE TABLE `message` (
`id` int(11) NOT NULL auto_increment,
`sender` varchar(255) default NULL,
`receiver` varchar(255) default NULL,
`content` text,
`is_read` char(1) default 'N',
`send_time` datetime default NULL,
`del_flag` tinyint(4) default '0',
PRIMARY KEY (`id`)
) ENGINE=MYISAM;
  
-- 也可以创建后更改:
ALTER TABLE `message` ENGINE = INNODB;

Afficher les types de tables

  • Méthode 1 :

-- 查看表类型(存储引擎)
SHOW TABLE STATUS FROM `test`;

Le résultat est l'information de toutes les tables dans le test de la base de données, où le deuxième type d'élément est le type de la table.

  • 方法2:

  -- 查看表类型(存储引擎)2
SHOW CREATE TABLE `message`;

结果为表message创建时的信息,其中有TYPE或ENGINE一项,指定了表的类型(存储引擎)。

注意:老版本的MySQL使用 TYPE而不是ENGINE(例如,TYPE = MYISAM)。MySQL 5.1为向下兼容而支持这个语法,但TYPE现在被轻视,而ENGINE 是首先的用法。 一般地,ENGINE选项是不必要的;除非默认已经被改变了,MyISAM是默认存储引擎。

【相关推荐:mysql视频教程

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn