主頁 > 後端開發 > 原來大廠的MySQL面試會問這些問題!

原來大廠的MySQL面試會問這些問題!

2020-09-10 01:50:51 後端開發

1. 寫出下面2個PHP操作Mysql函式的作用和區別(新浪網技術部)

mysql_num_rows() mysql_affected_rows()

這兩個函式都作用于 mysql_query($query)操作的結果,

mysql_num_rows() 回傳結果集中行的數目,

mysql_affected_rows() 取得前一次 MySQL 操作所影響的記錄行數,

mysql_num_rows()僅對 SELECT 陳述句有效,要取得被 INSERT,UPDATE 或者 DELETE 查詢所影響到的行的數目,用 mysql_affected_rows(),

相關題目:取得查詢結果集總數的函式是?
mysql_num_rows()

Github

2. sql陳述句應該考慮哪些安全性?(新浪網技術部)

防止 Sql 注入,對特殊字符進行轉義、過濾或者使用預編譯的 sql 陳述句系結變數,

最小權限原則,特別是不要用 root 賬戶,為不同的型別的動作或者組建使用不同的賬戶,當 sql 運行出錯時,不要把資料庫回傳的錯誤資訊全部顯示給用戶,以防止泄露服務器和資料庫相關資訊,

3. 簡單描述mysql中,索引,主鍵,唯一索引,聯合索引的區別,對資料庫的性能有什么影響(從讀寫兩方面)(新浪網技術部)

索引是一種特殊的檔案(InnoDB 資料表上的索引是表空間的一個組成部分),它們包含著對資料表里所有記錄的參考指標,

普通索引(由關鍵字 KEY 或 INDEX 定義的索引)的唯一任務是加快對資料的訪問速度,普通索引允許被索引的資料列包含重復的值,如果能確定某個資料列將只包含彼此各不相同的值,在為這個資料列創建索引的時候就應該用關鍵字 UNIQUE 把它定義為一個唯一索引,也就是說,唯一索引可以保證資料記錄的唯一性,

主鍵,是一種特殊的唯一索引,在一張表中只能定義一個主鍵索引,主鍵用于唯一標識 一條記錄,使用關鍵字 PRIMARY KEY 來創建,

索引可以覆寫多個資料列,如像 INDEX(columnA, columnB)索引,這就是聯合索引,索引可以極大的提高資料的查詢速度,但是會降低插入、洗掉、更新表的速度,因為在執行這些操作時,還要操作索引檔案,

4. 有一個留言板,用mysql做資料庫,用戶資訊包括:用戶名,密碼,email,留言內容包括:留言ID,標題,內容,發表時間,狀態(審核,未審核)(新浪網技術部)

請實作下列需求:

(1). 資料庫結構,無需寫建表陳述句,用類似下面的表格,描述清楚即可,注意,要在索引欄 中注明是否需要創建索引,以及要創建的索引的型別

表名 table_aaa
欄位名 欄位說明 欄位型別 索引
name 姓名 varchar(64) 唯一索引
gender 性別 enum(‘M’,‘F’)

(2). 用一個 sql 陳述句查詢出發表留言數量大于 10 條的用戶名及其留言數量,查詢結果按文章數量降序排列參考答案:

用戶表結構如下:

表名 user
欄位名 欄位說明 欄位型別 索引
user_id 用戶編號 int unsigned 主鍵
name 用戶名 varchar(30)
password 密碼 char(32)
email 郵箱 varchar(50)

留言表結構如下:

表名 message
欄位名 欄位說明 欄位型別 索引
message_id 留言編號 int unsigned 主鍵
title 標題 varchr(100)
content 內容 text
user_id 用戶 id int unsigned 普通索引
pubtime 發表時間 int unsigned
state 狀態 tinyint 0 未審核 1 審核

查詢陳述句如下:

SELECT u.name, COUNT(*) AS total
FROM user AS u INNER JOIN message AS m ON u.user_id = m.user_id
GROUP BY u.name HAVING total > 10 ORDER BY total DESC

5. 如何用命令把mysql里的資料備份出來(酷訊PHP工程師筆試題)

(1). 匯出一張表

mysqldump -u 用戶名 -p 密碼 庫名 表名 > 檔案名(如 D:/a.sql)

