欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL中庫的基本操作指南(推薦!)

 更新時間:2023年02月18日 15:20:24   作者:大蝦好吃嗎  
MySQL這個數據庫是一個客戶端-服務器結構的程序,下面這篇文章主要給大家介紹了關于MySQL中庫的基本操作指南,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

查看數據庫

語法格式:

SHOW {DATABASES | SCHEMAS}
    [LIKE 'pattern' | WHERE expr]

#查看全部數據庫

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
4 rows in set (0.00 sec)
show databases [like '庫名'| where 表達式];

例:查看有my的數據庫

show databases like 'my%'

創(chuàng)建數據庫

MySQL安裝好之后,?先需要創(chuàng)建數據庫,這是使?MySQL各種功能的前提。本章將詳細介紹數據的基本操作,主要內容包括:創(chuàng)建數據庫、刪除數據庫、不同類型的數據存儲引擎和存儲引擎的選擇。

MySQL安裝完成之后,將會在其data?錄下?動創(chuàng)建?個必需的數據庫,可以使?SHOW DATABASES; 語句來查看當前所有存在的數據庫,如下。

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
4 rows in set (0.01 sec)

可以看到,數據庫列表中包含了4個數據庫,mysql是必需的,它描述?戶訪問權限,?戶經常利?test數據庫做測試的?作,其他數據庫將在后?的章節(jié)中介紹。

創(chuàng)建數據庫是在系統(tǒng)磁盤上劃分?塊區(qū)域?于數據的存儲和管理,如果管理員在設置權限的時候為?戶創(chuàng)建了數據庫,則可以直接使?,否則,需要??創(chuàng)建數據庫。MySQL中創(chuàng)建數據庫的基本SQL語句格式為:

CREATE DATABASE [IF NOT EXISTS] <數據庫名> [[DEFAULT] CHARACTER SET <字符集名>] [[DEFAULT] COLLATE <校對規(guī)則名>];

<數據庫名>:創(chuàng)建數據庫的名稱。MySQL 的數據存儲區(qū)將以?錄?式表示 MySQL數據庫,因此數據庫名稱必須符合操作系統(tǒng)的?件夾命名規(guī)則,注意在 MySQL 中不區(qū)分??寫。

IF NOT EXISTS:在創(chuàng)建數據庫之前進?判斷,只有該數據庫?前尚不存在時才能執(zhí)?操作。此選項可以?來避免數據庫已經存在?重復創(chuàng)建的錯誤。

[DEFAULT] CHARACTER SET:指定數據庫的默認字符集。

mysql> create database test_db;
Query OK, 1 row affected (0.00 sec)
?
mysql> show create database test_db;
+----------+--------------------------------------------------------------------+
| Database | Create Database                                                    |
+----------+--------------------------------------------------------------------+
| test_db  | CREATE DATABASE `test_db` /*!40100 DEFAULT CHARACTER SET latin1 */ |
+----------+--------------------------------------------------------------------+
1 row in set (0.00 sec)

刪除數據庫

刪除數據庫是將已經存在的數據庫從磁盤空間上清除,清除之后,數據庫中的所有數據也將?起被刪除。刪除數據庫語句和創(chuàng)建數據庫的命令相似,MySQL中刪除數據庫的基本語法格式如下。

DROP {DATABASE | SCHEMA} [IF EXISTS] 庫名

注:IF EXISTS表示如果存在,則刪除庫。

如果指定的數據庫不存在,則刪除出錯。

mysql> drop database test_db;
Query OK, 0 rows affected (0.02 sec)

字符集/字符校驗

#查看字符校驗

show collation;

#查看字符集

show character set;

#查看字符集

SHOW CHARACTER SET [LIKE 'pattern' | WHERE expr]show character set [like '字符集名' | where 表達式];

#查看字符校驗

SHOW COLLATION [LIKE 'pattern' | WHERE expr] show collation [like '字符校驗名' | where 表達式]; 

修改數據庫

ALTER {DATABASE | SCHEMA} [db_name]
    alter_option ...
 
alter_option: {
    [DEFAULT] CHARACTER SET [=] charset_name | [DEFAULT] COLLATE [=] collation_name
}

#修改庫字符集

alter database 庫名 default character set = 字符集名;

#修改字符校驗

alter database test collate 字符校驗名;

幫助命令

#幫助

help

#幫助分類

help contents

#查看定義語言

help data definition

#查看操作語言

help data manipulation

#查看創(chuàng)建庫格式

help create database

數據庫存儲引擎

