• Oracle一对多


    -- 一对多 (订单order,订单明细orderDetail)
    -- 主从表
    -- 订单表
    create table t_order (
       order_id number primary key,
       today date,
       desk_num varchar2(10)
    );
    insert into t_order(order_id,today,desk_num)
    values(1,to_date('2018-03-12','yyyy-MM-dd'),'A05');
    
    insert into t_order(order_id,today,desk_num)
    values(2,to_date('2018-03-12','yyyy-MM-dd'),'B04');
    
    insert into t_order(order_id,today,desk_num)
    values(3,to_date('2018-03-11','yyyy-MM-dd'),'B01');
    
    commit
    select * from t_order
    
    -- 订单明细表
    drop table t_order_detail
    create table t_order_detail(
       id number primary key,
       order_id number,  -- 关系
       food_name varchar2(20),-- 食品名字
       unit_name varchar2(20),-- 单位
       price number(6,2),  --单价
       nums number         --数量
    );
    
    insert into t_order_detail
    (id,order_id,food_name, unit_name, price,nums)
    values
    (1,1,'麻婆豆腐','',1.5,12);
    insert into t_order_detail
    (id,order_id,food_name, unit_name, price,nums)
    values
    (2,1,'东坡肉','',15,3);
    
    
    insert into t_order_detail
    (id,order_id,food_name, unit_name, price,nums)
    values
    (3,2,'麻婆豆腐','',1.5,5);
    insert into t_order_detail
    (id,order_id,food_name, unit_name, price,nums)
    values
    (4,2,'上海青','',6.5,2);
    insert into t_order_detail
    (id,order_id,food_name, unit_name, price,nums)
    values
    (5,2,'香干火锅肉','',16.5,2);
    commit
    
    select * from t_order
    select * from t_order_detail
    
    -- 今天赚了多少钱
    select to_char(sysdate,'yyyy-MM-dd') from dual
    -- 找出2张订单ID
    select order_id from t_order 
    where 
    to_char(today,'yyyy-MM-dd')=to_char(sysdate,'yyyy-MM-dd')
    
    select sum(price*nums) as 总收入 from t_order_detail
    where order_id in(
       select order_id from t_order 
       where 
       to_char(today,'yyyy-MM-dd')=to_char(sysdate,'yyyy-MM-dd')
    )
     
    --本质:内关联
    select * from t_order,t_order_detail
    where t_order.order_id=t_order_detail.order_id
    --左关联(左为主,右为辅)
    select * from t_order
    left join t_order_detail
    on
    t_order.order_id=t_order_detail.order_id

    -- 一对多 (订单order,订单明细orderDetail

    -- 主从表

    -- 订单表

    createtable t_order (

       order_id numberprimarykey,

       today date,

       desk_num varchar2(10)

    );

    insertinto t_order(order_id,today,desk_num)

    values(1,to_date('2018-03-12','yyyy-MM-dd'),'A05');

     

    insertinto t_order(order_id,today,desk_num)

    values(2,to_date('2018-03-12','yyyy-MM-dd'),'B04');

     

    insertinto t_order(order_id,today,desk_num)

    values(3,to_date('2018-03-11','yyyy-MM-dd'),'B01');

     

    commit

    select * from t_order

     

    -- 订单明细表

    droptable t_order_detail

    createtable t_order_detail(

       idnumberprimarykey,

       order_id number,  -- 关系

       food_name varchar2(20),-- 食品名字

       unit_name varchar2(20),-- 单位

       price number(6,2),  --单价

       nums number         --数量

    );

     

    insertinto t_order_detail

    (id,order_id,food_name, unit_name, price,nums)

    values

    (1,1,'麻婆豆腐','',1.5,12);

    insertinto t_order_detail

    (id,order_id,food_name, unit_name, price,nums)

    values

    (2,1,'东坡肉','',15,3);

     

     

    insertinto t_order_detail

    (id,order_id,food_name, unit_name, price,nums)

    values

    (3,2,'麻婆豆腐','',1.5,5);

    insertinto t_order_detail

    (id,order_id,food_name, unit_name, price,nums)

    values

    (4,2,'上海青','',6.5,2);

    insertinto t_order_detail

    (id,order_id,food_name, unit_name, price,nums)

    values

    (5,2,'香干火锅肉','',16.5,2);

    commit

     

    select * from t_order

    select * from t_order_detail

     

    -- 今天赚了多少钱

    select to_char(sysdate,'yyyy-MM-dd') from dual

    -- 找出2张订单ID

    select order_id from t_order

    where

    to_char(today,'yyyy-MM-dd')=to_char(sysdate,'yyyy-MM-dd')

     

    selectsum(price*nums) as总收入 from t_order_detail

    where order_id in(

       select order_id from t_order

       where

       to_char(today,'yyyy-MM-dd')=to_char(sysdate,'yyyy-MM-dd')

    )

    --本质:内关联

    select * from t_order,t_order_detail

    where t_order.order_id=t_order_detail.order_id

    --左关联(左为主,右为辅)

    select * from t_order

    leftjoin t_order_detail

    on

    t_order.order_id=t_order_detail.order_id

  • 相关阅读:
    关于 JLRoutes
    关于Objection 框架或解耦合方案
    窥探 NSObject
    关于cocoa 运行时runtime
    关于 cocoapods 使用
    关于Xcode 遇到的 警告、错误 处理
    ios 中正则匹配 ,NSPredicate
    关于状态栏 上颜色配置 ios7.x 之后
    使用ios系统侧滑 7.x 之后
    常用的shell脚本
  • 原文地址:https://www.cnblogs.com/yuchne/p/12920668.html
Copyright © 2020-2023  润新知