Oracle小知识汇总

输入参数

carid in (&carids)

输入日期范围

trunc(e.startdate) between date '&datefrom' and date '&dateto''

and中需要带选择时

and (o.orgid in (&orgids) or o.parentorgid in (&orgids))

创建数据库唯一的索引

create unique index 索引名 on 表名 (列名);
create unique index sname on S(sname)

删除唯一性约束

ALTER TABLE table_name DROP CONSTRAINT constraint_name;
alter table j drop constraint jname

创建检查约束条件(check)

查询总个数

select count(1) from p;

分类查询个数

select pno,count(*) from spj group by spj.pno;

查询零件名以“螺”字开头的零件信息

select * from p where pname like '螺%';

查询平均数

select avg(weight) from p;

创建视图

create or replace view spj_view
as 
select s.sname, p.pname, j.jname, p.color, j.city, spj.qty from s,p,j,spj
where spj.sno=s.sno and spj.pno=p.pno and spj.jno=j.jno;

创建存储过程

create or replace procedure pro_s(no s.sno%type,name s.sname%type,city s.city%type)
as
       cou number;
begin
   select count(*) into cou from s where no = s.sno;
   if cou=0 then
      insert into s values(no,name,city);
      dbms_output.put_line('增加成功');
   else
      dbms_output.put_line('增加失败');
   end if;
end;
存储过程调用
begin
PRO_S('S11','精益4','天津');
end;
begin
  PRO_S('S13','为民2','上海');
end;

外连接

在等值连接的基础上加上被连接表的不匹配数据。

  • 左连接(以左边的数据为基准)
    (1)left joinleft outer join
    (2)条件a=b(+),以a表数据为基准。
  • 右连接(以右边的数据为基准)
    (1)right joinright outer join
    (2)条件a(+)=b,以b表为基准。
  • 全外连接
    在等值连接的基础上将左表和右表的未匹配数据都加上。
    (1)full outer join或者full join
    等价写法:对同一张表先做左连接,然后右连接。

内连接(等值连接)

选出两表中互相匹配的记录。

  • 直接等式
SELECT * 
FROM TESTA,TESTB
WHERE TEST A.A=TESTB.A
  • 使用inner join
SELECT * 
FROM TEST A  inner join TEST B
on TEST A.A=TEST B.A
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 50个常用的sql语句Student(S#,Sname,Sage,Ssex) 学生表Course(C#,Cname...
    哈哈海阅读 4,979评论 0 7
  • 花了3天时间学习MySql,考了个二级MySql 书籍参考:高等教育出版社《全国计算机等级考试二级教程-MySQL...
    如果仲有听日阅读 5,071评论 4 4
  • 笔记: 一、聚合函数:计数 最大值 最小值 平均数 求和 1.计数 COUNT() 忽略NULL值 方式1:COU...
    凤之鸠阅读 10,752评论 0 1
  • 纵身处陕西西北边 有一念去远方 纵生活琐碎繁杂 有一执要写诗 我们不谈茶饭 只说诗和远方 可否? (一枚大学生,被...
    雨中草zl阅读 1,222评论 0 0
  • 08年相识,09年底步入婚姻,至今磕磕绊绊也已有近十年了。说说这些年他给我的影响吧。 首先是信念。记得那时我们遇到...
    荔儿阅读 1,352评论 0 0