MySQL筆記

来源:https://www.cnblogs.com/iloveyoukm/archive/2019/04/21/10747614.html
-Advertisement-
Play Games

一、常用sql 1.1幫助命令 1.2SQL語言分類 1.3普通常用命令 1.4TRUNCATE與DELTE區別 二、備份與恢復 2.1mysqldump進行資料庫備份 2.2備份表 2.3備份資料庫表結構(不包含數據) 2.4備份資料庫表數據(不包含表結構) 2.5同時將數據和表結構分離導出 2. ...



一、常用sql

1.1幫助命令

mysql  help命令相當於linux的man命令;
help  contents;    #相當於linux man命令
update  mysql.user  set password= PASSWORD('123123')  where user="root" and  host="localhost";     #修改root用戶密碼

1.2SQL語言分類

1.數據查詢語言DQL
2.數據操作語言DML
3.事務處理語言TPL
4.數據控制語言DCL
5.數據定義語言DDL
6.指針控制需要CCL

1.3普通常用命令

show  create  database;    #列印創建資料庫的語法
select  database();            #列印use的資料庫
CREATE  USER  '用戶'@'主機'  IDENTIFIED BY  '密碼';    #授權用戶
rename  table  原表名  to  新表名;                                #重命名錶
select  id, name from  test  where  id = 2 and name='mashy';    #select 查詢語句
mysql -e "select * from 庫名.表名"                                #使用-e參數,可在命令行執行MySQL命令

1.4TRUNCATE與DELTE區別

TRUNCATE:通過釋放存儲表數據所用的數據頁來刪除數據,並且只在事務日誌中記錄頁的釋放,因此使用的系統和事務日誌資源更少。
DELETE語句每刪除一行,並且會在事務日誌中為所刪除的每一行記錄一項。
TRUNCATE與不帶WHERE子句的DELETE語句功能相同:兩者均刪除表中的全部行,到TRUNCATE比DELETE速度更快。

二、備份與恢復

2.1mysqldump進行資料庫備份

mysqldump -u user -p password 參數 資料庫名 > 備份文件名.sql 
mysqldump -u user -p password -B 資料庫名 > 備份文件名.sql                # -B參數的作用是增加創建資料庫和連接資料庫的語句,並且後面可直接接多個庫名,即同時備份多個庫。
mysqldump -u user -p password -B 資料庫名 | gzip > 備份文件名.sql        #指定壓縮命令gzip壓縮備份資料庫
mysqldump -u user -p password -A > 備份文件名.sql                             #備份所有的資料庫

2.2備份表

mysqldump -u user -p password 資料庫名 表名> 備份文件名.sql 
#### 備份單個表
mysqldump -u user -p password 參數 資料庫名 表名1 表名2> 備份文件名.sql 
#### 備份多個表

2.3備份資料庫表結構(不包含數據)

mysqldump -u user -p password -d 資料庫名 > 備份文件名.sql         #-d參數表示備份資料庫表結構,不包含數據

2.4備份資料庫表數據(不包含表結構)

mysqldump -u user -p password -t 資料庫名 > 備份文件名.sql 

2.5同時將數據和表結構分離導出

#需調整配置文件參數並重啟MySQL
#在[mysqld]模塊下增加secure_file_priv=''
mysqldump -u user -p password 資料庫名 表名 -T  備份目錄 

2.6mysqldump工作原理

    利用mysqldump命令備份數據的過程,實際上就是把數據(包括庫表)從MySQL庫里以SQL語句的形式直接輸出或者生成備份文件的過程,這種備份成SQL語句的方式稱為邏輯備份。

2.7取出mysql庫名

./bin/mysql -uroot -p123 -e "show databases" | egrep -v "_schema| atabase"

2.8binlog是什麼

    Binlog是一個二進位格式的文件,用於記錄用戶對資料庫更新的SQL語句信息,例如更改資料庫庫表和更改內容的SQL語句都會記錄到binlog里,但是對錶庫等內容的查詢則不會記錄到日誌中。因為binlog文件里的數據就是寫入資料庫的數據,使用binlog文件恢複數據,稱之為二進位增量數據恢復
#開啟binlog文件
log_bin=mysql-bin
server_id=1

2.9記錄binlog位置的特殊參數(—master-data)

    使用--master-data參數備份後,在備份的文件對應的SQL語句里會添加CHANGE  
MASTER 語句及binlog文件及位置點信息。
    當"--master-data=1"時,備份結果為可執行的"CHANGE MASTER..." 語句;當"--master-data=2"時,備份結果為註釋的"CHANGE MASTER"語句。

2.9.1鎖表備份

mysqldump 加上-x參數

innodb表特有的備份參數(—single-transaction)

mysqldump -u user -p password -B  --master-data=2 --single-transaction 資料庫名  > 備份文件名.sql
#當使用mysqldump的“--single-transaction”參數對innodb表進行備份時,會開啟一個事務,並將整個備份過程放到一個事務里,以確保執行本次dump會話時,不會看到其他連接會話已經提交了的數據,即備份開始的時候表是什麼樣,備份出來就是什麼樣子。

2.9.2將表數據導出為純文本

select * from test into outfile "/data/test_1.txt" ;        #導出時設置字元集
select * from test into outfile "/data/test_2.txt" character set utf8 ;        #以指定的分隔符導出,這裡指定“-”為不同域之間的分隔符
select * from test into outfile "/data/test_3.txt" character set utf8 fields terminated by '-';        #導出時設置對欄位內容進行引用,此處是'"'雙引號

