一、寫一個函數,獲取一篇文章內容中的全部圖片,并下載
成都創(chuàng)新互聯公司專注于廬山企業(yè)網站建設,響應式網站,商城網站制作。廬山網站建設公司,為廬山等地區(qū)提供建站服務。全流程定制網站制作,專業(yè)設計,全程項目跟蹤,成都創(chuàng)新互聯公司專業(yè)和態(tài)度為您提供的服務
二、什么是 CSRF 攻擊?XSS 攻擊?如何防范?
CSRF:跨站請求偽造,可以通過通過判斷來源和加 Token 的方式來防范。
XSS:跨站腳本攻擊,可以通過對內容轉義和過濾來防范,還有 CSP
三、應用中我們經常會遇到在 user 表隨機調取 10 條數據來展示的情況,簡述你如何實現該功能。
四、MYSQL 中主鍵與唯一索引的區(qū)別
主鍵:絕對不能有空值。唯一索引:可以有空值
五、http 與 https 的主要區(qū)別
關鍵是 S 上。簡而言之,https 建立連接后要先把 SSL 的證書發(fā)下去,有了公鑰和私鑰,就可以解密了。
六、兩臺 mysql 服務器,其中一臺掛了,怎么讓業(yè)務端無感切換,并保證正常情況下講臺服務器的數據是一致的
不是核心業(yè)務的話,先停寫,把備機拉起來,查看兩臺機器的日志,進行數據補償,開寫。
如果是核心業(yè)務的話,現在所有的操作都在正常的狀態(tài)機器上。把好的這臺機器的備機拉起來,當主機。
以上全是應急操作。實際上數據庫的容災設計要復雜得多。
面試官要是問你,備機的數據不一致怎么辦,你要勇敢懟回去,你們每秒多少寫入操作。按照百萬級表,每秒 1000 的寫入效率,正常的設計是,分布在 2 臺機器上每臺 500。這個級別的數據同步,出現差異的概率 可以忽略不計的。有一臺出現問題,另一臺也可以抗住。
(正常的操作,還是先停寫,等數據一致,切換,開寫。我們公司搞這些切換都是在凌晨 4.00 左右,核心業(yè)務的每秒寫操作,只有十幾個。前后耽擱不到 20 秒)。
七、10 瓶水,其中一瓶有毒,小白鼠喝完有毒的水之后,會在 24 小時后死亡,問:最少用幾只小白鼠可以在 24 小時后找到具體是哪一瓶水有毒。
答案:四只
二進制問題。薛定諤的老鼠。
一只老鼠有兩個狀態(tài),死活,對應 01。假設老鼠的個數為 A,則有 2^A=10; A=4;
思路很簡單,十瓶藥編號:0,1,10,11….1001;
0 不喝。第一只老鼠喝所有個位是 1 的:13579,第二只喝十位是 1 的,第三只和百位是 1 的,第四只喝千位是 1 的。
24 小時后,看下死了的是 1,活著的是 0。按老鼠的順序乖乖站好…… 假如第一只和第三只死了,那就是 0101,就是 5 有問題。
一、兩張表 city表和province表。分別為城市與省份的關系表。
表名:city
id City Provinceid
1 廣州 1
2 深圳 1
3 惠州 1
4 長沙 2
5 武漢 3
………. 廣州
表名稱:province:
id Province
1 廣東
2 湖南
3 湖北
……….
1、寫一條sql語句關系兩個表,實現:顯示城市的基本信息。顯示字段:城市id ,城市名, 所屬省份 。
如:
Id(城市id) Cityname(城市名) Privence(所屬省份)
2、如果要統(tǒng)計每個省份有多少個城市,請用group by 查詢出來。顯示字段:省份id ,省份名,包含多少個城市。
二、主鍵 和外鍵表示什么?一般用于做什么?
主鍵:能夠唯一表示數據表中的每個記錄的字段或者字段的組合就稱為主鍵。一個主鍵是唯一識別一個表的每一行記錄,但這只是其作用的一療分,主鍵的主要作用是將記錄和存放在其他表中的數據進行關聯,在這一點上,主鍵是不同表中各記錄間的簡單指針,主鍵約整就是確定表中的每一條記錄,主鍵不能是空值,唯一約束是用于指定一個或多個列的組合值具有唯一性,以防止在列中輸入重復的值,所以,主鍵的值對用戶而言是沒有什么意義,并且和它賦予的值也沒有什么特別聯系。
外鍵:若有兩個表A,B,C是A的主鍵,而B中也有C字段,則C就是表B的外鍵,外鍵約束主要用來維護兩個表之間數據的一致性。A為基本表,B為信息表。
在數據庫中,常常不只是一個表,這些表之間也不是相互獨立的,不同的表之間需要建立一種關系,才能將它們的數據相互溝通,而在這個溝通過程中,就需要表中有一個字段作為標志,不同的記錄對應的字段取值不能相同,也不能是空白的,通過這個字段中不同的值可以區(qū)別各條記錄,就像我們區(qū)別不同的人,每個人都有名字,但它卻不能作為主鍵,因為人名很容易出現重復,而身份證號是每個人都不同的,所以可以根據它來區(qū)別不同的人,數據庫的表中作為主鍵的段段就要像人的身份證號一樣,必須是每個記錄的值都不同,這才能根據
主鍵的值來確定不同的記錄。
關系:外鍵一定是另外某個表的主鍵。
三、select now(),Date_ADD(now(),INTERVAL 14 day),Date_SUB(now(),INTERVAL 3 Day) from table; 會獲得什么內容,請寫出來。
會獲得三條數據:
第一條:當前時間;
第二條:當前時間加上14天;
第三條:當前時間減去3天。
四、您所知道的MYSQL 數據庫備份,還原方式有哪幾種?
備份:
一,搭建主從架構,master-slave,通過binlog文件同步復制主庫的數據,也可以直接通過binlog文件恢復數據。
二,通過系統(tǒng)計劃任務執(zhí)行mysqldump做周期性全備份。
三,物理備份,直接拷貝數據文件、參數文件、日志文件。
還原:
一.通過mysql操作工具,如phpmyadmin,sqlyog等導入備份過的數據庫文件。
二.將物理備份的文件拷貝到mysql的data目錄下
五、內容管理系統(tǒng)中,表message有如下字段
id 文章id
title 文章標題
content 文章內容
category_id 文章分類id
hits 點擊量
創(chuàng)建上表,寫出MySQL語句
六、同樣上述內容管理系統(tǒng):表comment記錄用戶回復內容,字段如下
comment_id 回復id
id 文章id,關聯message表中的id
comment_content 回復內容
現通過查詢數據庫需要得到以下格式的文章標題列表,并按照回復數量排序,回復最高的排在最前面
文章id 文章標題 點擊量 回復數量
用一個SQL語句完成上述查詢,如果文章沒有回復則回復數量顯示0
七、內容管理系統(tǒng),表category保存分類信息,字段如下
category_id int(4) not null auto_increment;
category_name varchar(40) not null;
用戶輸入文章時,通過選擇下拉菜單選定文章分類
寫出如何實現這個下拉菜單
八、PHP文件操作
1、內容管理系統(tǒng):用戶提交內容后,系統(tǒng)生成靜態(tài)HTML頁面;寫出實現的基本思路
2、簡單描述用戶修改發(fā)布內容的實現流程和基本思路
1)當用戶提交后生成一個由url地址MD5后的文件的編譯頁面,用文件處理file函數生成一個模板合成頁,判斷模板編譯頁是否有,模板頁無或者編譯頁的創(chuàng)建時間戳小于模板頁的修改時間都會從新生成編譯頁面,編譯后的頁面會調用對應數據庫的值顯示在頁面中,通過對內存數據的讀取釋放,顯示出我們看到的靜態(tài)數據,然后用file文件將其保存起來生成靜態(tài)的頁面
2)當用戶修改了發(fā)布內容都會修改數據相關的內容,并通過編譯頁面更新靜態(tài)數據并用文件的方式緩存起來,當用戶查看時將不做任何數據庫查找,直接調用該緩存文件即可
一、簡述一下MongoDB的應用場景
mongodb 支持副本集、索引、自動分片,可以保證較高的性能和可用性。
更高的寫入負載
默認情況下,MongoDB 更側重高數據寫入性能,而非事務安全,MongoDB 很適合業(yè)務系統(tǒng)中有大量 “低價值” 數據的場景。但是應當避免在高事務安全性的系統(tǒng)中使用 MongoDB,除非能從架構設計上保證事務安全。
高可用性
MongoDB 的復副集 (Master-Slave) 配置非常簡潔方便,此外,MongoDB 可以快速響應的處理單節(jié)點故障,自動、安全地完成故障轉移。這些特性使得 MongoDB 能在一個相對不穩(wěn)定(如云主機)的環(huán)境中,保持高可用性。
數據量很大或者未來會變得很大
依賴數據庫 (MySQL) 自身的特性,完成數據的擴展是較困難的事,在 MySQL 中,當一個單達表到 5-10GB 時會出現明顯的性能降級,此時需要通過數據的水平和垂直拆分、庫的拆分完成擴展,使用 MySQL 通常需要借助驅動層或代理層完成這類需求。而 MongoDB 內建了多種數據分片的特性,可以很好地適應大數據量的需求。
基于位置的數據查詢
MongoDB 支持二維空間索引,因此可以快速及精確地從指定位置獲取數據。
表結構不明確
在一些傳統(tǒng) RDBMS 中,增加一個字段會鎖住整個數據庫 / 表,或者在執(zhí)行一個重負載的請求時會明顯造成其它請求的性能降級。通常發(fā)生在數據表大于 1G 的時候(當大于 1TB 時更甚)。 因 MongoDB 是文檔型數據庫,為非結構貨的文檔增加一個新字段是很快速的操作,并且不會影響到已有數據。另外一個好處當業(yè)務數據發(fā)生變化時,是將不再需要由 DBA 修改表結構。
二、數據庫設計經驗,為什么進行分表?分庫?一般多少數據量開始分表?分庫?分庫分表的目的?
1、為什么要分表
當一張表的數據達到幾百萬時,你查詢一次所花的時間會變多,如果有聯合查詢的話,有可能會死在那兒了。分表的目的就在于此,減小數據庫的負擔,縮短查詢時間。日常開發(fā)中我們經常會遇到大表的情況,所謂的大表是指存儲了百萬級乃至千萬級條記錄的表。這樣的表過于龐大,導致數據庫在查詢和插入的時候耗時太長,性能低下,如果涉及聯合查詢的情況,性能會更加糟糕。
分表和表分區(qū)的目的就是減少數據庫的負擔,提高數據庫的效率,通常點來講就是提高表的增刪改查效率。數據庫中的數據量不一定是可控的,在未進行分庫分表的情況下,隨著時間和業(yè)務的發(fā)展,庫中的表會越來越多,表中的數據量也會越來越大,相應地,數據操作,增刪改查的開銷也會越來越大;另外,由于無法進行分布式式部署,而一臺服務器的資源(CPU、磁盤、內存、IO 等)是有限的,最終數據庫所能承載的數據量、數據處理能力都將遭遇瓶頸。
2、分表的方案
做 mysql 集群,有人會問 mysql 集群,根分表有什么關系嗎?雖然它不是實際意義上的分表,但是它啟到了分表的作用,做集群的意義是什么呢?為一個數據庫減輕負擔,說白了就是減少 sql 排隊隊列中的 sql 的數量,舉個例子:有 10 個 sql 請求,如果放在一個數據庫服務器的排隊隊列中,他要等很長時間,如果把這 10 個 sql 請求,分配到 5 個數據庫服務器的排隊隊列中,一個數據庫服務器的隊列中只有 2 個,這樣等待時間是不是大大的縮短了呢?
linux mysql proxy 的安裝,配置,以及讀寫分離
mysql replication 互為主從的安裝及配置,以及數據同步
優(yōu)點:擴展性好,沒有多個分表后的復雜操作(php 代碼)
缺點:單個表的數據量還是沒有變,一次操作所花的時間還是那么多,硬件開銷大。
三、簡述一下數據庫主從復制,讀寫分離
* 什么是主從復制
主從復制,是用來建立一個和主數據庫完全一樣的數據庫環(huán)境,稱為從數據庫;
* 主從復制的原理:
1.數據庫有個bin-log二進制文件,記錄了所有的sql語句。
2.只需要把主數據庫的bin-log文件中的sql語句復制。
3.讓其從數據的relay-log重做日志文件中再執(zhí)行一次這些sql語句即可。
* 主從復制的作用
1.做數據的熱備份,作為后備數據庫,主數據庫服務器故障后,可切換到從數據庫繼續(xù)工作,避免數據丟失。
2.架構的擴展。業(yè)務量越來越大,I/O訪問頻率過高,單機無法滿足,此時做多庫的存儲,降低磁盤I/O訪問頻率,提高單機的I/O性能
3.主從復制是讀寫分離的基礎,使數據庫能制成更大 的并發(fā)。例如子報表中,由于部署報表的sql語句十分慢,導致鎖表,影響前臺的服務。如果前臺服務使用master,報表使用slave,那么報表sql將不會造成前臺所,保證了前臺的訪問速度。
* 主從復制的幾種方式:
1.同步復制:所謂的同步復制,意思是master的變化,必須等待slave-1,slave-2,…,slave-n完成后才能返回。
2.異步復制:如同AJAX請求一樣。master只需要完成自己的數據庫操作即可。至于slaves是否收到二進制日志,是否完成操作,不用關心。MYSQL的默認設置。
3.半同步復制:master只保證slaves中的一個操作成功,就返回,其他slave不管。
這個功能,是由google為MYSQL引入的。
* 關于讀寫分離
在完成主從復制時,由于slave是需要同步master的。所以對于insert/delete/update這些更新數據庫的操作,應該在master中完成。而select的查詢操作,則落下到slave中。
當前標題:php面試數據庫 php基礎面試
瀏覽路徑:http://jinyejixie.com/article46/hpdihg.html
成都網站建設公司_創(chuàng)新互聯,為您提供品牌網站建設、靜態(tài)網站、定制網站、網站設計、用戶體驗、云服務器
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