1. 视图
视图是一个虚拟表,它的本质是根据SQL语句获取动态的数据集,并为其命名,用户使用时只需使用【名称】即可获取结果集,可以将该结果集当做表来使用。
使用视图我们可以把查询过程中的临时表摘出来,用视图去实现,这样以后再想操作该临时表的数据时就无需重写复杂的sql了,直接去视图中查找即可,
但视图有明显地效率问题,并且视图是存放在数据库中的,如果我们程序中使用的sql过分依赖数据库中的视图,即强耦合,那就意味着扩展sql极为不便,
因此不推荐使用. 而且工作中一般不方便,因为是虚拟表 不方便共用,如果需要修改,可能设计到与DBA的沟通,很麻烦
1 --使用视图
2 select .. fromv13 select asd fromv14 --某个查询语句设置别名,日后方便使用
5
6 -创建7 create view 视图名称 asSQL8
9 PS: 虚拟的,临时表 无法插入操作10
11 -修改12 alter view 视图名称 asSQL13
14 -删除15 drop view 视图名称;
2. 触发器
定制用户对表进行【增、删、改】操作时前后的行为,注意:没有查询
工作中一般也很少用到,因为自己在代码中就能设计操作前后的行为
insert intotb (....)
delimiter// --修改结束标记
create trigger t1 BEFORE INSERT on student for EACH ROW --创建insert操作前的触发器
BEGIN --触发器具体内容
INSERT into teacher(tname) values(NEW.sname);INSERT into teacher(tname) values(NEW.sname);INSERT into teacher(tname) values(NEW.sname);INSERT into teacher(tname) values(NEW.sname);END //delimiter ;--恢复默认的语句结束标记
------------------------------------------------
insert into student(gender,class_id,sname) values('女',1,'涛'),('女',1,'根');--NEW,代指新数据 可以在触发器中点语法使用--OLD,代指老数据 删除的那一行记录被OLD引用
3.函数
因为在sql语句执行中调用函数会比较耗时,而且对索引的那一列使用了函数,则无法命中索引了。
所以工作中对响应速度要求高,一般不会不使用函数处理结果集。而是在架构级别或者程序级别处理结果集。
内置的函数很多,详情参看官方文档