數據庫存儲引擎是數據庫底層軟件組件,數據庫管理系統(tǒng)(DBMS)使?數據引擎進?創(chuàng)建、查詢、更新和刪除數據操作。不同的存儲引擎提供不同的存儲機制、索引技巧、鎖定?平等功能,使?不同的存儲引擎,還可以獲得特定的功能。現(xiàn)在許多不同的數據庫管理系統(tǒng)都?持多種不同的數據引擎。MySQL的核?就是存儲引擎。

2.3.1 MySQL存儲引擎簡介MySQL提供了多個不同的存儲引擎,包括處理事務安全表的引擎和處理?事務安全表的引擎。在MySQL中,不需要在整個服務器中使??種引擎,針對具體要求可以對每?個表使?不同的存儲引擎。MySQL5.5?持的存儲引擎有:InnoDB、MyISAM、Memory等。

mysql> show engines;
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| Engine             | Support | Comment                                                        | Transactions | XA   | Savepoints |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| MRG_MYISAM         | YES     | Collection of identical MyISAM tables                          | NO           | NO   | NO         |
| CSV                | YES     | CSV storage engine                                             | NO           | NO   | NO         |
| InnoDB             | DEFAULT | Supports transactions, row-level locking, and foreign keys     | YES          | YES  | YES        |
| BLACKHOLE          | YES     | /dev/null storage engine (anything you write to it disappears) | NO           | NO   | NO         |
| MyISAM             | YES     | MyISAM storage engine                                          | NO           | NO   | NO         |
| PERFORMANCE_SCHEMA | YES     | Performance Schema                                             | NO           | NO   | NO         |
| ARCHIVE            | YES     | Archive storage engine                                         | NO           | NO   | NO         |
| MEMORY             | YES     | Hash based, stored in memory, useful for temporary tables      | NO           | NO   | NO         |
| FEDERATED          | NO      | Federated MySQL storage engine                                 | NULL         | NULL | NULL       |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
9 rows in set (0.01 sec)

查看默認存儲引擎

mysql> show variables like 'default_storage_engine';
+------------------------+--------+
| Variable_name          | Value  |
+------------------------+--------+
| default_storage_engine | InnoDB |
+------------------------+--------+
1 row in set (0.06 sec)

存儲引擎簡介

  1. 存儲引擎說?了就是數據存儲的格式,不同的存儲引擎功能不同,占?的空間??不同,讀取性能也不同。
  2. 數據庫存儲引擎是數據庫底層軟件組件,不同的存儲引擎提供不同的存儲機制。
  3. 在 MySQL 中,不需要在整個服務器中使?同?種存儲引擎,可以對每?個表使?不同的存儲引擎。
  4. MySQL ?持多種存儲引擎,如 InnoDB 、MyISAM 、Memory 、Merge 、Archive 、CSV 、Federated 等等。

MyISAM 存儲引擎特點

  1. MySQL 5.5 之前使? MyISAM 引擎,MySQL 5.5 之后使? InnoDB 引擎。
  2. MyISAM 引擎讀取速度較快,占?資源相對較少,不?持事務,不?持外鍵約束,但?持全?索引。
  3. 讀寫互相阻塞,也就是說讀數據的時候你就不能寫數據,寫數據的時候你就不能讀數據。
  4. MyISAM 引擎只能緩存索引,?不能緩存數據。

MyISAM 適?場景

  1. 不需要事務?持的業(yè)務,例如轉賬就不?。
  2. 適?于讀數據?較多的業(yè)務,不適?于讀寫頻繁的業(yè)務。
  3. 并發(fā)相對較低、數據修改相對較少的業(yè)務。
  4. 硬件資源?較差的機器可以考慮使? MyISAM 引擎。

InnoDB 存儲引擎特點

  1. 事務型數據庫的?選引擎,?持事務安全表,?持?鎖定和外鍵,MySQL5.5.5 版本之后,InnoDB 作為默認存儲引擎。
  2. 具有提交、回滾和崩潰恢復能?的事務安全存儲引擎,能處理巨?數據量,性能及效率?,完全?持外鍵完整性約束。
  3. 具有?常?效的緩存特性,能緩存索引也能緩存數據,對硬件要求?較?。
  4. 使? InnoDB 時,將在 MySQL 數據?錄下創(chuàng)建?個名為 ibdata1 的 10MB ??的?動擴展數據?件,以及兩個名為 ib_logfile0 和 ib_logfile1 的 5MB ??的?志?件。

InnoDB 適?場景

  1. 需要事務?持的業(yè)務、?并發(fā)的業(yè)務。
  2. 數據更新較為頻繁的場景,?如 BBS、SNS、微博等。
  3. 數據?致性要求較?的業(yè)務,?如充值轉賬、銀?卡轉賬。

