php面试题汇总(二)数据库操作

理论基础题

1.触发器的作用?

答:触发器是一中特殊的存储过程,主要是通过事件来触发而被执行的。它可以强化约束,来维护数据的完整性和一致性,可以跟踪数据库内的操作从而不允许未经许可的更新和变化。可以联级运算。如,某表上的触发器上包含对另一个表的数据操作,而该操作又会导致该表触发器被触发。

2. 什么是存储过程?用什么来调用?

答:存储过程是一个预编译的SQL 语句,优点是允许模块化的设计,就是说只需创建一次,以后在该程序中就可以调用多次。如果某次操作需要执行多次SQL ,使用存储过程比单纯SQL 语句执行要快。可以用一个命令对象来调用存储过程。

3. 索引的作用?和它的优点缺点是什么?

答:索引就一种特殊的查询表,数据库的搜索引擎可以利用它加速对数据的检索。它很类似与现实生活中书的目录,不需要查询整本书内容就可以找到想要的数据。索引可以是唯一的,创建索引允许指定单个列或者是多个列。缺点是它减慢了数据录入的速度,同时也增加了数据库的尺寸大小。

4. 什么是内存泄漏?

答:一般我们所说的内存泄漏指的是堆内存的泄漏。堆内存是程序从堆中为其分配的,大小任意的,使用完后要显示释放内存。当应用程序用关键字new 等创建对象时,就从堆中为它分配一块内存,使用完后程序调用free 或者delete 释放该内存,否则就说该内存就不能被使用,我们就说该内存被泄漏了。

5. 维护数据库的完整性和一致性,你喜欢用触发器还是自写业务逻辑?为什么?

答:我是这样做的,尽可能使用约束,如check, 主键,外键,非空字段等来约束,这样做效率最高,也最方便。其次是使用触发器,这种方法可以保证,无论什么业务系统访问数据库都可以保证数据的完整新和一致性。最后考虑的是自写业务逻辑,但这样做麻烦,编程复杂,效率低下。

6. 什么是事务?什么是锁?

答:事务就是被绑定在一起作为一个逻辑工作单元的SQL 语句分组,如果任何一个语句操作失败那么整个操作就被失败,以后操作就会回滚到操作前状态,或者是上有个节点。为了确保要么执行,要么不执行,就可以使用事务。要将有组语句作为事务考虑,就需要通过ACID 测试,即原子性,一致性,隔离性和持久性。

锁:在所以的 DBMS中,锁是实现事务的关键,锁可以保证事务的完整性和并发性。与现实生活中锁一样,它可以使某些数据的拥有者,在某段时间内不能使用某些数据或数据结构。当然锁还分级别的。

7. 什么叫视图?游标是什么?

答:视图是一种虚拟的表,具有和物理表相同的功能。可以对视图进行增,改,查,操作,试图通常是有一个表或者多个表的行或列的子集。对视图的修改不影响基本表。它使得我们获取数据更容易,相比多表查询。

游标:是对查询出来的结果集作为一个单元来有效的处理。游标可以定在该单元中的特定行,从结果集的当前行检索一行或多行。可以对结果集当前行做修改。一般不使用游标,但是需要逐条处理数据的时候,游标显得十分重要。

SQL面试题

1.

a) 按日获取每个商家,订单额大于2元的订单数;
b) 按日获取每个商家,每人平均订单量;
c) 按日获取每个商家,每人平均订单额;
(每条SQL包含商家名称,用3条SQL完成上述查询)

shop_info表:

shop_id商家编号
shop_name商家名称

order_log表:

id主键
shop_id商家编号
user_id用户编号
dayyymmdd
create_time下单时间
prise订单额
a):
SELECT s.shop_name, o.day, count(o.id) AS num
FROM order_log o 
LEFT JOIN shop_info s 
ON s.shop_id = o.shop_id 
WHERE o.prise > 2 
GROUP BY o.shop_id,o.day;
b):
SELECT s.shop_name, o.day, avg(o.user_id) as order_num 
FROM order_log o 
LEFT JOIN shop_info s 
ON o.shop_id = s.shop_id 
GROUP BY o.shop_id,o.day;
c):
SELECT s.shop_name, o.day, avg(o.prise) as avg_prise 
FROM order_log o 
LEFT JOIN shop_info s 
ON o.shop_id = s.shop_id 
GROUP BY o.shop_id,o.day;
2. 两张表 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, c.city as cityname, p.province 
FROM city c 
LEFT JOIN province p 
ON c.provinceid = p.id;

(2). 如果要统计每个省份有多少个城市,请用 group by 查询出来。
显示字段:省份 id ,省份名,包含多少个城市。

SELECT p.id, p.province, count(c.id) AS num 
FROM province p 
LEFT JOIN city c 
ON c.provinceid = p.id 
GROUP BY p.id;
3. 设有成绩表如下所示,试查询两门及两门以上不及格同学的平均分。

编号 姓名 科目 分数
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
);
查询语句:
SELECT name, AVG(score), sum(score<60) AS gk FROM grade GROUP BY name HAVING gk>=2;
4. 写一sql语句获取发帖子数最多的前十个人的名字

表和字段如下:member(id,name,posts,sex,address) ,posts 为发帖子数目

SELECT name FROM member ORDER BY posts DESC limit 10;
变形:

表和字段如下:member(id,name,sex,address)
member_post(id,user_id)

SELECT m.username,count(*) AS num 
FROM member_posts p 
LEFT JOIN member m 
ON m.id=p.user_id 
GROUP BY p.user_id 
ORDER BY num DESC LIMIT 10;
15. 设计满足以下业务需求的数据库表结构:
  1. 某位商家举办一期限时玩游戏抽奖活动,用户玩游戏达到50分及以上才可抽奖,每位用户可以参加多次活动。
  2. 在活动结束之后需要统计一张抽奖纪录列表,同时包括以下内容:
  3. 如果A用户抽10次中奖2次则列表显示2条A用户中奖纪录;如果B用户抽8次都没有中奖,则仅显示B用户玩游戏得分最高的那条抽奖纪录。A,B用户的抽奖结果最后在列表上有三条纪录。
  4. 以纪录的时间倒序排序。
  5. 满足列表每20条翻页需求。
18. 设计一个论坛系统数据库,日访问1000万,更新10万帖子。

字段(id,username,phone,password,address,title,content,create_time,回复)

画出ER图,说说你的设计思路。

19. 接着上题,假设数据量添加了100倍,在不DB,说说你的优化思路。
20. 接着上题,假设使用redis来提升性能,redis最多存1万条,说说你的优化思路。
0 人推荐

声明:本文原创发布于加藤非博客,转载请注明出处:加藤非博客 jiatengfei.com 。如有侵权,请联系本站删除。

加藤非博客
请先登录再发表评论
  • 最新评论

  • 总共0条评论