(2). 匯出多張表

mysqldump -u 用戶名 -p 密碼 庫名 表名 1 表名 2 表名 3 > 檔案名(如D:/a.sql)

(3). 匯出所有表

mysqldump -u 用戶名 -p 密碼 庫名 > 檔案名(如 D:/a.sql)

(4). 匯出一個庫

mysqldump -u 用戶名 -p 密碼 -B 庫名 > 檔案名(如 D:/a.sql)

6. 兩張表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(所屬省份)
……
SELECT c.id AS id,c.city AS cityname,p.province
FROM city c LEFT JOIN province p ON c.provinceid=p.id

(2). 如果要統計每個省份有多少個城市,請用groupby 查詢出來, 顯示欄位:省份id ,省份名,包含多少個城市,

SELECT p.id,p.province,count(c.id) AS num
FROM province p LEFT JOIN city c ON p.id = c.provinceid GROUP BY p.id;

7. MySQL資料庫中的欄位型別varcharchar 的主要區別是什么?哪種欄位的查找效率要高,為什么?

區別一,定長和變長

char 表示定長,長度固定,varchar表示變長,即長度可變.當所插入的字串超出它們的長度時,視情況來處理,如果是嚴格模式,則會拒絕插入 并提示錯誤資訊,如果是寬松模式,則會截取然后插入,如果插入的字串長度小于定義長度時,則會以不同的方式來處理,如char(10),表示存盤的是10個字符,無論你插入的是多少,都是10個,如果少于10個,則用空格填滿,而varchar(10),小于10個的話,則插入多少個字符就存多少個,varchar怎么知道所存盤字串的長度呢?實際上,對于varchar 欄位來說,需要使用一個(如果字串長度小于255)或兩個位元組(長度大于255)來存盤字 符串的長度,

區別之二,存盤的容量不同

對 char 來說,最多能存放的字符個數 255,和編碼無關,而 varchar 呢,最多能存放65532 個字符,VARCHAR的最大有效長度由最大行大小和使用的字符集確定,整體最大長度是65,532位元組

最大有效長度是 65532 位元組,在 varchar 存字串的時候,第一個位元組是空的,不存任何的資料,然后還需要兩個位元組來存放字串的長度,所以有效長度就是 65535 -1 - 2= 65532 由字符集來確定,字符集分單位元組和多位元組

Latin1 一個字符占一個位元組,最多能存放65532 個字符GBK 一個字符占兩個位元組, 最多能存 32766 個字符UTF8 一個字符占三個位元組, 最多能存 21844 個字符

注意,char 和 varchar 后面的長度表示的是字符的個數,而不是位元組數,

兩相比較,char 的效率高,沒有碎片,尤其更新比較頻繁的時候,方便資料檔案指標的操作,但不夠靈活,在實際使用時,應根據實際需求來選用合適的資料型別,

相關題目:若一個表定義為 create table t1(c int, c2 char(30), c3 varchar(N)) charset=utf8; 問
N 的最大值又是多少?(65535 - 1 - 2 - 4 - 30 * 3 )/3

8. IP該如何保存?

最簡單的辦法是使用字串(varchar)來保存,如果從效率考慮的話,可以將ip 保存為整型(unsigned int),使用 php 或 mysql 提供的函式將 ip 轉換為整型,然后存盤即可,

PHP 函式:long2ip()和 ip2loang()

MySQL 函式:inet_aton()和 inet_ntoa

9. 設有成績表如下所示,試查詢兩門及兩門以上不及格同學的平均分,

編號 姓名 科目 分數
1 張三 數學 90
2 張三 語文 50
3 張三 地理 40
4 李四 語文 55
5 李四 政治 45
6 王五 政治 30
#創建一個成績表
CREATE TABLE grade(
id INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY, name VARCHAR(10) NOT NULL,
subject VARCHAR(10) NOT NULL, score TINYINT UNSIGNED NOT NULL
);
#插入記錄
INSERT INTO grade(name,subject,score) VALUES('張三','數學',90); INSERT INTO grade(name,subject,score) VALUES('張三','語文',50); INSERT INTO grade(name,subject,score) VALUES('張三','地理',40); INSERT INTO grade(name,subject,score) VALUES('李四','語文',55); INSERT INTO grade(name,subject,score) VALUES('李四','政治',45); INSERT INTO grade(name,subject,score) VALUES('王五','政治',30);
#查詢陳述句
SELECT name,AVG(score),SUM(score<60) AS gk FROM grade
GROUP BY name HAVING gk>=2;

