ToB企服应用市场:ToB评测及商务社交产业平台

标题: 数据库基础面试第二弹 [打印本页]

作者: 北冰洋以北    时间: 2023-9-6 01:55
标题: 数据库基础面试第二弹
1. 乐观锁和悲观锁的理解及使用

乐观锁和悲观锁是在并发编程中使用的两种并发控制机制,用于解决多线程或多进程环境下的数据一致性问题。
1. 悲观锁(Pessimistic Locking):
  悲观锁的思想是假设并发访问会导致冲突,因此在访问共享资源之前,悲观锁会将资源锁定,确保其他线程无法修改资源。悲观锁的典型应用是数据库中的行级锁,使用SELECT...FOR
UPDATE语句锁定查询结果。
使用悲观锁的过程如下:
悲观锁的优点是保证了数据的一致性,但是它的缺点是在高并发环境下,锁的竞争会导致性能下降。
2. 乐观锁(Optimistic Locking):
乐观锁的思想是假设并发访问不会导致冲突,因此在线程访问共享资源之前,不会加锁。相反,乐观锁会在更新资源时,检查在此期间是否有其他线程修改了资源。
使用乐观锁的过程如下:
  乐观锁的优点是在无冲突的情况下,不需要进行加锁操作,从而提高了并发性能。然而,如果冲突频繁发生,会导致大量的回滚和重试操作,降低性能。
总的来说,悲观锁适合对于冲突频繁发生的场景,可以保证数据的一致性;而乐观锁适合对于冲突较少发生的场景,可以提高并发性能。选择使用哪种锁要根据具体的应用场景和性能需求进行
权衡。
乐观锁与悲观锁例子:
  1. SELECT stock FROM inventory WHERE product_id = <product_id> FOR UPDATE;
  2. ```
  3. 在上述代码中,使用 `FOR UPDATE` 子句来锁定库存行,确保其他并发操作无法修改库存数量。
  4. START TRANSACTION;  -- 开启事务
  5. SELECT stock FROM inventory WHERE product_id = <product_id> FOR UPDATE;  -- 获取并锁定库存行
  6. -- 检查库存是否足够
  7. IF stock >= <quantity> THEN
  8.     UPDATE inventory SET stock = stock - <quantity> WHERE product_id = <product_id>;  -- 更新库存
  9.     COMMIT;  -- 提交事务
  10.     -- 库存更新成功,继续后续操作
  11. ELSE
  12.     ROLLBACK;  -- 回滚事务
  13.     -- 库存不足,处理相应逻辑,如提示用户库存不足
  14. END IF;
  15. ```
复制代码
2. 聚集索引和非聚集索引的区别:

聚集索引(Clustered Index)和非聚集索引(Non-clustered Index)是数据库中常用的索引类型,它们在索引的组织方式和数据访问方式上存在一些区别。
聚集索引:
非聚集索引:
区别总结:
在实际使用中,根据具体的查询需求和数据特点,可以根据需要选择适当的索引类型,以提高数据库的查询性能和数据访问效率。
创建聚集索引和非聚集索引的示例:
  1. CREATE CLUSTERED INDEX idx_Orders_OrderID ON Orders (OrderID);
  2. 上述语句创建了一个名为 "idx_Orders_OrderID" 的聚集索引,它基于 "Orders" 表的 "OrderID" 列。
  3. CREATE NONCLUSTERED INDEX idx_Customers_Email ON Customers (Email);
  4. 上述语句创建了一个名为 "idx_Customers_Email" 的非聚集索引,它基于 "Customers" 表的 "Email" 列。
复制代码
3.  为什么索引用B+树,而不用普通的二叉树

综上所述,B+树相对于普通的二叉树具有更好的磁盘访问效率、顺序访问性能、稳定性和缓存利用,使其成为了广泛应用于索引结构的一种理想选择。
4. Hash索引和B+树索引区别:

Hash索引和B+树索引是两种常见的索引结构,它们在实现原理、适用场景和性能方面存在一些区别。
实现原理:
适用场景:
数据访问性能:
存储空间利用:
综上所述,Hash索引适用于等值查询,具有固定的访问时间,但不支持范围查询和排序操作。B+树索引适用于范围查询、排序操作和模糊查询,具有较好的顺序访问性能和稳定性,但访问时间复杂度与树的高度相关。选择使用哪种索引结构取决于具体的应用需求和数据访问模式。
5. 索引不适合哪些场景以及有哪些优缺点:

索引在大多数情况下可以显著提高数据库查询的性能,但并不适合所有场景。以下是索引不适合的一些场景以及索引的一些优点和缺点:
索引不适合的场景:
索引的优点:
索引的缺点:
综上所述,索引在大多数情况下是数据库性能优化的重要工具,但在某些场景下可能不适用或需要谨慎使用。正确的索引设计和调优可以提高查询性能,而错误的使用可能会导致额外的开销和性能下降。
6.最左前缀匹配原则是什么

最左前缀匹配原则是数据库索引设计中的一个重要原则,它指出在使用复合索引(Composite Index)时,索引将按照索引键的顺序进行匹配和检索,并且只能利用索引的最左前缀来进行匹配。
具体来说,如果一个复合索引包含多个列(例如(A, B, C)),那么在查询时,最左前缀匹配原则要求查询条件必须从索引的最左侧开始,并且连续地匹配到索引的某个位置为止。也就是说,查询条件可以是(A)、(A, B)或者(A, B, C),但不能是(B)、(C)或者(B, C)。
遵循最左前缀匹配原则的好处是可以最大程度地利用索引的有序性,提高查询的效率。由于索引按照键的顺序存储,因此在查询时只需定位到满足最左前缀条件的索引位置,而不需要扫描整个索引。
举个例子,假设有一个复合索引 (A, B, C),如果查询条件是(A = 1),那么索引可以用于加速查询,因为最左前缀 (A) 匹配成功。但如果查询条件是(B = 2),即使索引中包含了列 B,也无法利用索引进行加速,因为最左前缀不匹配。
需要注意的是,最左前缀匹配原则并不意味着只有最左侧的列可以使用索引,而是强调索引的有序性和连续性。在某些情况下,可以通过创建单列索引或调整索引顺序来更好地利用索引。
 

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4