重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
update dolar set spay=1.5*spay where sno in (select sno from employee where trunc(months_between(sysdate,sbirth)/12) 30)
创新互联公司作为成都网站建设公司,专注重庆网站建设公司、网站设计,有关企业网站设计方案、改版、费用等问题,行业涉及成都橡塑保温等多个领域,已为上千家企业服务,得到了客户的尊重与认可。
可能我这个年龄算的也不严谨,但你那个人家只告诉你年龄30岁,你不能自己先算出来是哪年哪月哪日
设定dept表deptno列为主键。
alter
table
dept
add
constraint
pk_deptno
primary
key
(deptno);
在emp表deptno列上建立外键引用dept表deptno,指定外键类型为级联删除。
alter
table
emp
add
constraint
fk_deptno
foreign
key
(deptno)
references
dept(deptno)
on
delete
cascade;
这样删除dept表
只需:delete
from
dept
where
city='shanghai';
就可以自动删除对应emp表内容。
与其说oracle如何update索引数据
还不如说如何提高更新的效率.
简单说来:
1、暂停索引,更新后恢复.避免在更新的过程中涉及到索引的重建.
2、批量更新,每更新一些记录后及时进行提交动作.避免大量占用回滚段和或临时表空间.
3、创建一临时的大的表空间用来应对这些更新动作.
如果update的是索引字段,就会涉及到索引的重建,暂停索引不会提高多少的速度,反而有可能降低update速度,
因为在更新是索引可以提高数据的查询速度,重建索引引起的速度降低影响不大。
oracle优化修改参数最多也只能把性能提高15%,大部分都是sql语句的优化!
修改关联数据的方法如下。
有以下两张表:
根据test2表中的id和test1表中的id关联,修改test1表中name字段,语句如下:
update test1 a set a.name=(select b.name from test2 b where a.id=b.id) where a.id in (select id from test2);
更新后,test1表中结果:
update更新表不能用重命名
update bill set goodsname='汽车配件',torvover='5000'
where billid=6
and exists (select suppliername from supplier s where s.supplierid=bill.supplierid and s.suppliername='阿里巴巴')
不管是update还是merge每次都是只能修改一站表,还没听说一次修改两张表的。
如果分别修改那就比较简单了(先确定B列是否唯一,如果不唯一,那么可能存在修改扩大的问题,所以可能还要修改语句),update a set a.d=2 where a.b=(select b from E where h=1)(这是a表的,b表的改法更容易)
如果一起修改,那么可能只能临时修改,也就是select的时候修改一下,这个一般没什么用。