10. 為了記錄足球比賽的結果,設計表如下,

team:參賽隊伍表

欄位名稱 型別 描述
teamID int 主鍵
teamname varchar(20) 隊伍名稱

match:賽程表

其中,match 賽程表中的 hostTeamID 與 guestTeamID 都和 team 表中的 teamID 關聯,查出2006-6-1 到 2006-7-1 之間舉行的所有比賽,并且用以下形式列出:

拜仁 2:0不萊梅 2006-6-21

#創建參賽隊伍表CREATE TABLE team(
teamID INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY, teamName VARCHAR(30) NOT NULL
);
#向參賽隊伍表中插入記錄
INSERT INTO team(teamName) VALUES(' 拜 仁 '); INSERT INTO team(teamName) VALUES(' 不 萊 梅 '); INSERT INTO team(teamName) VALUES('皇家馬德里'); INSERT INTO team(teamName) VALUES('巴塞羅那'); INSERT INTO team(teamName) VALUES(' 切 爾 西 '); INSERT INTO team(teamName) VALUES(' 曼 聯 '); INSERT INTO team(teamName) VALUES('AC 米 蘭 '); INSERT INTO team(teamName) VALUES('國際米蘭');
#創建 match 賽程表
CREATE TABLE mat(
matchID INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEy,
hostTeamID INT UNSIGNED NOT NULL, guestTeamID INT UNSIGNED NOT NULL,
matchResult VARCHAR(20) NOT NULL, matchTime DATE NOT NULL
);
#向賽程表中插入幾條記錄
INSERT INTO mat(hostTeamID,guestTeamID,matchResult,matchTime) VALUES(1,2,'3:1','2006-6-15');
INSERT INTO mat(hostTeamID,guestTeamID,matchResult,matchTime) VALUES(3,4,'2:2','2006-6-28');
INSERT INTO mat(hostTeamID,guestTeamID,matchResult,matchTime) VALUES(5,6,'0:2','2006-7-10');
INSERT INTO mat(hostTeamID,guestTeamID,matchResult,matchTime) VALUES(7,8,'5:3','2006-5-30');
#查詢陳述句
SELECT t1.teamName,matchResult,t2.teamName,matchTime FROM mat LEFT JOIN team AS t1
ON hostTeamID = t1.teamID LEFT JOIN team AS t2
ON guestTeamID = t2.teamID
WHERE matchTime BETWEEN '2006-6-1' AND '2006-7-1';

11. 有如下兩張表a和b,請寫出得到結果表的查詢陳述句

a表

b表

結果表

#創建表 a
a 表b 表結果表
CREATE TABLE t1_uni( id CHAR(1),
num TINYINT
)engine=MyISAM charset=utf8;
 
#創建表 b
CREATE TABLE t2_uni( id CHAR(1),
num TINYINT
)engine=MyISAM charset=utf8;

#向 a 表中插入記錄
INSERT INTO t1_uni VALUES('a',5),('b',10),('c',15),('d',10);
#向 b 表中插入記錄
INSERT INTO t2_uni VALUES('b',5),('c',15),('d',20),('e',99);
 
#查詢陳述句
SELECT id,SUM(num) FROM(
SELECT id,num FROM t1_uni UNION ALL
SELECT id,num FROM t2_uni) AS tmp GROUP BY id;

12. 寫出發貼數最多的十個人名字的 SQL,利用下表:members(id,username,posts,pass,email)

SELECT members.username FROM members ORDER BY posts DESC LIMIT 10;

13. 請簡述專案中優化sql陳述句執行效率的方法,從哪些方面,sql陳述句性能如何分析?

  1. 盡量選擇較小的列

  2. 將where中用的比較頻繁的欄位建立索引

  3. select子句中避免使用‘*’

  4. 避免在索引列上使用計算、not in 和<>等操作

  5. 當只需要一行資料的時候使用limit 1

  6. 保證單表資料不超過200W,適時分割表,

