zoukankan      html  css  js  c++  java
  • SQL Cookbook—插入、更新与删除

    涉及到的问题
    –1、从一个表向另外的表中复制行
    –2、复制表定义(包含表记录)
    –3、一次向多个表中插入记录
    –4、
    –5、当相应行存在时更新
    –6、用其他表中的值更新
    –7、删除违反参照完整性的记录

                                                       
    –1、从一个表向另外的表中复制行
    insert into dept_test (deptno, dname, loc) select deptno, dname, loc from dept where deptno=10

    –2、复制表定义(包含表记录)
    create table dept_test as select deptno, dname, loc from dept where deptno=10

    –3、一次向多个表中插入记录
    问题描述
    有时需要将一个表中的数据按照一定的条件分别一次性插入到多个表中,怎样实现?
    insert all
    when loc in (upper('new york', upper('boston'))) then
       into dept_test_1 (deptno, dname, loc) values (deptno, dname, loc)
    when loc=upper('chicago') then
       into dept_test_2 (deptno, dname, loc) values (deptno, dname, loc)
    else
       into dept_test_3 (deptno, dname, loc) values (deptno, dname, loc)
    select deptno, dname, loc from dept

    –4、
    insert into (select empno, ename, job from emp) values (1, 'zhangsan', 'java')

    –5、当相应行存在时更新
    方法一
    UPDATE emp
    SET sal=sal*1.20
    WHERE empno in (SELECT empno FROM emp_bonus)
    方法二
    UPDATE emp
    SET sal=sal*1.20
    WHERE exists (SELECT null FROM emp_bonus where emp.empno=emp_bonus.empno)

    –6、用其他表中的值更新
    UPDATE emp e
    SET (e.sla, e.comm)=(SELECT ns.sal, ns.sal/2
                                     FROM new_sal ns
                                     WHERE ns.deptno=e.deptno)
    WHERE EXISTS( SELECT NULL
                  FROM  new_sal ns
                  WHERE ns.deptno=e.deptno)

    –7、删除违反参照完整性的记录
    例如,某些员工被分配到了一个不存在的部门中,要将这些员工删除。
    方法一(推荐)
    delete from emp where not exists (select * from dept where dept.deptno=emp.deptno)
    方法二
    delete from emp where emp.deptno not in (select deptno from dept where dept.deptno is not null)

  • 相关阅读:
    EntityFramework之领域驱动设计实践
    Entity Framework 学习初级篇1EF基本概况(入门)
    整理一下Entity Framework的查询
    Unity(六):使用场景Ⅲ:用于依赖注入(上)
    比较NHibernate和Entity Framework
    contentclass对应的一些值
    IE8访问架设在Windows Server 2008(R2)的SharePoint Server 2007是验证框问题
    创建一个图文并茂的调查
    SharePoint回环检查(Loopback Check)相关问题
    Something you need to know about Content Deployment in SharePoint
  • 原文地址:https://www.cnblogs.com/linjiqin/p/3152583.html
Copyright © 2011-2022 走看看