mysql存储引擎(二) mysql存储引擎二 MEMORY MERGE BerkeleyDB存储引擎 MEMORY MEMORY存储引擎通过采用内存中的内容来创建表。每个Memory表实际上和一个磁盘文件关联起来,文件名采用”表名.frm”的格式。Memory类型的表访问速度极快,因为数据源来自内存,
mysql存储引擎(二)
-
-
- mysql存储引擎二
- MEMORY
- MERGE
- BerkeleyDB存储引擎
- mysql存储引擎二
-
MEMORY
MEMORY存储引擎通过采用内存中的内容来创建表。每个Memory表实际上和一个磁盘文件关联起来,文件名采用”表名.frm”的格式。Memory类型的表访问速度极快,因为数据源来自内存,所以数据库关闭时,内存中的数据就会发生丢失。默认使用Hash索引。
<code class=" hljs asciidoc">mysql> create table memory<span class="hljs-emphasis">_table( id int primary key, name varchar(20) )engine=memory; Query OK, 0 rows affected (0.02 sec) </span>mysql> insert into memory<span class="hljs-emphasis">_table(id,name) values(2,'frank'); Query OK, 1 row affected (0.00 sec) </span><span class="hljs-header">mysql> select * from memory_table; +----+-----------+</span> <span class="hljs-header">| id | name | +----+-----------+</span> | 1 | frankstar | <span class="hljs-header">| 2 | frank | +----+-----------+</span> 2 rows in set (0.00 sec) mysql> show table status like <span class="hljs-emphasis">'memory_table'</span> \G; <span class="hljs-bullet">*************************** </span>1. row *************************** <span class="hljs-code"> Name: memory_table</span> <span class="hljs-code"> Engine: MEMORY</span> <span class="hljs-code"> Version: 10</span> <span class="hljs-code"> Row_format: Fixed</span> <span class="hljs-code"> Rows: 2</span> <span class="hljs-code"> Avg_row_length: 66</span> <span class="hljs-code"> Data_length: 127008</span> Max<span class="hljs-emphasis">_data_</span>length: 12582900 <span class="hljs-code"> Index_length: 126992</span> <span class="hljs-code"> Data_free: 0</span> <span class="hljs-code"> Auto_increment: NULL</span> <span class="hljs-code"> Create_time: 2016-05-09 22:23:47</span> <span class="hljs-code"> Update_time: NULL</span> <span class="hljs-code"> Check_time: NULL</span> <span class="hljs-code"> Collation: utf8_bin</span> <span class="hljs-code"> Checksum: NULL</span> <span class="hljs-code"> Create_options:</span> <span class="hljs-code"> Comment:</span> 1 row in set (0.00 sec) ERROR: No query specified mysql> show index from memory<span class="hljs-emphasis">_table \G; *************************** 1. row *************************** Table: memory_</span>table <span class="hljs-code"> Non_unique: 0</span> <span class="hljs-code"> Key_name: PRIMARY</span> <span class="hljs-code"> Seq_in_index: 1</span> <span class="hljs-code"> Column_name: id</span> <span class="hljs-code"> Collation: NULL</span> <span class="hljs-code"> Cardinality: 2</span> <span class="hljs-code"> Sub_part: NULL</span> <span class="hljs-code"> Packed: NULL</span> <span class="hljs-code"> Null:</span> <span class="hljs-code"> Index_type: HASH</span> <span class="hljs-code"> Comment:</span> Index<span class="hljs-emphasis">_comment: 1 row in set (0.00 sec) </span>ERROR: No query specified </code>
memory表的内存储存在内存中,如果表的数据很大,那么服务器将会自动将其转换为磁盘表,阀值由temp_table_size系统变量来确定。每个memory表的容量由max_heap_table_size变量的值控制。默认16MB。
主要用于数据内容变化不频繁的代码表及访问速度要求较高、数据量不大的场合,同时需要考虑更新操作数据不回写入到磁盘文件中。
MERGE
它实际上是一组myisam表的组合,将一组结构相同的MyISAM表组合在一起,MERGE表本身没有数据,对于该类型表的插入操作,是通过INSERT_METHOD定义完成的,取值为LAST或者为FIRST,FIRST意味着数据增加到组合表中的第一个myisam表中,同理LAST意味着添加到最后一个表中。所以MERGE表的文件有2个,一个是.frm文件,用于存放数据,还有一个MRG文件,用于存放MERGE表的名称,包括其组成表。
如下:
<code class=" hljs haml">mysql> create table myisam_table1( -<span class="ruby">> id int primary key, </span> -<span class="ruby">> data datetime </span> -<span class="ruby">> )engine=myisam; </span>Query OK, 0 rows affected (0.02 sec) create table myisam_table2( id int primary key, data datetime )engine=myisam; Query OK, 0 rows affected (0.01 sec) mysql> create table table1_merge_table2( -<span class="ruby">> id int primary key, </span> -<span class="ruby">> data datetime </span> -<span class="ruby">> )engine=merge union=(myisam_table1,myisam_table2) insert_method=first; </span>Query OK, 0 rows affected (0.01 sec)</code>
向2个字表分别添加数据,如下:
<code class=" hljs cs">mysql> insert <span class="hljs-keyword">into</span> myisam_table1 values(<span class="hljs-number">1</span>,<span class="hljs-string">'2016-5-7'</span>); Query OK, <span class="hljs-number">1</span> row affected (<span class="hljs-number">0.00</span> sec) mysql> insert <span class="hljs-keyword">into</span> myisam_table1 values(<span class="hljs-number">2</span>,<span class="hljs-string">'2016-5-6'</span>); Query OK, <span class="hljs-number">1</span> row affected (<span class="hljs-number">0.00</span> sec) mysql> insert <span class="hljs-keyword">into</span> myisam_table2 values(<span class="hljs-number">1</span>,<span class="hljs-string">'2016-5-7'</span>); Query OK, <span class="hljs-number">1</span> row affected (<span class="hljs-number">0.00</span> sec) mysql> insert <span class="hljs-keyword">into</span> myisam_table2 values(<span class="hljs-number">2</span>,<span class="hljs-string">'2016-5-6'</span>); Query OK, <span class="hljs-number">1</span> row affected (<span class="hljs-number">0.00</span> sec) </code>
查询merge表,如下:
<code class=" hljs asciidoc"><span class="hljs-header">mysql> select * from table1_merge_table2; +----+---------------------+</span> <span class="hljs-header">| id | data | +----+---------------------+</span> | 1 | 2016-05-07 00:00:00 | | 2 | 2016-05-06 00:00:00 | | 1 | 2016-05-07 00:00:00 | <span class="hljs-header">| 2 | 2016-05-06 00:00:00 | +----+---------------------+</span> 4 rows in set (0.01 sec)</code>
向merge表中添加一条数据,如下:
<code class=" hljs asciidoc">mysql> insert into table1<span class="hljs-emphasis">_merge_</span>table2 values(3,<span class="hljs-emphasis">'2016-5-8'</span>); Query OK, 1 row affected (0.00 sec) <span class="hljs-header">mysql> select * from table1_merge_table2; +----+---------------------+</span> <span class="hljs-header">| id | data | +----+---------------------+</span> | 1 | 2016-05-07 00:00:00 | | 2 | 2016-05-06 00:00:00 | | 3 | 2016-05-08 00:00:00 | | 1 | 2016-05-07 00:00:00 | <span class="hljs-header">| 2 | 2016-05-06 00:00:00 | +----+---------------------+</span> 5 rows in set (0.00 sec) <span class="hljs-header">mysql> select * from myisam_table1; +----+---------------------+</span> <span class="hljs-header">| id | data | +----+---------------------+</span> | 1 | 2016-05-07 00:00:00 | | 2 | 2016-05-06 00:00:00 | <span class="hljs-header">| 3 | 2016-05-08 00:00:00 | +----+---------------------+</span> 3 rows in set (0.00 sec) <span class="hljs-header">mysql> select * from myisam_table2; +----+---------------------+</span> <span class="hljs-header">| id | data | +----+---------------------+</span> | 1 | 2016-05-07 00:00:00 | <span class="hljs-header">| 2 | 2016-05-06 00:00:00 | +----+---------------------+</span> 2 rows in set (0.00 sec)</code>
INSERT_METHOD的指定起作用了,如果没有指定,那么当试图往Merge表中insert数据时,都会发生错误。通常使用merge表来透明的对多个表进行查询和更新。
BerkeleyDB存储引擎
简称BDB,创建该类型的表时,会有2个数据文件,一个.frm文件存储表元数据,另一个.db文件存储数据和索引文件,类似innodb。它的实现事务安全有redo日志。在每次启动的时候,都会做一次检查操作,将所有的redo日志清空。它和Memory引擎一样,都是页级锁定。