針對查詢較慢的陳述句,可以使用explain 來分析該陳述句具體的執行情況,

14. SQL中LEFTJOIN的含義是______,如果tbl_user記錄了學生的姓名(name)和學號(ID),tbl_score記錄了學生(有的學生考試以后被開除了,沒有其記錄)的學號(ID)和考試成績(score)以及考試科目(subject),要想列印出各個學生姓名及對應的的各科總成績,則可以用SQL陳述句_______,

left join 表示左外連接,以左表為準,左表中的記錄都會出現在查詢結果中,如果對應的記錄在右表中沒有匹配的記錄,則右表的欄位值以 NULL 填充,

#創建表 tbl_user
CREATE TABLE tbl_user( id INT NOT NULL,
name VARCHAR(50) NOT NULL, PRIMARY KEY (id)
);

#創建表 tbl_socre
CREATE TABLE tbl_score( id INT NOT NULL,
score DEC(6,2) NOT NULL,
subject VARCHAR(20) NOT NULL
);
 
#插入記錄
INSERT INTO tbl_user (id, name) VALUES (1, 'beimu'); INSERT INTO tbl_user (id, name) VALUES (2, 'aihui');
INSERT INTO tbl_score (id, score, subject) VALUES (1, 90, '語文'); INSERT INTO tbl_score (id, score, subject) VALUES (1, 80, '數學'); INSERT INTO tbl_score (id, score, subject) VALUES (2, 86, '數學'); INSERT INTO tbl_score (id, score, subject) VALUES (2, 96, '語文');
 
#查詢陳述句
SELECT a.id,SUM(b.score) AS sumscore FROM tbl_user a LEFT JOIN tbl_score b ON a.id=b.id
GROUP BY a.id;

15. 使用php 寫一段簡單查詢,查出所有姓名為“張三”的內容并列印出來表 user

name tel content date
張三 13333663366 大專畢業 2006-10-11
張三 13612312331 本科畢業 2006-10-15
張四 021-55665566 中專畢業 2006-10-15

請根據上面的題目完成代碼:

$mysql_db=mysql_connect("local","root","pass"); mysql_select_db("DB",$mysql_db);
$result=mysql_query("select * from user where name='張三'");
while($row=mysql_fetch_array($result)){
echo $row['name']. $row['tel']. $row['content']. $row['date']; echo "<br>";
}

16. 寫出SQL陳述句的格式:插入,更新,洗掉(卓望) 表名 user

name tel content date
張三 13333663366 大專畢業 2006-10-11
張三 13612312331 本科畢業 2006-10-15
張四 021-55665566 中專畢業 2006-10-15

(a). 有一新記錄(小王13254748547高中畢業2007-05-06)請用SQL陳述句新增至表中

(b). 請用sql陳述句把張三的時間更新成為當前系統時間

(c). 請寫出洗掉名為張四的全部記錄

INSERT INTO user(name,tel,content,date)VALUES('小王','13254748547','高中畢業','2007-05-06');
UPDATE user SET date = date_format(now(),'%Y-%m-%d') WHERE name = '張三' DELETE FROM user WHERE name = '張四'

17. 資料庫中的事務是什么?

事務(transaction)是作為一個單元的一組有序的資料庫操作,如果組中的所有操作 都成功,則認為事務成功,即使只有一個操作失敗,事務也不成功,如果所有操作完成,事 務則提交,其修改將作用于所有其他資料庫行程,如果一個操作失敗,則事務將回滾,該事 務所有操作的影響都將取消,ACID 四大特性,原子性、隔離性、一致性、持久性,

18. What's the difference between mysql_fetch_row() and mysql_fetch_array()?(Yahoo)

mysql_fetch_row() 從和指定的結果標識關聯的結果集中取得一行資料并作為陣列回傳,每個結果的列儲存在一個陣列的單元中,偏移量從 0 開始,

mysql_fetch_array() 是 mysql_fetch_row() 的擴展版本,除了將資料以數字索引方式儲存在陣列中之外,還可以將資料作為關聯索引儲存,用欄位名作為名,

mysql_fetch_array() 中可選的第二個引數 result_type 是一個常量,可以接受以下值:

MYSQL_ASSOC,MYSQL_NUM 和 MYSQL_BOTH,其默認值是MYSQL_BOTH,

如果 用了 MYSQL_BOTH , 將 得到一個 同時包 含關聯和 數字索 引的陣列 , 用MYSQL_ASSOC 只得到關聯索引(如同 mysql_fetch_assoc() 那樣)用 MYSQL_NUM 只得到數字索引(如同 mysql_fetch_row() 那樣),

19. 請寫出php連mysql連接中,獲取下一個自增長id值的方法,可以寫多個(酷訊)

方法一,使用 show table status ,然后獲取 auto_increment 的值

方法二,使用 select max(id) + 1 from table

方法三,如果是剛插入記錄,可以使用 last_insert_id() + 1 獲得

20. 從表login中選出name欄位包含admin的前10條結果所有資訊的sql陳述句(酷訊)

SELECT * FROM login WHERE name LIKE ‘%admin%’ LIMIT 10;

21. 表中有ABC三列,用SQL陳述句實作:當A列大于B列時選擇A列,否則選擇B列,當B 列大于 C 列時選擇 B 列否則選擇 C 列,

使用case陳述句,如下:

SELECT CASE WHEN A > B THEN A ELSE B END, CASE WHEN B > C THEN B ELSE C END FROM table

22. 寫出三種以上MySQL資料庫存盤引擎的名稱(提示:不區分大小寫)

MyISAM、InnoDB、BDB(Berkeley DB)、Merge、Memory(Heap)、Example、Federated、Archive、CSV、Blackhole、MaxDB 等等十幾個引擎,

23. 請簡述資料庫設計的范式及應用,

一般第 3 范式就足以,用于表結構的優化,這樣做既可以避免應用程式過于復雜同時也避免了 SQL 陳述句過于龐大所造成系統效率低下,

第一范式:若關系模式 R 的每一個屬性是不可再分解的,且有主鍵,則屬于第一范式,第二范式:若 R 屬于第一范式,且所有的非主鍵屬性都完全函式依賴于主鍵屬性,則滿足第二范式,

第三范式:若 R 屬于第二范式,且所有的非主鍵屬性沒有一個是傳遞函式依賴于候選主鍵屬性,則滿足第三范式,

在實際使用中,可以根據需求適當的逆范式,

24. 取得最新一次添加記錄(假設id為主鍵,并且是自增型別)所產生的id的函式是什么?

mysql_insert_id();如果上一查詢沒有產生AUTO_INCREMENT 的值,則mysql_insert_id()

回傳 0,

25. php連接 mysql之后,如何設定 mysql的字符集編碼為 utf8?

mysql_query(“set names utf8”);

26. php 訪問資料庫有哪幾步?

主要有以下幾個步驟:

  1. 連接資料庫服務器:mysql_connect('host','user','password');

  2. 選擇資料庫:mysql_select_db(資料庫名);

  3. 設定從資料庫提取資料的字符集:mysql_query("set names utf8");

  4. 執行 sql 陳述句:mysql_query(sql 陳述句);

  5. 處理結果集

  6. 關閉結果集,釋放資源:mysql_free_result($result);

  7. 關閉與資料庫服務器的連接:mysql_close($link);

27. 在平常mysql優化方面,最基本的也是最重要的優化是(),(奇矩互動)

查詢優化

28. 列出mysql資料庫常用的幾種型別HEAP、()、(),(奇矩互動)

MyISAM,innoDB

29. 請對于據select\fromtable example where((a and b)and c or(((a and b)and(c and d)))優化的陳述句,(奇矩互動)

題目多了一個括號,在 where 后面,但不影響題目的意思,可以將 sql 陳述句優化如下:

select * from table example where a and b and c

30. 解釋MySQL外連接、內連接與自連接的區別(小米)

先說什么是交叉連接,交叉連接又叫笛卡爾積,它是指不使用任何條件,直接將一個表的所有記錄和另一個表中的所有記錄一一匹配,

內連接則是只有條件的交叉連接,根據某個條件篩選出符合條件的記錄,不符合條件的記錄不會出現在結果集中,即內連接只連接匹配的行,

而外連接其結果集中不僅包含符合連接條件的行,而且還會包括左表、右表或兩個表中的所有資料行,這三種情況依次稱之為左外連接,右外連接,和全外連接,

左外連接,也稱左連接,左表為主表,左表中的所有記錄都會出現在結果集中,對于那 些在右表中并沒有匹配的記錄,仍然要顯示,右邊對應的那些欄位值以 NULL 來填充,

右外連接,也稱右連接,右表為主表,右表中的所有記錄都會出現在結果集中, 左連接和右連接可以互換,MySQL 目前還不支持全外連接,

31. 兩條查詢陳述句,一條是select * from table1 where id > 10and id 200 and id < 500,請嘗試只寫一條SQL 陳述句,完成相應的查詢任務,(鑫眾人云)

使用 union 陳述句,但有一個前提,即 table1 和 table2 的結構相同

SELECT * FROM table1 WHERE id > 10 AND id < 100 UNION ALL

SELECT * FROM table2 WHERE id > 200 AND id < 500

32. 寫出你所知道的資料庫,(億郵)

MySQL,SQL Server, Oracle,Sybase, informix, DB2 等

33. 用戶互為好友的 SNS 存盤結構怎么設計,(億郵)

首先是有用戶表,如下:

CREATE TABLE user(
id INT UNSIGNED NOT NULL PRIMARY KEY AUTO_INCREMENT, username VARCHAR(30) NOT NULL DEFAULT '' COMMENT '用戶名', emailVARCHAR(50) NOT NULL DEFAULT '' COMMENT ' 郵箱 ', password CHAR(32) NOT NULL DEFAULT ''COMMENT '密碼'
)engine=MyISAM charset=utf8 comment='用戶表';

其次是用戶間的關系,如下:

CREATE TABLE relation(
rel_id INT UNSIGNED NOT NULL PRIMARY KEY AUTO_INCREMENT, fuid INT UNSIGNED NOT NULL COMMENT '關注人的 id',
suid INT UNSIGNED NOT NULL COMMENT '被關注人的 id',
relation_type ENUM('S','D') NOT NULL DEFAULT 'S' COMMENT '關系,s 為關注,
d 表示為好友'
)engine=MyISAM charset=utf8 comment='用戶關系表';

34. 假設現在有一個資料庫服務器,服務器地址為192.168.0.110,用戶名為root 密碼為password 請使用 PHP 撰寫一個面向程序化的連接該資料庫的腳本代碼 (億郵)

$conn = mysql_connect('192.168.0.110','root','password') or die('資料庫連接失敗');

35. 簡述在 MySQL 資料庫中 MyISAM 和 InnoDB 的區別 (億郵)

區別主要有以下幾個:

  • 構成上,MyISAM 的表在磁盤中有三個檔案組成,分別是表定義檔案( .frm)、資料檔案(.MYD)、索引檔案(.MYI),而 InnoDB 的表由表定義檔案(.frm)、表空間資料和日志檔案組成,
  • 安全方面,MyISAM 強調的是性能,其查詢效率較高,但不支持事務和外鍵等安全性方面的功能,而 InnoDB 支持事務和外鍵等高級功能,查詢效率稍低,
  • 對鎖的支持,MyISAM 支持表鎖,而 InnoDB 支持行鎖,

36. 現在有下面一個查詢句 select \ from tabname where id=2 and password='abc’如何判斷它是現在是最優的,(億郵)

可以使用 explain select * from tabname where id=2 and password='abc’來分析其執行情況,

37. 請問如何在 Mysql 操作中如何寫入 utf8 格式資料 (億郵)

首先確保資料庫中的表是基于 utf8 編碼的,其次 php 檔案是 utf8 編碼,在執行 mysql 操作之前,執行 mysql_query(‘set names utf8’)操作,對于要操作的文本如果是 utf8 編碼,則可以直接操作,如果是其它編碼,則可以使用iconv 函式將其轉化為 utf8 編碼, 然后寫入,

38. mysql 中 varchar 度是多少? 用什么型別的欄位存盤大文本? date 和datetime 和 timestamp 什么區別?怎么看資料庫中有哪些 sql 正在執行? (卓望)

varchar 的最大有效長度由最大行大小和使用的字符集確定,整體最大長度是65532 位元組,在 varchar 存字串的時候,第一個位元組是空的,不存任何的資料,然后還需要兩個位元組來存放字串的長度,所以有效長度就是 65535 - 1 - 2 =65532,

由字符集來確定,字符集分單位元組和多位元組,如果是單位元組,如 latin1,則最多可以存放 65532 個字符,如果是多位元組,如 GBK 則可以存放 32766 個字符,UTF8 則可以存放 21844個字符,

存盤大文本可以使用 text 型別,

date 表示日期,其范圍為 1000-01-01 ~ 9999-12-31

datetime 表示日期時間,其范圍為 1000-01-01 00:00:00 ~ 9999-12-31 23:59:59

timestamp 是 unix 時 間 戳 的 日 期 時 間 表 示 方 式 , 其 范 圍 較 小 為1970-01-01 00:00:00~2038-01-19 03:14:07 ,timestamp 具備自動初始化和自動更新功能,

查看資料庫中正在執行的 sql 陳述句可以使用日志,也可以使用 show processlist 命令,

39. 現在有一個 mysql 資料庫表visits 記錄用戶訪問情況,表結構如下:

visits(
id int unsigned auto_increment,
user_id int unsigned comment ‘本次訪問頁面數’, visit_time timestamp comment‘本次訪問開始時間’, primary key(id)
);

用戶每訪問過一次網站(從進入到離開),會增加一條記錄,記錄用戶的ID(user_id),以及訪問的頁面總數,比如:

1)208,2,//208 這個用戶訪問 2 個頁面

