當前位置:首頁 » 數據倉庫 » 資料庫原理查詢分析題
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

資料庫原理查詢分析題

發布時間: 2022-05-01 03:21:45

㈠ 《資料庫原理》求答案!


1.有組織,可共享.
2.實體完整性,參照完整性.
3.網狀模型.關系模型
4.一致性,原子性.
5.數據不一致.數據丟失.
6.外模式,內模式.
7.對內儲存,對外儲存.
8.讀鎖(s)寫鎖(x)
9.E-R圖
10.消除了非主屬性對碼的傳遞函數依賴.
二.
1.物理的邏輯獨立性就是數據的存儲和資料庫系統相互獨立,資料庫里的數據單獨存在於資料庫操作系統之外.
2.網狀模型的優點:分層明確,且每個結點的數據都相互獨立.缺點:關系表現形式太復雜,不容易明顯看清楚.
3.由於需要對數據進行增刪改查,所以需要對數據修改做保護,避免出現增刪改查的異常.
4.內模式是指資料庫的存儲模式,單純的資料庫數據存儲.
三.
1.∏sno,sname,sage,sdept(student)σ
2.∏sdept(σsno,sname,sage,sdept(student))
3.∏ name,sdept(σcno='1'∧(student*course*c)
四.
1.select sno,sname,sage,sdept
from student
2.select sname,sage
from student
where sdept='IS' and sdept='MS' and sdept='CS'
3.select sno,sname,sage,sdept,cno,grade
from student,sc
where student sno=sc sno
五.事物T1 事物T2
讀A
讀B
B=A+1
寫回B
A=B+1
寫回A
六.不明白此題.我的題不這樣的問.
七.同上
八.倉庫 (庫號,面積,電話號碼)倉庫號是主碼
零件 (零件號,名稱,規格,單價,描述)零件號是主碼
供應商(供應商號,姓名,地址,電話號碼,賬號)供應商是主碼
項目(項目號,預算,開工日期)項目號是主碼
職工(職工號,姓名,年齡,職稱)職工號是主碼

㈡ SQL資料庫系統原理中數據查詢問題,題目如下:

自定義的列名,因為你有用到函數,sum和avg是函數方法,那麼用它們查詢出來的結果,所顯示的列名
都是
「無列名」,那麼加了
as
什麼什麼
接在函數後面,那麼顯示查詢結果時,這個名稱就是它的列名,方便列作用的理解。
其實你只要將這條語句
分加
as...
和不加as..
到資料庫里執行一遍就能看出比對結果來了

㈢ 資料庫原理試題(簡答)

1、DBS由哪幾個部分組成?

答:DBS由四部分組成:資料庫、硬體、軟體、資料庫管理員。

2.資料庫的並發操作會帶來哪些問題?

答:資料庫的並發操作會帶來三類問題:丟失更新問題;不一致分析問題和「臟數據」的讀出。

3.簡述採用E-R圖方法的資料庫概念設計的過程。
答:E-R模型的圖示法:(1)實體集表示法; (2)屬性表法; (3)聯系表示法。
層次模型的基本結構是樹形結構,具有以下特點:
(1)每棵樹有且僅有一個無雙親結點,稱為根;
(2)樹中除根外所有結點有且僅有一個雙親。
從圖論上看,網狀模型是一個不加任何條件限制的無向圖。
關系模型採用二維表來表示,簡稱表,由表框架及表的元組組成。一個二維表就是一個關系。
在二維表中凡能唯一標識元組的最小屬性稱為鍵或碼。從所有侯選健中選取一個作為用戶使用的鍵稱主鍵。表A中的某屬性是某表B的鍵,則稱該屬性集為A的外鍵或外碼。
關系中的數據約束:
(1)實體完整性約束:約束關系的主鍵中屬性值不能為空值;
(2)參照完全性約束:是關系之間的基本約束;
(3)用戶定義的完整性約束:它反映了具體應用中數據的語義要求。

4.簡述客戶/伺服器式DBS的一般結構。此時資料庫應用的功能如何劃分?
答:DBS :資料庫系統(Database System),DBS是實現有組織地、動態地存儲大量關聯數據,方便多用戶訪問的計算機軟體、硬體和數據資源組成的系統,即採用了資料庫技術的計算機系統。

㈣ 資料庫系統原理的題目(請會做的幫忙解決下)特此謝謝啊

補充樓上的
38.select sum(報酬) from 項目 where 項目號 in (select 項目號 from 參加 where 學號 in (select 學號 from 學生 where 系別號='系1')) union select sum(報酬) from 項目 where 項目號 in (select 項目號 from 參加 where 學號 in (select 學號 from 學生 where 系別號='系2')) union ......;

40.create view cs ('1','2','3') as select 學號,姓名,項目名稱 from 項目,學生 ;
視圖表頭
最後要加分號

㈤ 求解,資料庫原理測試題。

  1. create database booksales

  2. create table cb

    (cid char(10) froeign key references customer(cid) not null,

    bid char(10) froeign key references book(bid) not null,

    shoppingdate datetime not null,

    quantity int null,

    constranit cb_c_b primary key(cid,bid)

    )

  3. 這么多題目才5金幣,後面的不寫啦!

㈥ 資料庫原理與應用練習求答案!~急用

1,
CREATE SCHEMA ourclass_db authorization XXXXX;
CREATE TABLE Domitory(
Dno CHAR(6) PRIMARY KEY,
Dphone CHAR(7));
CREATE TABLE Student(
Sno CHAR(6) PRIMARY KEY,
Sname CHAR(20) NOT NULL,
Ssex CHAR(2) CHECK(Ssex in('w','m'),
Sid CHAR(18) UNIQUE,
Sdo CHAR(6),
FOREIGN KEY(Sdo) REFERENCES Domitory(Dno));
2,
INSERT INTO Domitory VALUES('101','6331157');
INSERT INTO Domitory VALUES('102','6331158');
UPDATE Domitory SET Dphone='6331158' WHERE Dno='101';
DELETE FROM Domitory WHERE Dno='102';
3,
SELECT * FROM Domitory;
SELECT Sname,Ssex,Dphone FROM Domitory,Student
WHERE Student.Sdo=Domitory.Dno AND
Sname LIKE '張%' AND Ssex='w';
SELECT Sdo,COUNT(*) FORM Student GROUP BY Sdo;
CREATE VIEW Stu AS SELECT Sno,Sname,Ssex,Sid,Sdo,Dphone
FROM Student,Domitory WHERE Student.Sdo=Domitory.Dno;
4,
CREATE SCHEMA orderform authorization YYYYY;
CREATE TABLE Order(
Ono CHAR(6) PRIMARY KEY,
Odate DATE)
CREATE TABLE List(
Lno CHAR(6) PRIMARY KEY,
Lono CHAR(6),
Lname CHAR(20) NOT NULL,
Lprice SMALLINT NOT NULL,
Lnum SMALLINT NOT NULL,
FOREIGN KEY(Lono) REFERENCES Order(Ono),
CHECK(Lprice>0 AND Lnum>0));
5,
INSERT INTO Order VALUES('101','2008-10-1');
INSERT INTO List VALUES('1','101','可樂',1.5,6);
INSERT INTO List VALUES('2','101','都樂橙汁',15,2);
UPDATE List SET Lnum=3 WHERE Lno='2';
DELETE FROM List WHERE Lno='1';
6,
SELECT * FROM Order;
SELECT * FROM Order WHERE Ono='101';
SELECT Lono,SUM(Lnum*Lprice) AS Total_cost
GROUP BY Lono;
CREATE VIEW L1 AS SELECT Ono,Odate,Lno,Lname,Lprice,Lnum
FROM List Order WHERE Order.Ono=List.Lono;

㈦ 簡單資料庫原理題目求解!判斷,填空(高分)

1對
2對
3對
4
5錯
6錯,應該不可調度,一個進程可以包含多個線程
7對
8
9對
10對
11對
12
13錯
14
15對
16錯
17對
18錯
19錯
20錯
43
44對
45對
46對
47錯
48對
49錯
50錯
51對
太費勁了,。。。汗好像大部分都是操作系統的題啊,我記得都是從操作系統課上學的啊。。呵呵

㈧ 資料庫 分析題 高分求助!跪求!

1、select * from 教師信息表 where 姓名 not like '王%'

2、select * from 教師信息表 where year(工作時間) ='1992'

3、select * from 教師信息表 where 職稱 in ('教授','副教授')

4、
select * from 教師信息表 where right(簡歷,2) ='桂林'

select * from 教師信息表 where 簡歷 like '%桂林'

㈨ 資料庫原理及應用試題

1.B 2.C 3.B 4.C 5.D 6.C 7.C 8.D 9.C 10.A
11.A 12.A 13.A --不太確定 14.B 15.C 16.A 17.B 18.A 19.D 20.C

1.試述事務的概念及事務的四個特性。
答:
事務是用戶定義的一個資料庫操作序列,這些操作要麼全做要麼全不做,是一個不可分割的工作單位。
事務具有四個特性:原子性(Atomicity)、一致性(Consistency)、隔離性(Isolation)和持續性(Durability)。這個四個特性也簡稱為ACID特性。
原子性:事務是資料庫的邏輯工作單位,事務中包括的諸操作要麼都做,要麼都不做。
一致性:事務執行的結果必須是使資料庫從一個一致性狀態變到另一個一致性狀態。
隔離性:一個事務的執行不能被其他事務干擾。即一個事務內部的操作及使用的數據對其他並發事務是隔離的,並發執行的各個事務之間不能互相干擾。
持續性:持續性也稱永久性(Permanence),指一個事務一旦提交,它對資料庫中數據的改變就應該是永久性的。接下來的其他操作或故障不應該對其執行結果有任何影響。

2.為什麼事務非正常結束時會影響資料庫數據的正確性,請列舉一例說明之。
答:
事務執行的結果必須是使資料庫從一個一致性狀態變到另一個一致性狀態。如果資料庫系統運行中發生故障,有些事務尚未完成就被迫中斷,這些未完成事務對資料庫所做的修改有一部分已寫入物理資料庫,這時資料庫就處於一種不正確的狀態,或者說是不一致的狀態。
例如某工廠的庫存管理系統中,要把數量為Q的某種零件從倉庫1移到倉庫2存放。
則可以定義一個事務T,T包括兩個操作;Q1=Q1-Q,Q2=Q2+Q。如果T非正常終止時只做了第一個操作,則資料庫就處於不一致性狀態,庫存量無緣無故少了Q。

3.資料庫中為什麼要有恢復子系統?它的功能是什麼?
答:
因為計算機系統中硬體的故障、軟體的錯誤、操作員的失誤以及惡意的破壞是不可避免的,這些故障輕則造成運行事務非正常中斷,影響資料庫中數據的正確性,重則破壞資料庫,使資料庫中全部或部分數據丟失,因此必須要有恢復子系統。
恢復子系統的功能是:把資料庫從錯誤狀態恢復到某一已知的正確狀態(亦稱為一致狀態或完整狀態)。

4.資料庫運行中可能產生的故障有哪幾類?哪些故障影響事務的正常執行?哪些故障破壞資料庫數據?
答:資料庫系統中可能發生各種各樣的故障,大致可以分以下幾類:
(1)事務內部的故障;
(2)系統故障;
(3)介質故障;
(4)計算機病毒。
事務故障、系統故障和介質故障影響事務的正常執行;介質故障和計算機病毒破壞數據
庫數據。

5.據庫恢復的基本技術有哪些?
答:
數據轉儲和登錄日誌文件是資料庫恢復的基本技術。
當系統運行過程中發生故障,利用轉儲的資料庫後備副本和日誌文件就可以將資料庫恢復到故障前的某個一致性狀態。

6. 資料庫轉儲的意義是什麼? 試比較各種數據轉儲方法。
答:
數據轉儲是資料庫恢復中採用的基本技術。所謂轉儲即DBA定期地將資料庫復制到磁帶或另一個磁碟上保存起來的過程。當資料庫遭到破壞後可以將後備副本重新裝入,將資料庫恢復到轉儲時的狀態。
靜態轉儲:在系統中無運行事務時進行的轉儲操作。靜態轉儲簡單,但必須等待正運行的用戶事務結束才能進行。同樣,新的事務必須等待轉儲結束才能執行。顯然,這會降低資料庫的可用性。
動態轉儲:指轉儲期間允許對資料庫進行存取或修改。動態轉儲可克服靜態轉儲的缺點,它不用等待正在運行的用戶事務結束,也不會影響新事務的運行。但是,轉儲結束時後援副本上的數據並不能保證正確有效。因為轉儲期間運行的事務可能修改了某些數據,使得後援副本上的數據不是資料庫的一致版本。
為此,必須把轉儲期間各事務對資料庫的修改活動登記下來,建立日誌文件(log file)。這樣,後援副本加上日誌文件就能得到資料庫某一時刻的正確狀態。
轉儲還可以分為海量轉儲和增量轉儲兩種方式。
海量轉儲是指每次轉儲全部資料庫。增量轉儲則指每次只轉儲上一次轉儲後更新過的數據。從恢復角度看,使用海量轉儲得到的後備副本進行恢復一般說來更簡單些。但如果資料庫很大,事務處理又十分頻繁,則增量轉儲方式更實用更有效。

7. 什麼是日誌文件?為什麼要設立日誌文件?
答:
(1)日誌文件是用來記錄事務對資料庫的更新操作的文件。
(2)設立日誌文件的目的是: 進行事務故障恢復;進行系統故障恢復;協助後備副本進行介質故障恢復。

8. 登記日誌文件時為什麼必須先寫日誌文件,後寫資料庫?
答:
把對數據的修改寫到資料庫中和把表示這個修改的日誌記錄寫到日誌文件中是兩個不同的操作。有可能在這兩個操作之間發生故障,即這兩個寫操作只完成了一個。
如果先寫了資料庫修改,而在運行記錄中沒有登記這個修改,則以後就無法恢復這個修改了。如果先寫日誌,但沒有修改資料庫,在恢復時只不過是多執行一次UNDO操作,並不會影響資料庫的正確性。所以一定要先寫日誌文件,即首先把日誌記錄寫到日誌文件中,然後寫資料庫的修改。

9. 針對不同的故障,試給出恢復的策略和方法。(即如何進行事務故障的恢復?系統故障的恢復?介質故障恢復?)
答:
事務故障的恢復:
事務故障的恢復是由DBMS自動完成的,對用戶是透明的。
DBMS執行恢復步驟是:
(1)反向掃描文件日誌(即從最後向前掃描日誌文件),查找該事務的更新操作。
(2)對該事務的更新操作執行逆操作。即將日誌記錄中「更新前的值」寫入資料庫。
(3)繼續反向掃描日誌文件,做同樣處理。
(4)如此處理下去,直至讀到此事務的開始標記,該事務故障的恢復就完成了。
答:
系統故障的恢復:
系統故障可能會造成資料庫處於不一致狀態:
一是未完成事務對資料庫的更新可能已寫入資料庫;
二是已提交事務對資料庫的更新可能還留在緩沖區,沒來得及寫入資料庫。
因此恢復操作就是要撤銷(UNDO)故障發生時未完成的事務,重做(REDO)已完成的事務。
系統的恢復步驟是:
(1)正向掃描日誌文件,找出在故障發生前已經提交的事務隊列(REDO隊列)和未完成的事務隊列(UNDO隊列)。
(2)對撤銷隊列中的各個事務進行UNDO處理。
進行UNDO處理的方法是,反向掃描日誌文件,對每個UNDO事務的更新操作執行逆操作,即將日誌記錄中「更新前的值」(Before Image)寫入資料庫。
(3)對重做隊列中的各個事務進行REDO處理。
進行REDO處理的方法是:正向掃描日誌文件,對每個REDO事務重新執行日誌文件登記的操作。即將日誌記錄中「更新後的值」(After Image)寫入資料庫。
*解析:
在第(1)步中如何找出REDO隊列和UNDO隊列?請大家思考一下。
下面給出一個演算法:
1) 建立兩個事務隊列:
· UNDO-LIST: 需要執行undo操作的事務集合;
· REDO-LIST: 需要執行redo操作的事務集合;
兩個事務隊列初始均為空。
2) 從日誌文件頭開始,正向掃描日誌文件
· 如有新開始(遇到Begin Transaction)的事務Ti,把Ti暫時放入UNDO-LIST隊列;
· 如有提交的事務(遇到End Transaction)Tj,把Tj從UNDO-LIST隊列移到REDO-LIST隊列;
直到日誌文件結束
答:
介質故障的恢復:
介質故障是最嚴重的一種故障。
恢復方法是重裝資料庫,然後重做已完成的事務。具體過程是:
(1)DBA裝入最新的資料庫後備副本(離故障發生時刻最近的轉儲副本),使資料庫恢復到轉儲時的一致性狀態。
(2)DBA裝入轉儲結束時刻的日誌文件副本
(3)DBA啟動系統恢復命令,由DBMS完成恢復功能,即重做已完成的事務。

*解析
1)我們假定採用的是靜態轉儲,因此第(1)步裝入資料庫後備副本便可以了。
2)如果採用的是靜動態轉儲,第(1)步裝入資料庫後備副本還不夠,還需同時裝入轉儲開始時刻的日誌文件副本,經過處理後才能得到正確的資料庫後備副本。
3)第(2)步重做已完成的事務的演算法是:
a. 正向掃描日誌文件,找出故障發生前已提交的事務的標識,將其記入重做隊列
b. 再一次正向掃描日誌文件,對重做隊列中的所有事務進行重做處理。即將日誌記錄中「更新後的值」寫入資料庫。

10. 具有檢查點的恢復技術有什麼優點?
答:
利用日誌技術進行資料庫恢復時,恢復子系統必須搜索日誌,確定哪些事務需要REDO,哪些事務需要UNDO。一般來說,需要檢查所有日誌記錄。這樣做有兩個問題:
一是搜索整個日誌將耗費大量的時間。
二是很多需要REDO處理的事務實際上已經將它們的更新操作結果寫到資料庫中了,恢復子系統又重新執行了這些操作,浪費了大量時間。
檢查點技術就是為了解決這些問題。

11. 試述使用檢查點方法進行恢復的步驟。
答:
① 從重新開始文件中找到最後一個檢查點記錄在日誌文件中的地址,由該地址在日誌文件中找到最後一個檢查點記錄。
② 由該檢查點記錄得到檢查點建立時刻所有正在執行的事務清單ACTIVE-LIST。
這里建立兩個事務隊列:
· UNDO-LIST: 需要執行undo操作的事務集合;
· REDO-LIST: 需要執行redo操作的事務集合;
把ACTIVE-LIST暫時放入UNDO-LIST隊列,REDO隊列暫為空。
③ 從檢查點開始正向掃描日誌文件
· 如有新開始的事務Ti,把Ti暫時放入UNDO-LIST隊列;
· 如有提交的事務Tj,把Tj從UNDO-LIST隊列移到REDO-LIST隊列,直到日誌文件結束;
④ 對UNDO-LIST中的每個事務執行UNDO操作, 對REDO-LIST中的每個事務執行REDO操作。

12. 什麼是資料庫鏡像?它有什麼用途?
答:
資料庫鏡像即根據DBA的要求,自動把整個資料庫或者其中的部分關鍵數據復制到另一個磁碟上。每當主資料庫更新時,DBMS自動把更新後的數據復制過去,即DBMS自動保證鏡像數據與主數據的一致性。
資料庫鏡像的用途有:
一是用於資料庫恢復。當出現介質故障時,可由鏡像磁碟繼續提供使用,同時DBMS自動利用鏡像磁碟數據進行資料庫的恢復,不需要關閉系統和重裝資料庫副本。
二是提高資料庫的可用性。在沒有出現故障時,當一個用戶對某個數據加排它鎖進行修改時,其他用戶可以讀鏡像資料庫上的數據,而不必等待該用戶釋放鎖。

㈩ 資料庫原理期末題中的一個用SQL語句查詢的題,是圖中的第7小題

select cno from C where tno = 6 //查出業務是6 的主營公司

select count(1) from C where tno = 6 //查出業務是6 的主營公司總數
select count(1),cno from CT where tno !=6 and cno in ( select cno from C where tno = 6) group by cno 根據主營是6的公司 查出非6 的其他營業業務 和數量

select
b from (select count(1) a,cno b from CT where tno !=6 and cno in (
select cno from C where tno = 6)group by cno) where a =( select count(1) from C
where tno = 6) 根據數量對比 查出伴生業務號

其他的就根據業務號查了

思路是 根據C查出公司號,根據公司號在CT表裡篩選 ,業務號是非6的其他業務 這樣查出 2 3 1 業務 因為是半生的 所以數量一定和公司數量一致 根據公司數量對比一下就出來了 。也不確定理解的對不對,我是這樣想的。

C表

公司號 主營業務
A 6

B 3

C 6

CT表
公司號 營業務號
A 6

A 2
A 3
B 3
C 6
C 3
C 1