transaction-sql

-----题引:transaction-sql是微软的数据库编程语言,实现了 sql 92标准,兼容了一些微软自身的东西,像流程定义、函数等。
 
1、索引
好处:(1)提高查询表内数据的速度。(2)表与表之间的连接速度加快。
坏处:(1)创建索引和维护索引都会消耗时间。(2)会占用一定物理空间,占用物理空间过多会影响整个SQL Server性能。
建立索引的原则:
(1) 主键的数据列一定要建立索引,因为主键可以加速定位到表中的某一行。
(2) 外键的数据列一定要建立索引,外键列通常用于表与表之间的连接,在其上创建索引可以加快表间的连接速度。
(3) 对于经常查询的数据列最好建立索引。
索引分类:(1)聚集索引。(2)非聚集索引。(3)唯一索引。
 
 
2、视图
优点:
(1) 数据保密,对不同的用户定义不同的视图,使用户只能看到与自己相关的数据。
(2) 简化查询操作。
(3) 保证数据的逻辑独立性。
缺点:某些视图是不能更新数据的,union、group by、avg、sum、max、distinct等及连接表的视图。
 
 
 
3、存储过程
存储过程是一个预编译的SQL语句,优点是允许模块化的设计,就是说只需创建一次,以后在该程序中就可以调用多次。如果某次操作需要执行多次SQL,使用存储过程比单纯SQL语句执行要快。
主要优点有如下三点:
(1)通过本地存储、代码预编译和缓存技术,提高数据操作的性能。
(2)增加了可维护性。
(3)增强了安全性。
 
 
 