2)2073,3,

3)208,1,//208 用戶訪問了 1 個頁面

(1). 請寫一個SQL 陳述句挑出你是累計訪問頁面數最多的 10 個用戶(user_id)和對應的訪問頁面數,

(2). 請寫一個 SQL 陳述句,輸出累計訪問頁面數分別等于 1,2,3,4,5,6,7,8,9,10 的唯一用戶的數量,如果某個數量對應的用戶數為 0,可以不輸出,(嘀嗒團)

從題目的描述來看,表結構貌似有些問題,user_id 應為用戶 ID,而不是訪問頁面數, 增加一個欄位 pages 表示訪問頁面數,

查詢訪問頁面數最多的 10 個用戶的查詢陳述句如下: SELECT user_id, sum(pages) as total FROM visits GROUP BY user_id ORDER BY total DESC LIMIT 10;

輸出累計訪問頁面數分別等于 1,2,3,4,5,6,7,8,9,10 的唯一用戶的數量的查詢陳述句如下: SELECT total,count(user_id) FROM (SELECT user_id, sum(pages) AS total FROM visits

GROUP BY user_id) AS temp WHERE total IN (1,2,3,4,5,6,7,8,9,10) GROUP BY total ;

40. 簡述存盤程序的適用情況

當需要處理復雜的查詢和運算時,可以使用存盤程序,

從應用分層的原則,大量使用存盤程序導致業務邏輯分散在 DB 和應用服務器層,不利于維護和更新,

總體來說,存盤程式可以用,但要慎重,最好只用來維護,不用于業務邏輯和支撐高并 發高性能的東西,

點關注,不迷路

好了各位,以上就是這篇文章的全部內容了,能看到這里的人呀,都是人才,之前說過,PHP方面的技術點很多,也是因為太多了,實在是寫不過來,寫過來了大家也不會看的太多,所以我這里把它整理成了PDF和檔案,如果有需要的可以

點擊進入暗號: 博客園


更多學習內容可以訪問【對標大廠】精品PHP架構師教程目錄大全,只要你能看完保證薪資上升一個臺階(持續更新)

以上內容希望幫助到大家,很多PHPer在進階的時候總會遇到一些問題和瓶頸,業務代碼寫多了沒有方向感,不知道該從那里入手去提升,對此我整理了一些資料,包括但不限于:分布式架構、高可擴展、高性能、高并發、服務器性能調優、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql優化、shell腳本、Docker、微服務、Nginx等多個知識點高級進階干貨需要的可以免費分享給大家,需要的可以加入我的PHP技術交流群953224940

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/381.html

標籤:PHP

上一篇:thinkphp自動生成sitemap網站站點地圖

下一篇:兩個優秀的在線去水印網站,短視頻圖片去水印

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Rust中的智能指標:Box<T> Rc<T> Arc<T> Cell<T> RefCell<T> Weak

    Rust中的智能指標是什么 智能指標(smart pointers)是一類資料結構,是擁有資料所有權和額外功能的指標。是指標的進一步發展 指標(pointer)是一個包含記憶體地址的變數的通用概念。這個地址參考,或 ” 指向”(points at)一些其 他資料 。參考以 & 符號為標志并借用了他們所 ......

    uj5u.com 2023-04-20 07:24:10 more
  • Java的值傳遞和參考傳遞

    值傳遞不會改變本身,參考傳遞(如果傳遞的值需要實體化到堆里)如果發生修改了會改變本身。 1.基本資料型別都是值傳遞 package com.example.basic; public class Test { public static void main(String[] args) { int ......

    uj5u.com 2023-04-20 07:24:04 more
  • [2]SpinalHDL教程——Scala簡單入門

    第一個 Scala 程式 shell里面輸入 $ scala scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! 檔案形式 object HelloWorld { /* 這是我的第一個 Scala 程式 * 以 ......

    uj5u.com 2023-04-20 07:23:58 more
  • 理解函式指標和回呼函式

    理解 函式指標 指向函式的指標。比如: 理解函式指標的偽代碼 void (*p)(int type, char *data); // 定義一個函式指標p void func(int type, char *data); // 宣告一個函式func p = func; // 將指標p指向函式func ......

    uj5u.com 2023-04-20 07:23:52 more
  • Django筆記二十五之資料庫函式之日期函式

    本文首發于公眾號:Hunter后端 原文鏈接:Django筆記二十五之資料庫函式之日期函式 日期函式主要介紹兩個大類,Extract() 和 Trunc() Extract() 函式作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等資料 Trunc() 的作用則是截取,比如 2022-0 ......

    uj5u.com 2023-04-20 07:23:45 more
  • 一天吃透JVM面試八股文

    什么是JVM? JVM,全稱Java Virtual Machine(Java虛擬機),是通過在實際的計算機上仿真模擬各種計算機功能來實作的。由一套位元組碼指令集、一組暫存器、一個堆疊、一個垃圾回收堆和一個存盤方法域等組成。JVM屏蔽了與作業系統平臺相關的資訊,使得Java程式只需要生成在Java虛擬機 ......

    uj5u.com 2023-04-20 07:23:31 more
  • 使用Java接入小程式訂閱訊息!

    更新完微信服務號的模板訊息之后,我又趕緊把微信小程式的訂閱訊息給實作了!之前我一直以為微信小程式也是要企業才能申請,沒想到小程式個人就能申請。 訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】【企業微信】【釘釘】等訊息型別。 https://gitee.com/zhongfuch ......

    uj5u.com 2023-04-20 07:22:59 more
  • java -- 緩沖流、轉換流、序列化流

    緩沖流 緩沖流, 也叫高效流, 按照資料型別分類: 位元組緩沖流:BufferedInputStream,BufferedOutputStream 字符緩沖流:BufferedReader,BufferedWriter 緩沖流的基本原理,是在創建流物件時,會創建一個內置的默認大小的緩沖區陣列,通過緩沖 ......

    uj5u.com 2023-04-20 07:22:49 more
  • Java-SpringBoot-Range請求頭設定實作視頻分段傳輸

    老實說,人太懶了,現在基本都不喜歡寫筆記了,但是網上有關Range請求頭的文章都太水了 下面是抄的一段StackOverflow的代碼...自己大修改過的,寫的注釋挺全的,應該直接看得懂,就不解釋了 寫的不好...只是希望能給視頻網站開發的新手一點點幫助吧. 業務場景:視頻分段傳輸、視頻多段傳輸(理 ......

    uj5u.com 2023-04-20 07:22:42 more
  • Windows 10開發教程_編程入門自學教程_菜鳥教程-免費教程分享

    教程簡介 Windows 10開發入門教程 - 從簡單的步驟了解Windows 10開發,從基本到高級概念,包括簡介,UWP,第一個應用程式,商店,XAML控制元件,資料系結,XAML性能,自適應設計,自適應UI,自適應代碼,檔案管理,SQLite資料庫,應用程式到應用程式通信,應用程式本地化,應用程式 ......

    uj5u.com 2023-04-20 07:22:35 more