日期:2014-05-17  浏览次数:20552 次

携程SQL面试题 忘大牛解答
题目是这样的:
1.数据库锁一共分为几种?锁一般在什么情况下使用?
2:怎样处理百万级的数据? 怎样去优化查询
3:现在要有一个关键字aa 要查询文章内容包括aa字符的信息 不能用%aa%和aa%,请问还有什么方法可以查询到包含aa的字符文章信息??
4:临时表一共分为几种?它们之间有哪些区别?

------解决方案--------------------
1.数据库锁一共分为几种?锁一般在什么情况下使用?
--锁作为一种安全机制,用于控制多个用户的并发操作,
以防止用户读取正在由其他用户更改的数据或者多个用
户同时修改统一数据,从而确保事务完整性和数据库的
一致性。
共享锁,排它锁,更新锁


------解决方案--------------------
坐等大牛
------解决方案--------------------
3:现在要有一个关键字aa 要查询文章内容包括aa字符的信息 不能用%aa%和aa%,请问还有什么方法可以查询到包含aa
select * from tbl where charindex('aa',col)>0
------解决方案--------------------
4.临时表一共分为几种?它们之间有哪些区别?
临时表有两种类型:本地和全局。
它们在名称、可见性以及可用性上有区别。
本地临时表的名称以单个数字符号 (#) 打头;它们仅对当前的用户连接是可见的;
当用户从 SQL Server 实例断开连接时被删除。
全局临时表的名称以两个数字符号 (##) 打头,创建后对任何用户都是可见的,
当所有引用该表的用户从 SQL Server 断开连接时被删除。
------解决方案--------------------
2:怎样处理百万级的数据? 怎样去优化查询
这个我也不知道,关注
------解决方案--------------------
3:现在要有一个关键字aa 要查询文章内容包括aa字符的信息 不能用%aa%和aa%,请问还有什么方法可以查询到包含aa的字符文章信息??
可以在该字段上面建个全文索引
查询时,加上 contains(col,'aa')
------解决方案--------------------
坐等大牛!
------解决方案--------------------
http://blog.csdn.net/henreash/article/details/2217363
------解决方案--------------------
4.
临时表就是那些名称以井号 (#) 开头的表。如果当用户断开连接时没有除去临时表,SQL Server 将自动除去临时表。临时表不存储在当前数据库内,而是存储在系统数据库 tempdb 内。

分为两种
 1本地临时表 
 2全局临时表 

------解决方案--------------------
坐等邹老大。不知道何时来啊
------解决方案--------------------
问题1:
锁的概述  
一. 为什么要引入锁  
多个用户同时对数据库的并发操作时会带来以下数据不一致的问题:  
丢失更新
A,B两个用户读同一数据并进行修改,其中一个用户的修改结果破坏了另一个修改的结果,比如订票系统  
脏读
A用户修改了数据,随后B用户又读出该数据,但A用户因为某些原因取消了对数据的修改,数据恢复原值,此时B得到的数据就与数据库内的数据产生了不一致  
不可重复读
A用户读取数据,随后B用户读出该数据并修改,此时A用户再读取数据时发现前后两次的值不一致  
并发控制的主要方法是封锁,锁就是在一段时间内禁止用户做某些操作以避免产生数据不一致  
二 锁的分类  
锁的类别有两种分法:  
1. 从数据库系统的角度来看:分为独占锁(即排它锁),共享锁和更新锁  
MS-SQL Server 使用以下资源锁模式。  
锁模式 描述  
共享 (S) 用于不更改或不更新数据的操作(只读操作),如 SELECT 语句。  
更新 (U) 用于可更新的资源中。防止当多个会话在读取、锁定以及随后可能进行的资源更新时发生常见形式的死锁。  
排它 (X) 用于数据修改操作,例如 INSERT、UPDATE 或 DELETE。确保不会同时同一资源进行多重更新。  
意向锁 用于建立锁的层次结构。意向锁的类型为:意向共享 (IS)、意向排它 (IX) 以及与意向排它共享 (SIX)。  
架构锁 在执行依赖于表架构的操作时使用。架构锁的类型为:架构修改 (Sch-M) 和架构稳定性 (Sch-S)。  
大容量更新 (BU) 向表中大容量复制数据并指定了 TABLOCK 提示时使用。  
共享锁
共享 (S) 锁允许并发事务读取 (SELECT) 一个资源。资源上存在共享 (S) 锁时,任何其它事务都不能修改数据。一旦已经读取数据,便立即释放资源上的共享 (S) 锁,除非将事务隔离级别设置为可重复读或更高级别,或者在事务生存周期内用锁定提示保留共享 (S) 锁。