2.9.3導入表

mysql> load data infile '/data/test_1.txt' into table test ;    #從/data/test_1.txt讀數據寫入test表中

三、恢複數據庫

1.進入mysql資料庫source 備份.sql
2.mysql 需要恢復的庫名  < 備份.sql 

3.1mysql -e 參數查看mysql數據

mysql -u user -p password -e "select * from 庫名.表名;"        #查看表數據
mysql -u user -p password -e "show processlist;"                 #查看SQL線程執行狀態
mysql -u user -p password -e "show full processlist;"            #查看完整SQL線程狀態
show variables like "%_timeout%";                            #產看超時參數配置
在my.cnf文件mysqld模塊設置timeout值
interactive_timeout=120
wait_timeout=120
#修改完成後重啟mysql資料庫使配置生效

3.2查看資料庫狀態命令

show global status; #查看整個資料庫運行的狀態信息
show processlist ;  #查看正在執行的SQL語句,可能無法看全完整的SQL語句
show full processlist ;     #查看正在執行的完整SQL語句。
show variables;     #查看資料庫的配置參數信息
show variables like "%_timeout%"; #過濾查看
kill ID                 #殺掉SQL線程的命令,ID為線程號
show session status;    #查看當前整個資料庫的運行狀態
show engine innodb status ; #顯示innodb引擎的性能狀態

3.3mysqladmin常用命令參數

mysqladmin password newpasswd   #設置密碼
mysqladmin -uroot -ppasswd password newpasswd   #修改密碼
mysqladmin -uroot -ppasswd status #查看狀態
mysqladmin -uroot -ppasswd -i 1 status  #每秒查看一次狀態
mysqladmin -uroot -ppasswd extended-status #查看當前整個資料庫的運行狀態
mysqladmin -uroot -ppasswd processlist #查看執行的SQL語句信息
mysqladmin -uroot -ppasswd processlist -i 1  #每秒查看一次執行的SQL語句信息
mysqladmin -uroot -ppasswd shutdown         #關閉mysql服務
mysqladmin -uroot -ppasswd variables    #查看資料庫的配置參數信息

3.4解析指定庫的binlog日誌

mysqlbinlog -d oldboy mysql-bin.000001 -r bin.sql        
#mysqlbinlog可以指定-d實現分庫導出binlog,如果使用-d參數,那麼在更新數據時,必須要有use庫名,才能分出指定庫的binlog。必須採用如下寫法:
use 庫名;
insert into  test values(1,'huge');
下麵這種寫法就不行
insert into 庫名.test values(2,'oldgirl');

3.5binlog過期清理

在my.cnf中配置
expire_logs_days=7
#只保存7天內的binlog日誌

四、資料庫備份概念

4.1全量備份

    全量數據就是資料庫中所有的數據(或某一個庫的全部數據);全量備份就是把資料庫中所有數據進行備份

4.2增量備份

    增量數據就是指上一次全量備份數據之後到下一次全量備份數據之前資料庫所更新的數據。

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.按姓氏筆畫排序:Select * From TableName Order By CustomerName Collate Chinese_PRC_Stroke_ci_as 2.資料庫加密:select encrypt('原始密碼')select pwdencrypt('原始密碼')select ...
  • mysql優化二之鎖機制 mysql提供了鎖機制和MVCC機制來保證併發操作的安全性,這裡主要討論鎖機制, MVCC見下篇文章 mysql的鎖按照鎖粒度可分為行鎖與表鎖,按照操作類型劃分可讀鎖和寫鎖 InnoDB存儲引擎支持表鎖和行鎖,預設鎖為行鎖,MyIsam只支持表鎖 鎖粒度越高則併發性越好 表 ...
  • SQL中只有兩列數據(欄位1,欄位2),將其相同欄位1的行轉列 轉換前: 轉換後: 轉自:https://bbs.csdn.net/topics/392320974 ...
  • 一.Spark2.0的新特性Spark讓我們引以為豪的一點就是所創建的API簡單、直觀、便於使用,Spark 2.0延續了這一傳統,併在兩個方面凸顯了優勢: 1、標準的SQL支持; 2、數據框(DataFrame)/Dataset (數據集)API的統一。 在SQL方面,我們已經對Spark的SQL ...
  • 前言 關於資料庫鎖,是一個很重要的知識點; 不少人在開發的時候,應該 很少會註意到 這些鎖的問題,也很少會給程式加鎖(除了 庫存 這些對數量準確性要求極高的情況下); 一般也就聽過常說的樂觀鎖和悲觀鎖,瞭解過基本的含義之後就沒了,沒有去實際的操作過,本文將簡單的整理一下資料庫鎖的知識,希望對大家有所 ...
  • 數據導出時,出現錯誤: 一臉懵逼,百度了下,是導出數量有格式有限制。一開始導出為excel表格式,後改為文本格式,不會報錯。 ...
  • 在in\not in\except這種查詢結構時,如果涉及到的數據量較大,建議堅決用連接left join/inner join等替換掉,否則查詢效率十分低下。 ...
  • 更改表結構: alter TABLE 表1 ALTER COLUMN 列名1 NCHAR(40) ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...