4、触发器
触发器(trigger)是个特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作( insert,delete, update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。触发器的主要好处在于它们可以包含使用 Transact-SQL 代码的复杂处理逻辑。虽然触发器功能强大,能轻松可靠地实现许多复杂的功能,但必须慎用触发器,因为滥用会造成数据库及应用程序的维护困难。
触发器的分类与作用:
可以认为触发器是一种特殊的存储过程,在某种特定事件发生时自动执行。在sql server2005中有两类触发器, DDL触发器DML触发器
其中DML 触发器在数据库中发生 数据操作语言 (DML) 事件时将启用。DML 事件包括在指定表或视图中修改数据的 INSERT 语句、UPDATE 语句或 DELETE 语句。DDL 触发器是 SQL Server 2005 的新增功能。当服务器或数据库中发生数据定义语言 (DDL) 事件时将调用这些触发器。所谓DDL事件指Create ,Drop数据库对象等操作。
使用DML触发器可以实现表的同时修改,比如我们在当前学生毕业,我们在student表中删除该学生记录,同时我们要向已毕业学生表中存放该学生信息,可以用DML触发器来确保该操作执行。其次使用触发器可以防止错误的增删改操作,可移植性比Check约束更为复杂的约束,这是因为在触发器中我们能够引用其他表中的内容,甚至其他数据库中的内容。最后一点使用DML触发器可以在update,insert,delete执行完以后对相关表的数据进行检查,以保障数据库的完整性。
DDL 触发器会为响应多种数据定义语言 (DDL) 语句而激发。这些语句主要是以 CREATE、ALTER 和 DROP 开头的语句。DDL 触发器可用于管理任务,例如审核和控制数据库操作。一般DDL触发器会在如下情况用到,阻止用户更改数据库结构,对数据库架构的更改做记录,要对数据库架构的更改做响应。
值得注意的是,只有在运行触发 DDL 触发器的 DDL 语句后,DDL 触发器才会激发。因此DDL 触发器不能作为 INSTEAD OF 触发器使用。
 
 
5、游标
游标(Cursor)是处理数据的一种方法,为了查看或者处理结果集中的数据,游标提供了在结果集中一次以行或者多行前进或向后浏览数据的能力。我们可以把游标当作一个指针,它可以指定结果中的任何位置,然后允许用户对指定位置的数据进行处理。
游标包含两个部分:游标结果集(定义该游标得SELECT语句返回的行的集合),游标位置(指向这个结果集某一行的当前指针)。
游标的优点:
1.允许程序对由查询语句Select返回的行集合中的每一行执行相同或不同的操作,而不是对整个行集合执行同一操作。
2.提供基于游标位置的表中的行进行删除和更新的能力。
3.游标实际上是作为面向数据库集合的数据库管理系统(DBMS)和面向行的程序设计之间的桥梁。
 
 
 
6、什么是事务?什么是锁?
事务:被绑定在一起作为一个逻辑工作单元的SQL语句分组,如果任何一个语句操作失败那么整个操作就会失败,以后操作就会回滚到操作前状态,或者是上一个节点。为了确保要么执行,要么不执行,就可以使用事务。要将有组语句作为事务考虑,就需要通过ACID测试,即原子性,一致性,隔离性和持久性。
 锁:在所以的DBMS中,锁是实现事务的关键,锁可以保证事务的完整性和并发性。与现实生活中锁一样,它可以使某些数据的拥有者,在某段时间内不能使用某些数据或数据结构。当然锁还分级别的。
 
 
7、存储过程和函数的区别
1.  一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。
2.  对于存储过程来说可以返回参数,而函数只能返回值或者表对象。
3.  存储过程一般是作为一个独立的部分来执行,而函数可以作为查询语句的一个部分来调用,由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。
4.  当存储过程和函数被执行的时候,SQL Manager会到procedure cache中去取相应的查询语句,如果在procedure cache里没有相应的查询语句,SQL Manager就会对存储过程和函数进行编译。
 
 
 
8、维护数据库的完整性和一致性,你喜欢用触发器还是自写业务逻辑?为什么?
尽可能使用约束,如check,主键,外键,非空字段等来约束,这样做效率最高,也最方便。其次是使用触发器,这种方法可以保证,无论什么业务系统访问数据库都可以保证数据的完整新和一致性。最后考虑的是自写业务逻辑,但这样做麻烦,编程复杂,效率低下。
 
 
9、什么是内存泄漏?
一般我们所说的内存泄漏指的是堆内存的泄漏。堆内存是程序从堆中为其分配的,大小任意的,使用完后要显示释放内存。当应用程序用关键字new等创建对象时,就从堆中为它分配一块内存,使用完后程序调用free或者delete释放该内存,否则就说该内存就不能被使用,我们就说该内存被泄漏了。
 
10、SQLSERVER服务器中,给定表 table1 中有两个字段 ID、LastUpdateDate,ID表示更新的事务号, LastUpdateDate表示更新时的服务器时间,请使用一句SQL语句获得最后更新的事务号
SELECT ID 
FROM table1 
WHERE LastUpdateDate = 
(
    SELECT MAX(LastUpdateDate) 
    FROM table1
)
11、 写出一条Sql语句: 取出表A中第31到第40记录(SQLServer, 以自动增长的ID作为主键,  注意:ID可能不是连续的)
 
解1:  select top 10 * from A where id not in (select top 30 id from A)
解2:  
select top 10 * 
from A 
where id > 
(
    select max(id) 
    from (select top 30 id from A )as A
)
 
12、如下的两个表,如下图所示,写出执行图下SQL语句的结果
  SELECT *   
  FROM Table1 a,Table2 b   
  WHERE a.id = b.id  
 
 
 
13、为管理岗位业务培训信息,建立3个表:  [经典多对多样例]
S (S#,SN,SD,SA)    S#,SN,SD,SA 分别代表学号、学员姓名、所属单位、学员年龄
C (C#,CN )    C#,CN 分别代表课程编号、课程名称
SC ( S#,C#,G )    S#,C#,G 分别代表学号、所选修的课程编号、学习成绩
1. 使用标准SQL嵌套语句查询选修课程名称为 税收基础 的学员学号和姓名2. 使用标准SQL嵌套语句查询选修课程编号为'02'的学员姓名和所属单位
Select S#,SN FROM S
Where S# IN 

    Select [S#] 
    FROM C,SC
    Where C.[C#]=SC.[C#]   
    AND CN=N'税收基础' --加 N 就表示字符串用 Unicode 方式存储
)
 
 ---使用连接(join)查询
SELECT S.SN,S.SD 
FROM S,SC
WHERE S.[S#]=SC.[S#] 
AND SC.[C#]='02'
---上述sql等价于
SELECT S.SN,S.SD 
FROM S inner join SC
on S.[S#]=SC.[S#] 
AND SC.[C#]='02'
 
---- 注:连接查询分四种:内连接,左连接,右连接以及 笛卡尔积。
 
3. 使用标准SQL嵌套语句查询不选修课程编号为’02’的学员姓名和所属单位
SELECT SN,SD 
FROM S
WHERE [S#] NOT IN 

    SELECT [S#] 
    FROM SC
    Where [C#]='02'
)
4. 使用标准SQL嵌套语句查询选修全部课程的学员姓名和所属单位
SELECT SN,SD 
FROM S 
WHERE S# IN 
(
    SELECT SC.S# 
    FROM SC RIGHT JOIN C ON SC.C# = C.C#
    GROUP BY SC.S#  --在结果集中以学生分组,分组后的 SC.C#选课数=C.C#课程数 即为全部课程
    HAVING COUNT(distinct(SC.C#))  --注意:一个学生同一门课程可能有多条成绩记录,需要distinct 
    =( select count(*) from C ) --注意:HAVING条件不能用COUNT(distinct(SC.C#)) = COUNT(distinct(C.C#)
)--子查询获得选修全部课程的学生学号

5. 查询选修了课程的学员人数

6. 查询选修课程超过5门的学员学号和所属单位
Select 学员人数=COUNT(DISTINCT [S#]) FROM SC
 
Select [S#],SD 
FROM S
Where [S#] IN 
(  
    Select [S#]
    FROM SC
    GROUP BY [S#]
    HAVING COUNT( DISTINCT [C#]) > 5  
)

你可能感兴趣的:(mysql,sql,数据库管理)