酸性属性には、原子性、一貫性、分離、耐久性が含まれ、データベース設計の基礎です。 1.原子性は、トランザクションが完全に成功するか、完全に失敗することを保証します。 2.一貫性により、データベースがトランザクションの前後に一貫性を保証します。 3.分離により、トランザクションが互いに干渉しないようにします。 4.永続性により、トランザクションの提出後にデータが永久に保存されることが保証されます。

MySQLは、データベース管理システム(DBMS)であるだけでなく、プログラミング言語にも密接に関連しています。 1)DBMSとして、MySQLはデータを保存、整理、取得するために使用され、インデックスを最適化するとクエリのパフォーマンスが向上する可能性があります。 2)SQLとPythonに埋め込まれたプログラミング言語とSQLalchemyなどのORMツールを使用すると、操作を簡素化できます。 3)パフォーマンスの最適化には、インデックス、クエリ、キャッシュ、ライブラリ、テーブル分割、およびトランザクション管理が含まれます。

MySQLはSQLコマンドを使用してデータを管理します。 1.基本コマンドには、select、挿入、更新、削除が含まれます。 2。高度な使用には、参加、サブクエリ、および集計関数が含まれます。 3.一般的なエラーには、構文、ロジック、パフォーマンスの問題が含まれます。 4。最適化のヒントには、インデックスの使用、Select*の回避、制限の使用が含まれます。

