1. 資料庫語言有哪些
資料庫語言最常用的是sql
(結構化查詢語言)。
t-sql
是微軟SQL
SERVER的SQL語句,兼容SQL,並具有SQL
SERVER本身獨有的函數、關鍵字;
pl/sql是針對Oracle資料庫的第三方工具;
k-sql是國內最領先ERP廠商金蝶軟體自主使用的sql語言。
都是基於sql的,兼容sql,也有符合自己資料庫的特色。可以這么理解,SQL是普通話,而t-sql、pl/sql、ksql是方言。
企業比較常用的大型資料庫有Oracle
(甲骨文)、db2(IBM)
、sql
server(微軟)
、Sybase(剛被sap收購)、Mysql(sun,已被甲骨文收購)Mysql也算大型資料庫。
小
型資料庫有access、MSDE
2000、FoxPro(原名foxbase曾是狐狸公司的)等,這三個都是微軟的。foxpro是一款非常方便好用的桌面資料庫開發工具,至今還有很多
公司用來做數據處理。其他還有些我不熟悉的,就不寫了。了解這么多資料庫沒用,關鍵是學會用一兩種就行了。
了解更多開源相關,去LUPA社區看看吧。
2. 資料庫問題:嵌入式sql語句與主語言之間的通信機制是怎樣的
首先用SQL通信區(SQL
Communication
Area,簡稱SQLCA)向主語言傳遞SQL語句的執行狀態信息,使主語言能夠據此控製程序流程;在程序運行中,主語言向SQL語句提供參數,使用主變數(host
variable)輸入數據;同時,程序把SQL語句查詢資料庫的結果交主語言進一步處理,其中使用主變數和游標(cursor)向主語言輸出數據,從而實現了SQL語言的過程化工作。
SQL語句執行後,系統要反饋給應用程序若干信息,主要包括描述系統當前工作狀態和運行環境的各種數據,這些信息將送到SQL通信區SQLCA中。應用程序從SQLCA中取出這些狀態信息,據此決定接下來執行的語句。
3. 資料庫語言有哪些
數據定義語言(DDL),例如:CREATE、DROP、ALTER等語句。
數據操作語言(DML),例如:INSERT(插入)、UPDATE(修改)、DELETE(刪除)語句。
數據查詢語言(DQL),例如:SELECT語句。(一般不會單獨歸於一類,因為只有一個語句)。
數據控制語言(DCL),例如:GRANT、REVOKE等語句。
事務控制語言(TCL),例如:COMMIT、ROLLBACK等語句。
SQL語言包括四類種主要程序設計語言類別的語句:數據定義語言(DDL),數據操作語言(DML)及數據控制語言(DCL)還有事務控制語言(TCL)。
資料庫語言以記錄集合作為操作對象
所有SQL語句接受集合作為輸入,返回集合作為輸出,這種集合特性允許一條SQL語句的輸出作為另一條SQL語句的輸入,所以SQL語句可以嵌套,這使他具有極大的靈活性和強大的功能,在多數情況下,在其他語言中需要一大段程序實現的功能只需要一個SQL語句就可以達到目的,這也意味著用SQL語言可以寫出非常復雜的語句。
以上內容參考:網路-資料庫語言
4. 關系資料庫的標准語言是
三、關系資料庫的標准語言———SQL
1.SQL概述SQL的英語名稱是結構查詢語言(Structured Query Language)實際上它的功能包括查詢(Query)、操縱(Manipulation)、定義(Definition)和控制(Control)四個方面,是一個綜合的、通用的、功能極強的關系資料庫語言。SQL支持資料庫的三級模式結構。
2.SQL的數據定義功能SQL的數據定義功能包括三部分:
定義基本表,定義視圖和定義索引。它們是:CREATE TABLE CREATE VIEW CREATE INDEX DROP TABLE DROP VIEW DROP INDEX SQL的數據定義功能可用於定義和修改模式(如基本表),定義外模式(如視圖)和內模式(如索引)。
3.基本表的定義與刪除定義基本表的語句格式為:
CREATE TABLE表名 (列名1 類型[NOT NULL]
[,列名2類型[NOT NULL]]…)[其他參數];其中,任選項「其它參數」是與物理存儲有關的參數。根據具體系統的不同而不同。刪除基本表的語句為:DROP TABLE表名;刪除索引的語句為:DROP INDEX索引名;刪除索引的同時把有關索引的描述也從數據字典中刪去。但表的內涵仍存在且其數據外延內容不變。把一個基本表的定義連同表上所有的記錄、索引以及由此基本表導出的所有視圖全部都刪除,並釋放相應的存儲空間。
4.索引的建立與刪除對一個基本表,可以根據應用環境的需要建立若干索引,以提供多種存取方式。通常,索引的建立和刪除由DBA或表的主人(即建立表的人)負責。用戶不必也不能在存取數據時選擇索引。存取路徑的選擇由系統自動進行。索引的描述存放在數據字典中。建立索引的語句格式為:
CREATE[UNIQUE] INDEX索引名ON基本表名(列名[次序][,列名[次序]]…)[其他參數];這里的任選項———其他參數是與物理存儲有關的參數。索引可以建在一列或幾列上。圓括弧內是索引列的順序說明表。其中的任選項———次序,指定了索引值排序的次序。可取ASC(升序)或DESC(降序)。預設值為升序。UNIQUE表示每一索引值只對應唯一的數據記錄。
5.SQL的數據操縱功能SQL的數據操縱功能包括SELECT,INSERT,DELETE和UPDATE四個語句,即檢索和更新(包括增、刪、改)兩部分工能。檢索就是查詢。
SQL更新語句SQL的更新語句包括修改,刪除和插入三類語句。
①修改(UPDATE)(亦稱為更新)修改語句的一般格式為:
UPDATE表名SET欄位=表達式[,欄位=表達式]…[WHERE謂詞];修改指定表中滿足謂詞(或條件)的元組,把這些元組按SET子句中的表達式修改相應屬性或欄位上的值。
②刪除(DELETE)刪除語句一般格式為:
DELETE FROM表名[WHERE謂詞];從指定表中刪除滿足謂詞的那些記錄。沒有WHERE子句時表示刪去此表中的全部記錄,但此表的定義仍在數據字典中,只是一個空表。DELETE只對表外延操作,不對內涵操作。
③插入(INSERT)插入語句的一般格式為:
INSERT INTO表名[(欄位名[,欄位名]…)]
valueS(常量[,常量]…);或INSERTINTO表名[(欄位名[,欄位名]…)]
子查詢;第一種格式把一個新記錄插入指定的表中。第二種格式把子查詢的結果插入表中。若表中有些欄位在插入語句中沒有出現,則這些欄位上的值取空值NULL。當然在表定義中說明了NOT NULL的欄位在插入時不能取NULL。若插入語句中沒有指出欄位名,則新記錄必須在每個欄位上均有值6.視圖視圖是從一個或幾個基本表(或視圖)導出的表。某一用戶可以定義若干視圖。因此對某一用戶而言,按ANSI/SPARC報告的觀點,他的外模式是由若干基本表和若干視圖組成的。視圖和基本表不同,視圖是一個虛表,即視圖所對應的數據不實際存儲在資料庫中,資料庫中只存儲視圖的定義(存在數據字典中)。視圖一經定義就可以和基本表一樣被查詢、被刪除(DROP),也可以用來定義新的視圖,但更新(增、刪、改)操作將有一定限制。視圖可以理解成一個資料庫,只有內涵保存在資料庫字典中,而無外延存儲;其外延是在使用時動態地生成的或計算出來的。
(1)視圖的定義與刪除SQL建立視圖的語句格式為:
CREATE VIEW視圖名[(欄位名[,欄位名]…)]
AS子查詢[WITH CHECK OPTION謂詞];視圖可以刪除,語句格式為:
DROP VIEW視圖名;視圖的定義就從數據字典中刪除。由此視圖導出的其它視圖也將自動被刪除。若導出此視圖的基本表刪除了,則此視圖也將自動刪除。
(2)視圖的查詢語句視圖定義後,用戶可以如同基本表那樣對視圖查詢。
(3)視圖的更新語句對視圖的更新最終要轉換成對基本表的更新(這里的更新,指INSERT,UPDATE和DELETE三類操作)。在關系資料庫中,並非所有的視圖都是可更新的,也就是說,有些視圖的更新不能唯一地有意義地轉換成對基本表的更新。
(4)視圖的優點視圖的概念具有很多優點,主要有:
(1)視圖對於資料庫的重構造提供了一定程度的邏輯獨立性;(2)簡化了用戶觀點;(3)視圖機制使不同的用戶能以不同的方式看待同一數據;(4)視圖機制對機密數據提供了自動的安全保護功能。
7.SQL的數據控制功能SQL數據控制功能是指控制用戶對數據的存取權力。某個用戶對某類數據具有何種操作權力是由DBA決定的。這是個政策問題而不是技術問題。資料庫管理系統的功能是保證這些決定的執行。為此它必須能:
(1)把授權的決定告知系統,這是由SQL的GRANT和REVOKE語句來完成的。
(2)把授權的結果存入數據字典。
(3)當用戶提出操作請求時,根據授權情況進行檢查,以決定是執行操作請求還是拒絕之。授權語句的一般格式為:GRANT權力[,權力]…[ON對象類型對象名] TO用戶[,用戶]…,[WITH GRANT OPTION];對不同類型的操作對象可有不同的操作權力。
(1)對基本表、視圖及其欄位的操作權力有查詢、插入、更新、刪除以及它們的總和ALL PRIVILEGE。
(2)對基本表的操作權力還有修改(ALTER)和建立索引(INDEX)。
(3)對資料庫的操作權力有建立表(CREATETAB)。某用戶有了此權力就可以使用Create table建立基本表。稱他為表的主人,擁有對此表的一切操作權力。
(4)對表空間的權力有使用(USE)資料庫空間存儲基本表的權力。
(5)系統權力有建立新資料庫(CREATEDBA)的權力。GRANT語句中的任選項WITH GRANT OPTION的作用是使獲得某種權力的用戶可以把權力再授予別的用戶。
8.嵌入式SQL把SQL嵌入主語言使用時必須解決三個問題:
(1)區分SQL語句與主語言語句。這是通過在所有的SQL語句前加前綴EXEC SQL來解決的。SQL語句結束標志隨主語言不同而不同,如PL/1用分號(;),COBOL用EMD-EXEC來表示。SQL語句首先由預編譯程序加以處理,轉換為主語言編譯程序能夠識別的形式,然後交主語言編譯程序進一步處理。
(2)資料庫工作單元和程序工作單元之間的通信。SQL語句中可以使用主語言的程序變數(簡稱主變數),這些變數名前加冒號(:)作標志,以區別地欄位名,程序中使用的任何錶(基本表或視圖)都要用EXEC SQL DECLARE語句加以說明。一則使程序更加清晰,二則使預編譯程序能作某些語法檢查。SQL語句執行後,系統要反饋給應用程序若干信息,這些信息送到SQL的通信區SQL CA。SQL CA用語句EXEC SQL INCLUDE加以定義。在SQL CA中有一個狀態指示欄位SQL CODE。當SQL CODE為零時,表示SQL語句執行成功,否則返回一個錯誤代碼(負值)或警告信息(正值)。程序員應該在每個SQL語句之後測試SQL CODE的值,以便處理各種情況。
(3)一個SQL語句原則上可產生或處理一組記錄,而主語言一次只能處理一個記錄,為此必須協調兩種處理方式。這是用游標(Cursor)來解決的。下面首先討論不需要游標的DML語句,然後討論使用游標的DML語句。
9.不用游標的DML語句不需要游標的DML語句有:查詢結果為單記錄的SELECT語句UPDATE(除了CURRENT形式的UPDATE)語句DELETE(除了CURRENT形式的DELETE)語句INSERT語句(1)查詢結果為單記錄的SELECT語句這類語句的一般格式是:(主語言為PL/1)EXEC SQL SELECT目標列INTO主變數[空值標志]FROM基本表(或視圖)[WHERE條件表達式];SELECT語句從資料庫中找到符合條件的記錄,把結果放到主變數中。(2)UPDATE語句(3)DELETE語句(4)INSERT語句
10.使用游標的DML語句一般情況下SELECT語句的查詢結果是記錄的集合而不是單個記錄,為此需要用游標機製作為橋梁,把集合操作轉換為單記錄處理。與游標有關的語句有四個:
(1)定義游標。游標是與某一查詢結果相聯系的符號名。用DECLARE語句定義。這是一個說明語句。與游標相對應的SELECT語句這時並不執行。
(2)打開(OPEN)游標。打開游標語句使游標處於活動狀態。與游標相應的查詢語句被執行。游標指向查詢結果集中的第一個記錄之前。
(3)推進(FETCH)游標。把游標向前推進一個記錄,並把游標指向的當前記錄中的欄位值取出,放到INTO子句後相應的主變數中。FETCH語句常常用於循環,以藉助主語言功能逐一處理結果集中的數據。
(4)關閉(CLOSE)游標。關閉游標,使它不再和原來的查詢結果相聯系。關閉了的游標可以再次被打開,與新的查詢結果集相聯系。使用CURRENT形式的UPDATE和刪除語句應注意:
(1)若游標定義中的SELECT語句帶有UNION或ORDER BY子句,或者這個SELECT語句相當於定義了一個不可更新的視圖,則不能用這兩個更新語句。
(2)若使用CURRENT形式的UPDATE語句,則游標定義中要包括FOR UPDATE子句,指出更新的欄位(SET子句中使用的欄位)。因此,游標定義語句的一般格式為:EXEC SQL DECLARE游標名CURSOR FOR子查詢UNION子查詢…[FOR UPDATE OF欄位名[,欄位名]…|ORDER-BY-子句];11.SQL的事務處理功能(1)事務處理的概述所謂事務(Transaction)是指一系列動作的組合,這些動作被當作一個整體來處理。這些動作或者相繼都被執行,或者什麼也不做。在資料庫中,一個動作是指一個SQL語句。事務是一組SQL語句組成的一個邏輯單位。要麼這些SQL語句全部被按順序正確執行,要麼在某SQL語句執行失敗時,按照用戶要求,取消已執行的SQL語句對資料庫中數據的修改。或者要麼事務中SQL語句都被正確執行,完成該事務對資料庫中數據的所有操作;或者要麼相當於一條SQL語句也未執行,資料庫數據未做任何改動。
(2)SQL語言的事務處理語句SQL語言有3條語句用於事務處理,它們是:
(1)Commit語句,對於正確執行了的事務進行提交,進行提交即對資料庫中數據的修改永久化。同時還釋放事務和封鎖,標志該事務結束。
(2)Save point語句,定義事務中的一個回滾保留點,它是事務恢復時的一個標記點。
(3)rollback語句,無論事務執行的當前位置在哪裡,該語句的執行要麼取消事務執行以來對資料庫的全部修改,要麼取消至某個指定回滾點後對資料庫的全部修改。釋放自保留點之後的全部表或行的封鎖(沒有保留點,相當於回滾到事務開始處,終止該事務)。事務的恢復(回滾)是根據事務執行前保存下的當時資料庫狀態來實現的。一遇到rollback語句,就將資料庫中數據恢復到原來的狀態,相當於撤消事務中已執行了的SQL語句。
5. 資料庫系統的組成,及各自的作用
1、資料庫(database,DB)
作用是資料庫中的數據按一定的數學模型組織、描述和存儲,有組織,可共享的數據的集合。具有較小的冗餘,較高的數據獨立性和易擴展性,並可為各種用戶共享。
2、硬體
構成計算機系統的各種物理設備,包括存儲所需的外部設備。作用是硬體的配置應滿足整個資料庫系統的需要。
3、軟體
包括操作系統、資料庫管理系統及應用程序。資料庫管理系統是資料庫系統的核心軟體,作用是在操作系統的支持下工作,科學地組織和存儲數據,高效獲取和維護數據的系統軟體。其主要功能包括數據定義功能、數據操縱功能、資料庫的運行管理和資料庫的建立與維護。
4、人員
主要分類及其作用是系統分析員和資料庫設計人員,負責應用系統的需求分析和規范說明,確定系統的硬體配置,並參與資料庫系統的概要設計;應用程序員,負責編寫使用資料庫的應用程序,利用系統的介面或查詢語言訪問資料庫;資料庫管理員負責資料庫的總體信息控制。
(5)主語言資料庫擴展閱讀:
資料庫系統的模型
1、層次模型:用一顆「有向樹」的數據結構來表示各類實體以及實體間的聯系,樹中每一個節點代表一個記錄類型,樹狀結構表示實體型之間的聯系。層次數據模型的提出,首先是為了模擬這種按層次組織起來的事物。層次資料庫也是按記錄來存取數據的。
2、網狀模型:取消了層次模型的不能表示非數狀結構的限制,兩個或兩個以上的結點都可以有多個雙親結點,則此時有向樹變成了有向圖,該有向圖描述了網狀模型。網狀模型中以記錄為數據的存儲單位。記錄包含若干數據項。
3、關系模型:基本假定是所有數據都表示為數學上的關系。關系數據模型以集合論中的關系概念為基礎發展起來的。關系模型中無論是實體還是實體間的聯系均由單一的結構類型關系來表示。