Memory 存儲引擎特點

  1. Memory 存儲引擎將表中的數據存儲到內存中,為查詢和引?其他表數據提供快速訪問。
  2. Memory 存儲引擎執(zhí)? HASH 和 BTREE 索引,不?持 BLOB 和 TEXT 列,?持 AUTO_INCREMENT 列和對可包含 NULL 值得列的索引。
  3. 當不再需要 Memory 表的內容時,要釋放被 Memory 表使?的內存,應該執(zhí)?DELETE FROM 或 TRUNCATE TABLE ,或者刪除整個表。

存儲引擎的選擇

  1. 如果要提供提交、回滾和崩潰恢復能?的事務安全能?,并要求實現(xiàn)并發(fā)控制,InnoDB 是個很好的選擇。
  2. 如果數據表主要?來插?和查詢記錄,則 MyISAM 引擎能提供較?的處理效率。
  3. 如果只是臨時存放數據,數據量不?,并且不需要較?的安全性,可以選擇將數據保存在內存中的 Memory 引擎,MySQL 使?該引擎作為臨時表,存放查詢的中間結果。
  4. 如果只有 INSERT 和 SELECT 操作,可以選擇 Archive 引擎,?持?并發(fā)的插?操作,如記錄?志信息可以使? Archive 引擎。

功能

MyISAM

Memory

InnoDB

存儲限制

256TB

RAM

64TB

?持事務

no

no

yes

支持全文索引

yes

no

no

支持數索引

yes

yes

yes

支持哈希緩存

no

yes

no

支持數據緩存

no

N/A

yes

支持外鍵

no

no

yes

總結

在mysql中,每個數據庫最多可創(chuàng)建20億個表,?個表允許定義1024列,每?的最??度為8092字節(jié)(不包括?本和圖像類型的?度)。

當表中定義有varchar、nvarchar或varbinary類型列時,如果向表中插?的數據?超過8092字節(jié)時將導致語句失敗,并產?錯誤信息。SQL Server對每個表中?的數量沒有直接限制,但它受數據庫存儲空間的限制。

每個數據庫的最?空間1048516TB,所以?個表可?的最?空間為1048516TB減去數據庫類系統(tǒng)表和其它數據庫對象所占?的空間。理論上?限? 就看你硬?夠不夠? ?多數情況先是你的硬?不夠。

到此這篇關于MySQL中庫的基本操作指南的文章就介紹到這了,更多相關MySQL庫的基本操作內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • linux下講解MySQL安裝與登錄方法

    linux下講解MySQL安裝與登錄方法

    MySQL安裝文件已被廣泛應用但是也在不斷的更新,這里介紹MySQL安裝文件設置使用,幫助大家安裝更新MySQL安裝文件系統(tǒng)。
    2010-11-11
  • mysql支持跨表delete刪除多表記錄

    mysql支持跨表delete刪除多表記錄

    Mysql可以在一個sql語句中同時刪除多表記錄,也可以根據多個表之間的關系來刪除某一個表中的記錄
    2012-12-12
  • MySQL8.0中的my.ini文件位置說明

    MySQL8.0中的my.ini文件位置說明

    這篇文章主要介紹了MySQL8.0中的my.ini文件位置說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • MySQL Select語句是如何執(zhí)行的

    MySQL Select語句是如何執(zhí)行的

    這篇文章主要介紹了MySQL Select語句是如何執(zhí)行的,幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下
    2020-11-11
  • MySQL group by和order by如何一起使用

    MySQL group by和order by如何一起使用

    這篇文章主要介紹了MySQL group by和order by如何一起使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-10-10
  • MySQL binlog中的事件類型詳解

    MySQL binlog中的事件類型詳解

    這篇文章主要介紹了MySQL binlog中的事件類型詳解,介紹的非常詳細,具有參考借鑒價值,需要的朋友可以參考下
    2016-08-08
  • Mysql百萬級分頁優(yōu)化技巧

    Mysql百萬級分頁優(yōu)化技巧

    這篇文章主要介紹了Mysql百萬級分頁優(yōu)化技巧,包括普通分頁和優(yōu)化分頁兩種,在數據量比較大的時候,我們盡量去利用索引來優(yōu)化語句。下面通過本文給大家詳細講解,一起看看吧
    2016-12-12
  • MySQL存儲IP地址的方法

    MySQL存儲IP地址的方法

    本文介紹了MySQL存儲IP地址的方法其目的就是最大限度的優(yōu)化性能,需要的朋友可以參考下
    2015-07-07
  • 修改Mysql索引長度限制解決767?byte限制問題

    修改Mysql索引長度限制解決767?byte限制問題

    這篇文章主要介紹了修改Mysql索引長度限制解決767?byte限制問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • MySql數據庫備份的幾種方式

    MySql數據庫備份的幾種方式

    這篇文章主要介紹了MySql數據庫備份的幾種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12

最新評論