MySQLは、データの保存と管理に適した効率的なリレーショナルデータベース管理システムです。その利点には、高性能クエリ、柔軟なトランザクション処理、豊富なデータ型が含まれます。実際のアプリケーションでは、MySQLはeコマースプラットフォーム、ソーシャルネットワーク、コンテンツ管理システムでよく使用されますが、パフォーマンスの最適化、データセキュリティ、スケーラビリティに注意を払う必要があります。

SQLとMySQLの関係は、標準言語と特定の実装との関係です。 1.SQLは、リレーショナルデータベースの管理と操作に使用される標準言語であり、データの追加、削除、変更、クエリを可能にします。 2.MYSQLは、SQLを運用言語として使用し、効率的なデータストレージと管理を提供する特定のデータベース管理システムです。

INNODBは、レドログと非論的なものを使用して、データの一貫性と信頼性を確保しています。 1.レドログは、クラッシュの回復とトランザクションの持続性を確保するために、データページの変更を記録します。 2.Undologsは、元のデータ値を記録し、トランザクションロールバックとMVCCをサポートします。

説明コマンドのキーメトリックには、タイプ、キー、行、および追加が含まれます。 1)タイプは、クエリのアクセスタイプを反映しています。値が高いほど、constなどの効率が高くなります。 2)キーは使用されているインデックスを表示し、nullはインデックスがないことを示します。 3)行はスキャンされた行の数を推定し、クエリのパフォーマンスに影響します。 4)追加の情報を最適化する必要があるというFilesortプロンプトを使用するなど、追加情報を提供します。

Temporaryを使用すると、MySQLクエリに一時テーブルを作成する必要があることが示されています。これは、異なる列、またはインデックスされていない列を使用して順番に一般的に見られます。インデックスの発生を回避し、クエリを書き直し、クエリのパフォーマンスを改善できます。具体的には、expliect出力に使用を使用する場合、MySQLがクエリを処理するために一時テーブルを作成する必要があることを意味します。これは通常、次の場合に発生します。1)個別またはグループビーを使用する場合の重複排除またはグループ化。 2)Orderbyに非インデックス列が含まれているときに並べ替えます。 3)複雑なサブクエリを使用するか、操作に参加します。最適化方法には以下が含まれます。1)OrderbyとGroupB


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター
