程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> MSSQL >> sql server 2000數據庫備份復原的圖文教程

sql server 2000數據庫備份復原的圖文教程

編輯:MSSQL

sql server 2000數據庫備份復原的圖文教程。本站提示廣大學習愛好者:(sql server 2000數據庫備份復原的圖文教程)文章只能為提供參考,不一定能成為您想要的結果。以下是sql server 2000數據庫備份復原的圖文教程正文


MSSQL是微軟公司的一款數據庫治理體系,本文將具體引見MSSQL2000中數據庫的備份和復原功效。

1、起首請包管您的備份文件是bak文件,而且備份文件可以或許正常復原。

2、翻開“企業治理器”→“數據庫”,選擇您要復原的數據庫,右鍵“一切義務”→“復原數據庫”。如圖:

MSSQL2000數據庫備份復原的圖文教程

3、假如須要復原之前備份過的文件,直接在“復原”選擇“數據庫”,然後鄙人方選摘要復原的備份便可,假如是從其他處所上傳或許復制過去的,請選擇“從裝備”復原。點“添加”,添加您須要復原的備份文件。如圖:

MSSQL2000數據庫備份復原的圖文教程

4、點擊肯定後,點復原數據庫上的“選項”檢查恢復後數據庫的途徑,有時能夠會復原掉敗,可以勾選“在現稀有據庫上強迫復原”,至此,數據庫復原的進程就講完了。如圖:

MSSQL2000數據庫備份復原的圖文教程

5、假如您曾經有MDF和LDF文件,可以用數據庫的附加功效停止附加。起首將您的數據庫mdf和ldf文件上傳到辦事器的某個目次(普通不要放在 體系盤,以避免體系破壞形成數據喪失),好比d:\mssql目次,並給該目次mssqluser的完整掌握權限。然後翻開企業治理器,右鍵點擊“數據庫” ——“一切義務”——“附加數據庫”,如圖:

MSSQL2000數據庫備份復原的圖文教程

點擊“…”添加須要附加的mdf文件,並指定要附加的數據庫名和數據庫一切者如圖:

MSSQL2000數據庫備份復原的圖文教程

點擊肯定附加數據庫勝利,如圖:

MSSQL2000數據庫備份復原的圖文教程

留意,假如放在其他目次,務必包管該目次先加上mssqluser的完整掌握權限,不然復原或備份會掉敗。保留備份的目次也必需有這個權限!!

y | +-------------+----------+ | 163 | hangzhou | | 9you | shanghai | | 百度 | hangzhou | | tx | hangzhou | +-------------+----------+ 4 rows in set (0.00 sec) mysql> select * from table2; +----------+-------------+ | order_id | customer_id | +----------+-------------+ | 1 | 163 | | 2 | 163 | | 3 | 9you | | 4 | 9you | | 5 | 9you | | 6 | tx | +----------+-------------+ 7 rows in set (0.00 sec)

預備任務做的差不多了,開端明天的總結吧。
CROSS JOIN聯接(穿插聯接)

CROSS JOIN對兩個表履行FROM語句(笛卡爾積)操作,前往兩個表中一切列的組合。假如左表有m行數據,右表有n行數據,則履行CROSS JOIN將前往m*n行數據。CROSS JOIN只履行SQL邏輯查詢語句履行的前三步中的第一步。

CROSS JOIN可以干甚麼?因為CROSS JOIN只履行笛卡爾積操作,其實不會停止過濾,所以,我們在現實中,可使用CROSS JOIN生成年夜量的測試數據。

對上述測試數據,應用以下查詢:

select * from table1 cross join table2;

就會獲得以下成果:

+-------------+----------+----------+-------------+
| customer_id | city   | order_id | customer_id |
+-------------+----------+----------+-------------+
| 163     | hangzhou |    1 | 163     |
| 9you    | shanghai |    1 | 163     |
| 百度    | hangzhou |    1 | 163     |
| tx     | hangzhou |    1 | 163     |
| 163     | hangzhou |    2 | 163     |
| 9you    | shanghai |    2 | 163     |
| 百度    | hangzhou |    2 | 163     |
| tx     | hangzhou |    2 | 163     |
| 163     | hangzhou |    3 | 9you    |
| 9you    | shanghai |    3 | 9you    |
| 百度    | hangzhou |    3 | 9you    |
| tx     | hangzhou |    3 | 9you    |
| 163     | hangzhou |    4 | 9you    |
| 9you    | shanghai |    4 | 9you    |
| 百度    | hangzhou |    4 | 9you    |
| tx     | hangzhou |    4 | 9you    |
| 163     | hangzhou |    5 | 9you    |
| 9you    | shanghai |    5 | 9you    |
| 百度    | hangzhou |    5 | 9you    |
| tx     | hangzhou |    5 | 9you    |
| 163     | hangzhou |    6 | tx     |
| 9you    | shanghai |    6 | tx     |
| 百度    | hangzhou |    6 | tx     |
| tx     | hangzhou |    6 | tx     |
+-------------+----------+----------+-------------+

INNER JOIN聯接(內聯接)

INNER JOIN比CROSS JOIN壯大的一點在於,INNER JOIN可以依據一些過濾前提來婚配表之間的數據。在SQL邏輯查詢語句履行的前三步中,INNER JOIN會履行第一步和第二步;即沒有第三步,不添加內部行,這是INNER JOIN和接上去要說的OUTER JOIN的最年夜差別之一。

如今來看看應用INNER JOIN來查詢一下:

select * 
from table1 
inner join table2 
on table1.customer_id=table2.customer_id;

就會獲得以下成果:

+-------------+----------+----------+-------------+
| customer_id | city   | order_id | customer_id |
+-------------+----------+----------+-------------+
| 163     | hangzhou |    1 | 163     |
| 163     | hangzhou |    2 | 163     |
| 9you    | shanghai |    3 | 9you    |
| 9you    | shanghai |    4 | 9you    |
| 9you    | shanghai |    5 | 9you    |
| tx     | hangzhou |    6 | tx     |
+-------------+----------+----------+-------------+

關於INNER JOIN來講,假如沒有應用ON前提的過濾,INNER JOIN和CROSS JOIN的後果是一樣的。當在ON中設置的過濾前提列具有雷同的稱號,我們可使用USING症結字來簡寫ON的過濾前提,如許可以簡化sql語句,例如:

select * from table1 inner join table2 using(customer_id);

在現實編寫sql語句時,我們都可以省略失落INNER症結字,例如:

select * 
from table1 
join table2 
on table1.customer_id=table2.customer_id;

然則,請記住,這照樣INNER JOIN。
OUTER JOIN聯接(外聯接)

哦,記得有一次加入面試,還問我這個成績來著,那在這裡再好好的總結一下。經由過程OUTER JOIN,我們可以依照一些過濾前提來婚配表之間的數據。OUTER JOIN的成果集等於INNER JOIN的成果集加上內部行;也就是說,在應用OUTER JOIN時,SQL邏輯查詢語句履行的前三步,都邑履行一遍。關於若何添加內部行,請參考《SQL邏輯查詢語句履行次序》這篇文章中的添加內部行部門內容。

MySQL數據庫支撐LEFT OUTER JOIN和RIGHT OUTER JOIN,與INNER症結字一樣,我們可以省略OUTER症結字。關於OUTER JOIN,異樣的也能夠應用USING來簡化ON子句。所以,關於以下sql語句:

select * 
from table1 
left outer join table2 
on table1.customer_id=table2.customer_id;

我們可以簡寫成如許:

select * 
from table1 
left join table2 
using(customer_id);

然則,與INNER JOIN還有一點差別是,關於OUTER JOIN,必需指定ON(或許using)子句,不然MySQL數據庫會拋出異常。
NATURAL JOIN聯接(天然銜接)

NATURAL JOIN同等於INNER(OUTER) JOIN與USING的組合,它隱含的感化是將兩個表中具有雷同稱號的列停止婚配。異樣的,NATURAL LEFT(RIGHT) JOIN同等於LEFT(RIGHT) JOIN與USING的組合。好比:

select * 
from table1 
join table2 
using(customer_id);

select * 
from table1 
natural join table2;

等價。

在好比:

select * 
from table1 
left join table2 
using(customer_id);

select * 
from table1 
natural left join table2;

等價。
STRAIGHT_JOIN聯接

STRAIGHT_JOIN其實不是一個新的聯接類型,而是用戶對sql優化器的掌握,其同等於JOIN。經由過程STRAIGHT_JOIN,MySQL數據庫會強迫先讀取右邊的表。舉個例子來講,好比以下sql語句:

explain select * 
from table1 join table2 
on table1.customer_id=table2.customer_id;

它的重要輸入部門以下:

+----+-------------+--------+------+---------------+
| id | select_type | table | type | possible_keys |
+----+-------------+--------+------+---------------+
| 1 | SIMPLE   | table2 | ALL | NULL     |
| 1 | SIMPLE   | table1 | ALL | PRIMARY    |
+----+-------------+--------+------+---------------+

我們可以很清晰的看到,MySQL是先選擇的table2表,然後再停止的婚配。假如我們指定STRAIGHT_JOIN方法,例如:

explain select * 
from table1 straight_join table2 
on table1.customer_id=table2.customer_id;

上述語句的重要輸入部門以下:

+----+-------------+--------+------+---------------+
| id | select_type | table | type | possible_keys |
+----+-------------+--------+------+---------------+
| 1 | SIMPLE   | table1 | ALL | PRIMARY    |
| 1 | SIMPLE   | table2 | ALL | NULL     |
+----+-------------+--------+------+---------------+

可以看到,當指定STRAIGHT_JOIN方法今後,MySQL就會先選擇table1表,然後再停止的婚配。

那末就有讀者問了,這有啥利益呢?機能,照樣機能。因為我這裡測試數據比擬少,年夜停止年夜量數據的拜訪時,我們指定STRAIGHT_JOIN讓MySQL先讀取右邊的表,讓MySQL依照我們的志願來完成聯接操作。在停止機能優化時,我們可以斟酌應用STRAIGHT_JOIN。
多表聯接

在下面的一切例子中,我都是應用的兩個表之間的聯接,而更多時刻,我們在任務中,能夠不止要聯接兩張表,能夠要觸及到三張或許更多張表的聯接查詢操作。

關於INNER JOIN的多表聯接查詢,可以隨便支配表的次序,而不會影響查詢的成果。這是由於優化器會主動依據本錢評價出拜訪表的次序。假如你想指定聯接次序,可使用下面總結的STRAIGHT_JOIN。

而關於OUTER JOIN的多表聯接查詢,表的地位分歧,觸及到添加內部行的成績,便可能會影響終究的成果。
總結

這是MySQL中聯接操作的全體內容了,內容雖多,然則都還比擬簡略,聯合文章中的例子,再本身現實操作一遍,完整可以弄定的。這一篇文章就如許了。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved