java MySQL資料庫編程 第五章:事務,視圖,索引,備份和恢復

来源:http://www.cnblogs.com/ppdpp/archive/2017/09/27/7604092.html
-Advertisement-
Play Games

第五章:事務,視圖,索引,備份和恢復 1.事務是指將一系列數據操作捆綁成為一個整體進行統一管理. 一、事務語法: 1.開始事務 語法: BEGIN 或 START TRAINSACTION; 2.提交事務:執行的所有數據更新將永久地保存在資料庫數據文件中 語法: COMMIT; 3.回滾事務:將數據 ...


第五章:事務,視圖,索引,備份和恢復

1.事務是指將一系列數據操作捆綁成為一個整體進行統一管理.

 

 

一、事務語法:

 

1.開始事務

語法: BEGIN 或 START TRAINSACTION;

 

2.提交事務:執行的所有數據更新將永久地保存在資料庫數據文件中

語法: COMMIT;

 

3.回滾事務:將數據狀態回滾到事務開始前

語法:  ROLLBACK;

 

 

4.設置自動提交開或關

MySQL中預設開始自動提交模式

關:值0: 關閉自動提交

語法: SET autocommit=0;

 

開:值1:開啟自動提交

語法: SET autocommit=1;

 

 

二、編寫事務時要遵循以下原則:

 

  • 事務儘可能簡短

 

  • 事務中訪問的數據量儘量最少

 

  • 查詢數據時儘量不要使用事務

 

  • 在事務處理過程中儘量不要出現等待用戶輸入的操作

 

什麼是視圖?

視圖是保存在資料庫中的select查詢

 

三、創建和使用視圖

 

1.使用SQL語句創建視圖

語法: CREATE  VIEW  視圖名

AS

<SELECT  語句>;

註意:在SQL語句命名規範中,視圖一般以view_xxx或v_xxx的樣式來命名.

使用SQL語句刪除視圖

語法:DROP  VIEW  [IF EXISTS] 視圖名;

 

2.使用SQL語句查看視圖數據

語法:SELECT 欄位1, 欄位2,…..FROM view_name;

 

3.使用時視圖要註意

每個視圖中可以使用多個表與查詢相似一個視圖可以嵌套另一個視圖,但最好不要超過三層

對視圖數據進行添加,更新和刪除操作直接引用表中的數據當視圖數據來自多個表時,不允許添加和刪除數據。

 

 

什麼是索引?

根據索引的存儲類型,可以將索引分為B-樹索引(BTREE)和哈希索引(HASH)索引的作用是通過使用索引。

 

四、索引

索引分類:

普通索引、唯一索引、主鍵索引、全文索引、空間索引

 

普通索引

普通索引時MySQL中的基本索引類型,允許在定義索引的列中插入重覆值和空值.它的唯一任務是加快對數據的訪問速度.

 

唯一索引

唯一索引不允許兩行具有相同的索引值.創建唯一索引的列允許有空值.

 

主鍵索引

主鍵索引要求主鍵中的每個值時非空,唯一的.

複合索引

可以將多個列組合作為索引,這種索引稱為複合索引.

 

全文索引

全文索引的作用是在定義索引的列上支持值的全文查找,允許在這些索引列中插入重覆值和空值.

 

五、索引的語法

1.創建索引

 

語法: CREATE [UNIQUE | FULLTEXT | SPATIAL] INDEX index_name

 

ON table_name (column_name[length].....);

 

(1)UNIQUE | FULLTEXT | SPATIAL: 分別表示唯一索引,全文索引和空間索引,為可選參數

(2)Index_name :指定索引名

(3)Table_name:指定創建索引的表名

(5)column_name:指定需要創建索引的列

(6)Length:指定索引長度

 

2.刪除索引

語法:  DROP INDEX index_name ON table_name;

 

(1)刪除表時,該表的所有索引將同時被刪除

(2)刪除表中的列時,如果要刪除的列為索引的組成部分,則該列也會從索引中刪除.

 

3.查看索引

 

語法: SHOW INDEX FROM table_name;

 

(1)在查詢語句後加”\G”,表示將結果集按列表示.

 

 

六:備份和恢復

 

mysqldump命令備份資料庫

1.mysqldump命令格式

語法:mysqldump -u username -h host -ppassword dbname[tbname1[,tbname2.....]]

>filename.sql

 

解析:

Username:表示用戶名

Host表示登錄用戶的主機名稱,如本機為主機可省略

Password表示登錄密碼

Dbname為需要備份的資料庫

Tbname為需要備份的數據表,可指定多張表,為可選項.如備份整個資料庫則此項省略

Filename.sql表示備份文件的名稱

 

2.mysql命令恢複數據庫

 

語法: mysql -u username -p [dbname]<filename.sql

 

解析:

username 表示用戶

Dbname 資料庫名

filename.sql 為資料庫備份後的文件

註意:在執行該語句之前,必須在MySQL伺服器中創建新資料庫,如果不存在新資料庫恢複數據庫過程將會出錯。

 

 

3.Mysql命令在DOS環境下的恢複數據庫命令:

 

語法:source filename;

通過複製文件實現數據恢復


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

-Advertisement-
Play Games
更多相關文章
  • Keep UINavigationBar at the top (Don't scroll with keyboard) (#21, #24) If you don't want to hide the default UINavigationBar of UINavigationControlle ...
  • 原文地址:http://www.linuxidc.com/Linux/2007-05/4338.htm # /etc/init.d/mysql stop# mysqld_safe --user=mysql --skip-grant-tables --skip-networking &# mysql ... ...
  • 安裝oracle11g客戶端,再安裝oacle12c odac插件。應將oracle11g的環境變數放到12c環境變數前面。 ...
  • 標簽:SQL SERVER/MSSQL SERVER/資料庫/DBA/ 概述 SQLServer2016發佈版本到現在已有一年多的時間了,目前最新的穩定版本是SP1版本。接下來就開看看2016在Alwyson上做了哪些改進,記得之前我在寫2014Alwayson的時候提到過幾個需要改進的問題在201 ...
  • MySQL更改線上配置方案思想:原則上,需要備機、備份工作准備到位,有參數調優配置方案、有配置回退方案、有應急切換備機方案。以上方案評審無問題,然後可以和客戶約定實施的時間。服務中斷時間,先向客戶側申請30分鐘吧。如果客戶承受不了,就讓客戶自己給個時間。在規定時間內,我們做得到就做,做不到就立即回退 ...
  • 我們可能經常安裝和部署資料庫伺服器,但是可能突然忘記了某個設置,為後來的運維造成隱患。下麵是國外大牛整理的的檢查列表。 其實也包含了很多我們平時資料庫配置的最佳實踐。比如TEMPDB 文件的個數,比如資料庫文件,日誌文件如何存放,最大記憶體的設置等等。如果有補充的歡迎留言 ...
  • UNPIVOT UNPIVOT則相反,把數據從列旋轉到行 SELECT * INTO product_vlues FROM ( SELECT NAME , YEAR(shijian) AS shijian , jiage FROM dbo.product ) AS ov PIVOT ( SUM(ov ...
  • 安裝MySQL碰到的超級新手問題 看了各種教程從官網下載了mysql-5.7.17.msi,安裝碰到問題。 .紅框位置提示沒安裝Microsoft visual c++ 2013 runtime ,很是鬱悶剛開始沒註意看直接下一步了。因為這個問題,導致MySQL Server安裝不成功。 但是MyS ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...