1、常見的關系型資料庫管理系統產品有?
答:Oracle、SQL Server、MySQL、Sybase、DB2、Access等,
2、SQL語言包括哪幾部分?每部分都有哪些操作關鍵字?
答:SQL語言包括資料定義(DDL)、資料操縱(DML),資料控制(DCL)和資料查詢(DQL)四個部分,
-
資料定義:Create Table,Alter Table,Drop Table, Craete/Drop Index等
-
資料操縱:Select ,insert,update,delete,
-
資料控制:grant,revoke
-
資料查詢:select
3、完整性約束包括哪些?
答:資料完整性(Data Integrity)是指資料的精確(Accuracy)和可靠性(Reliability),
分為以下四類:
-
物體完整性:規定表的每一行在表中是惟一的物體,
-
域完整性:是指表中的列必須滿足某種特定的資料型別約束,其中約束又包括取值范圍、精度等規定,
-
參照完整性:是指兩個表的主關鍵字和外關鍵字的資料應一致,保證了表之間的資料的一致性,防止了資料丟失或無意義的資料在資料庫中擴散,
-
用戶定義的完整性:不同的關系資料庫系統根據其應用環境的不同,往往還需要一些特殊的約束條件,用戶定義的完整性即是針對某個特定關系資料庫的約束條件,它反映某一具體應用必須滿足的語意要求,
與表有關的約束:包括列約束(NOT NULL(非空約束))和表約束(PRIMARY KEY、foreign key、check、UNIQUE) ,
4、什么是事務?及其特性?
答:事務:是一系列的資料庫操作,是資料庫應用的基本邏輯單位,
事務特性:
(1)原子性:即不可分割性,事務要么全部被執行,要么就全部不被執行,
(2)一致性或可串性,事務的執行使得資料庫從一種正確狀態轉換成另一種正確狀態
(3)隔離性,在事務正確提交之前,不允許把該事務對資料的任何改變提供給任何其他事務
(4) 持久性,事務正確提交后,其結果將永久保存在資料庫中,即使在事務提交后有了其他故障,事務的處理結果也會得到保存,
或者這樣理解:
事務就是被系結在一起作為一個邏輯作業單元的SQL陳述句分組,如果任何一個陳述句操作失敗那么整個操作就被失敗,以后操作就會回滾到操作前狀態,或者是上有個節點,為了確保要么執行,要么不執行,就可以使用事務,要將有組陳述句作為事務考慮,就需要通過ACID測驗,即原子性,一致性,隔離性和持久性,
5、什么是鎖?
答:資料庫是一個多用戶使用的共享資源,當多個用戶并發地存取資料時,在資料庫中就會產生多個事務同時存取同一資料的情況,若對并發操作不加控制就可能會讀取和存盤不正確的資料,破壞資料庫的一致性,
加鎖是實作資料庫并發控制的一個非常重要的技術,當事務在對某個資料物件進行操作前,先向系統發出請求,對其加鎖,加鎖后事務就對該資料物件有了一定的控制,在該事務釋放鎖之前,其他的事務不能對此資料物件進行更新操作,
基本鎖型別:鎖包括行級鎖和表級鎖
6、什么叫視圖?游標是什么?
答:視圖是一種虛擬的表,具有和物理表相同的功能,可以對視圖進行增,改,查,操作,視圖通常是有一個表或者多個表的行或列的子集,對視圖的修改不影響基本表,它使得我們獲取資料更容易,相比多表查詢,
游標:是對查詢出來的結果集作為一個單元來有效的處理,游標可以定在該單元中的特定行,從結果集的當前行檢索一行或多行,可以對結果集當前行做修改,一般不使用游標,但是需要逐條處理資料的時候,游標顯得十分重要,
7、什么是存盤程序?用什么來呼叫?
答:存盤程序是一個預編譯的SQL陳述句,優點是允許模塊化的設計,就是說只需創建一次,以后在該程式中就可以呼叫多次,如果某次操作需要執行多次SQL,使用存盤程序比單純SQL陳述句執行要快,可以用一個命令物件來呼叫存盤程序,
8、索引的作用?和它的優點缺點是什么?
答:索引就一種特殊的查詢表,資料庫的搜索引擎可以利用它加速對資料的檢索,它很類似與現實生活中書的目錄,不需要查詢整本書內容就可以找到想要的資料,索引可以是唯一的,創建索引允許指定單個列或者是多個列,缺點是它減慢了資料錄入的速度,同時也增加了資料庫的尺寸大小,
9、如何通俗地理解三個范式?
答:第一范式:1NF是對屬性的原子性約束,要求屬性具有原子性,不可再分解;
第二范式:2NF是對記錄的惟一性約束,要求記錄有惟一標識,即物體的惟一性;
第三范式:3NF是對欄位冗余性的約束,即任何欄位不能由其他欄位派生出來,它要求欄位沒有冗余,,
10、什么是基本表?什么是視圖?
答:基本表是本身獨立存在的表,在 SQL 中一個關系就對應一個表,
視圖是從一個或幾個基本表匯出的表,視圖本身不獨立存盤在資料庫中,是一個虛表
11、試述視圖的優點?
答:(1) 視圖能夠簡化用戶的操作
(2) 視圖使用戶能以多種角度看待同一資料;
(3) 視圖為資料庫提供了一定程度的邏輯獨立性;
(4) 視圖能夠對機密資料提供安全保護,
12、NULL是什么意思
答:NULL這個值表示UNKNOWN(未知):它不表示“”(空字串),對NULL這個值的任何比較都會生產一個NULL值,您不能把任何值與一個 NULL值進行比較,并在邏輯上希望獲得一個答案,
使用IS NULL來進行NULL判斷
13、主鍵、外鍵和索引的區別?
定義:
-
主鍵–唯一標識一條記錄,不能有重復的,不允許為空
-
外鍵–表的外鍵是另一表的主鍵, 外鍵可以有重復的, 可以是空值
-
索引–該欄位沒有重復值,但可以有一個空值
作用:
-
主鍵–用來保證資料完整性
-
外鍵–用來和其他表建立聯系用的
-
索引–是提高查詢排序的速度
個數:
-
主鍵–主鍵只能有一個
-
外鍵–一個表可以有多個外鍵
-
索引–一個表可以有多個唯一索引
14. 你可以用什么來確保表格里的欄位只接受特定范圍里的值?
答:Check限制,它在資料庫表格里被定義,用來限制輸入該列的值,
觸發器也可以被用來限制資料庫表格里的欄位能夠接受的值,但是這種辦法要求觸發器在表格里被定義,這可能會在某些情況下影響到性能,
15. 說說對SQL陳述句優化有哪些方法?(選擇幾條)
(1)Where子句中:where表之間的連接必須寫在其他Where條件之前,那些可以過濾掉最大數量記錄的條件必須寫在Where子句的末尾.HAVING最后,
(2)用EXISTS替代IN、用NOT EXISTS替代NOT IN,
(3) 避免在索引列上使用計算
(4)避免在索引列上使用IS NULL和IS NOT NULL
(5)對查詢進行優化,應盡量避免全表掃描,首先應考慮在 where 及 order by 涉及的列上建立索引,
(6)應盡量避免在 where 子句中對欄位進行 null 值判斷,否則將導致引擎放棄使用索引而進行全表掃描
(7)應盡量避免在 where 子句中對欄位進行運算式操作,這將導致引擎放棄使用索引而進行全表掃描
16. SQL陳述句中‘相關子查詢’與‘非相關子查詢’有什么區別?
答:子查詢:嵌套在其他查詢中的查詢稱之,
子查詢又稱內部,而包含子查詢的陳述句稱之外部查詢(又稱主查詢),
所有的子查詢可以分為兩類,即相關子查詢和非相關子查詢
(1)非相關子查詢是獨立于外部查詢的子查詢,子查詢總共執行一次,執行完畢后將值傳遞給外部查詢,
(2)相關子查詢的執行依賴于外部查詢的資料,外部查詢執行一行,子查詢就執行一次,
故非相關子查詢比相關子查詢效率高
17. char和varchar的區別?
答:是一種固定長度的型別,varchar則是一種可變長度的型別,它們的區別是:
char(M)型別的資料列里,每個值都占用M個位元組,如果某個長度小于M,MySQL就會在它的右邊用空格字符補足.(在檢索操作中那些填補出來的空格字符將被去掉)在varchar(M)型別的資料列里,每個值只占用剛好夠用的位元組再加上一個用來記錄其長度的位元組(即總長度為L+1位元組).
18. Mysql 的存盤引擎,myisam和innodb的區別,
答:簡單的表達:
-
MyISAM 是非事務的存盤引擎;適合用于頻繁查詢的應用;表鎖,不會出現死鎖;適合小資料,小并發
-
innodb是支持事務的存盤引擎;合于插入和更新操作比較多的應用;設計合理的話是行鎖(最大區別就在鎖的級別上);適合大資料,大并發,
19. 資料表型別有哪些
答:MyISAM、InnoDB、HEAP、BOB,ARCHIVE,CSV等,
-
MyISAM:成熟、穩定、易于管理,快速讀取,一些功能不支持(事務等),表級鎖,
-
InnoDB:支持事務、外鍵等特性、資料行鎖定,空間占用大,不支持全文索引等,
20. MySQL資料庫作發布系統的存盤,一天五萬條以上的增量,預計運維三年,怎么優化?
a. 設計良好的資料庫結構,允許部分資料冗余,盡量避免join查詢,提高效率,
b. 選擇合適的表欄位資料型別和存盤引擎,適當的添加索引,
c. mysql庫主從讀寫分離,
d. 找規律分表,減少單表中的資料量提高查詢速度,
e.添加快取機制,比如memcached,apc等,
f. 不經常改動的頁面,生成靜態頁面,
g. 書寫高效率的SQL,比如
SELECT * FROM TABEL 改為 SELECT field_1, field_2, field_3 FROM TABLE.
21. 對于大流量的網站,您采用什么樣的方法來解決各頁面訪問量統計問題?
答:
a. 確認服務器是否能支撐當前訪問量,
b. 優化資料庫訪問,
c. 禁止外部訪問鏈接(盜鏈), 比如圖片盜鏈,
d. 控制檔案下載,
e. 使用不同主機分流,
f. 使用瀏覽統計軟體,了解訪問量,有針對性的進行優化,
點關注,不迷路
好了各位,以上就是這篇文章的全部內容了,能看到這里的人呀,都是人才,之前說過,PHP方面的技術點很多,也是因為太多了,實在是寫不過來,寫過來了大家也不會看的太多,所以我這里把它整理成了PDF和檔案,如果有需要的可以
點擊進入暗號: PHP+「平臺」


更多學習內容可以訪問【對標大廠】精品PHP架構師教程目錄大全,只要你能看完保證薪資上升一個臺階(持續更新)
以上內容希望幫助到大家,很多PHPer在進階的時候總會遇到一些問題和瓶頸,業務代碼寫多了沒有方向感,不知道該從那里入手去提升,對此我整理了一些資料,包括但不限于:分布式架構、高可擴展、高性能、高并發、服務器性能調優、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql優化、shell腳本、Docker、微服務、Nginx等多個知識點高級進階干貨需要的可以免費分享給大家,需要的可以加入我的 PHP技術交流群
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/141068.html
標籤:java
