数据库基础知识
一、exists和in的比较
1、exists和in的区别
- 执行顺序不同
谁是驱动表,谁先执行查询,谁后执行查询
- 执行过程不同
exists的优点是:只要存在就返回了,这样的话很有可能不需要扫描整个表。
in需要扫描完整个表,并返回结果。
- 字表查询结果不同
exists判断子查询的结果是不是存在,但查到什么结果,什么字段,并不关心;
in需要子查询查得的结果给主查询使用
2、用exists替代in
在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。
在这种情况下,使用exists(或not exists)通常将提高查询的效率。
3、用not exists替代not in:
在子查询中,not in子句将执行一个内部的排序和合并。
无论在哪种情况下,not in都是最低效的 (因为它对子查询中的表执行了一个全表遍历)。
为了避免使用not in,我们可以把它改写成外连接(Outer Joins)或not exists。
4、用表连接替换exists:
通常来说,采用表连接的方式比exists更有效率。
二、多表连接
1、外连接(left join/left outer join、right join/right outer join、full join/full outer join)
2、内连接(join/inner join)将那些带有null值的行去掉
3、交叉连接(cross join)笛卡尔积
三、数据库对象
1、表
2、视图
3、图表
数据库表之间的关系示意图。利用它可以编辑表与表之间的关系。
4、缺省值
当在表中创建列或插入数据时,对没有指定其具体值的列或列数据项赋予事先设定好的值。
5、规则
对数据库表中数据信息的限制。它限定的是表的列。
6、索引
索引就一种特殊的查询表,数据库的搜索引擎可以利用它加速对数据的检索。它很类似与现实生活中书的目录,不需要查询整本书内容就可以找到想要的数据。索引可以是唯一的,创建索引允许指定单个列或者是多个列。缺点是它减慢了数据录入的速度,同时也增加了数据库的尺寸大小。
按照存储方式分为:聚集索引与非聚集索引
按照维护与管理索引角度分为:唯一索引、复合索引和系统自动创建的索引
7、触发器
是一种特殊的存储过程,主要是通过事件来触发而被执行的。它可以强化约束,来维护数据的完整性和一致性,可以跟踪数据库内的操作从而不允许未经许可的更新和变化。可以联级运算。如,某表上的触发器上包含对另一个表的数据操作,而该操作又会导致该表触发器被触发。
触发器的分类:DML触发器、DDL触发器、登录触发器
8、存储过程
存储过程是一个预编译的SQL语句,优点是允许模块化的设计,就是说只需创建一次,以后在该程序中就可以调用多次。如果某次操作需要执行多次SQL,使用存储过程比单纯SQL语句执行要快。可以用一个命令对象来调用存储过程。
9、用户
所谓用户就是有权限访问数据库的人。

四、其他
1、事务和锁
事务就是被绑定在一起作为一个逻辑工作单元的SQL语句分组,如果任何一个语句操作失败那么整个操作就被失败,以后操作就会回滚到操作前状态,或者是上有个节点。为了确保要么执行,要么不执行,就可以使用事务。要将有组语句作为事务考虑,就需要通过ACID测试,即原子性,一致性,隔离性和持久性。
锁:在所以的DBMS中,锁是实现事务的关键,锁可以保证事务的完整性和并发性。与现实生活中锁一样,它可以使某些数据的拥有者,在某段时间内不能使用某些数据或数据结构。当然锁还分级别的。

浙公网安备 33010602011771号