Insert ¹®°ü·ÃÇÏ¿© SQLÁú¹®ÇÕ´Ï´Ù.

   Á¶È¸ 3424   Ãßõ 0    

 오라클에서


A 라는 회원테이블과 B라는 쿠폰테이블이 있습니다.


모든회원에게 쿠폰을 줄려고합니다

A라는 회원테이블의 모든 id를 B라는쿠폰테이블에 insert 해야하는데

건수가 너무많습니다.



insert를 어떻게돌려야할까요 ??

박지훈
ªÀº±Û Àϼö·Ï ½ÅÁßÇÏ°Ô.
s±èÁ¾È­z 2017-04
±âº»Àº insert select ÀÔ´Ï´Ù.

A Å×ÀÌºí µ¥ÀÌÅÍ°¡ º°µµÀÇ ÆÄÀÏ¿¡ ÀúÀåµÇ¾î ÀÖ´Ù¸é bulk insert µµ ±¦ÂúÀº ¹æ¹ýÀ̱ä ÇÕ´Ï´Ù.
     
idÄ÷³°ª¸¸µû·Î³ÖÀ»¼öÀÕ³ª¿ä? °¨»çÇÕ´Ï´Ù. bulk insert ã¾Æº¸°Ù½À´Ï´Ù.
Áú¹®ÀÇ ³»¿ëÀÌ ¸íÈ®ÇÏÁö ¾Ê±º¿ä.

1. AÀÇ id¸¦ BÅ×ÀÌºí¿¡ insert ÇÏ´Â SQL¹®ÀÌ ¹«¾ùÀÎÁö¸¦ ¹°¾îº»°Í Àΰ¡¿ä?

2. ¾Æ´Ï¸é 1. ÀÇ ÀÛ¾÷À» Çϴµ¥ °É¸®´Â ½Ã°£À» ÁÙÀÏ ¹æ¹ýÀÌ ÀÖ´ÂÁö¸¦ Áú¹®ÇÑ°Í ÀÎÁö¿ä?
     
ÀüÀÚ 1¹øÀÌ ¸Â½À´Ï´Ù .  insert ÇÒ¼öÀÖ´Â SQL¹®ÀÌÀÖÀ»±î¿ä
          
¼­ºêÄõ¸®¸¦ ¾²¸é µË´Ï´Ù.(SQL¹®Àå ¾È¿¡ ¶Ç ´Ù¸¥ SQL¹®ÀåÀÌ µé¾î ÀÖ´Â °æ¿ì¸¦ ¼­ºêÄõ¸® ¶ó°í ºÎ¸¨´Ï´Ù.)

´ëÃæ ÀÌ·±½ÄÀÔ´Ï´Ù.
INSERT INTO B (XXX) VALUES (SELECT id FROM A);
               
SELECT ID FROM A ·Î ÇÏ¸é      ¿©·¯°³ÀÇ ID °¡ ³ª¿À´Âµ¥    INSERT INTO B (XXX) VALUES (SELECT id FROM A); ÀÌ·¸°Ô¸¸Çصµ ¿©·¯°³°¡ Àμ­Æ®°¡ µÇ³ª¿ä???
                    
WHERE ¸¦ ÁÖ°í Á¶°ÇÀ» Àû´çÈ÷ ºÙ¿©¼­ ÇÑ°³¸¸ ³ª¿Àµµ·Ï ó¸®ÇÏ¸é µÉÅ×°í..

±×°É ¿©·ÁÁÙ µ¹¸®¸é µË´Ï´Ù.
auto commit Àΰ¡ Ç®°í µ¹¸®¸é
±Ý¹æ µé¾î°¡Áö ¾Ê³ª¿ä ?
     
auto commit °Ë»öÇÏ°Ú½À´Ï´Ù.
Àϱ¹ 2017-04
Insert into B (mb_code,  cp_cnt)
As select mb_code, 1
        from A;
Commit;

B=ÄíÆùÅ×À̺í
A=ȸ¿øÅ×À̺í

ÀÌ·±½ÄÀ¸·Î ÇÏ¸é µÇÁö ¾ÊÀ»±î¿ä..
     
ÇÑ°ÇÀ̾ƴ϶ó 10¸¸°ÇÀÌ»óÀÏ °æ¿ì°¡ ±Ã±ÝÇÕ´Ï´Ù ¤Ð¤Ð¤Ð¤Ð¤Ð¤Ð¤Ð
          
Àϱ¹ 2017-04
Rollback segment ÃæºÐÇϸé
10¸¸°Ç Á¤µµ´Â ¹®Á¦°¡ ¾ÈµÉ°Å °°½À´Ï´Ù¸¸....
¸¸¾à Äõ¸® ½ÇÇà½Ã°£ÀÌ ±æ¾îÁö¸é
Àû´çÇÑ ´ÜÀ§·Î ÂÉ°³¼­ ½ÇÇàÇÏ½Ã¸é µÉ°Å °°¾Æ¿ä..

INSERT INTO B (MB_CODE, CP_CNT)
AS  SELECT MB_CODE, 1
        FROM ( SELECT ROWNUM RM
                                , MBCODE
                                , MBNAME
                        FROM A
                  )
      WHERE RM BETWEEN 10001 AND 19999;
Commit;

BETWEEN °ªÀ¸·Î ÂÉ°³¸é µÉ°Å °°½À´Ï´Ù.
ÀÚµ¿À¸·Î ÂÉ°³¼­ insert ÇÏ·Á¸é
Cursor »ç¿ëÇÏ¸é µÇ±¸¿ä..
               
°¨»çÇÕ´Ï´Ù!
¿À¿À ÇØ°á‰Ñ½À´Ï´Ù °¨»çÇÕ´Ï´Ù


QnA
Á¦¸ñPage 5441/5688
2014-05   5000474   Á¤ÀºÁØ1
2015-12   1536353   ¹é¸Þ°¡
2020-11   2919   ½º¹«ÇÁ
2013-10   6450   ¸Æµµ³¯µå
2020-11   2698   ·¹ÆäÀÌ·¹
2004-11   6977   ±è±â¸¸
2007-08   5536   À̼ºÁØ
2007-08   5078   ±èÇö¿ì
2011-03   6250   ¹ÚÁØ¿ë
2007-08   5078   ·ùâÈÆ
2018-07   4157   ±è°Ç¿ì
01-30   1383   ÂøÇÏ°Ô»ìÀÚ2
2007-08   4923   ¹æÇõÁØ
2019-09   2831   ½Ãµµ´Ï
02-02   2570   ¿ì´çÅÁÅÁ
2004-12   6928   ÃÖ¿ø½Ä
2007-09   4795   Á¤µµ¿µ
2019-09   4423   ±è°Ç¿ì
2004-12   6788   ¹Ú¿ë
2007-09   5853   Ãֿ켺
2016-05   8797   AplPEC
2005-01   7038   Çѽ¼ö