Oracle ´´½¨×Ô¶¨ÒåµÄÁ÷Ë®ºÅ - Oracle / ¿ª·¢
Òª×ö¸ö·¢»õµ¥£¬ÓõĴ¥·¢Æ÷À´´´½¨×Ô¶¨ÒåÁ÷Ë®ºÅ£¬Èç¹û¹«Ë¾AÔÚ2010Äê5Ô·¢µÄµÚÒ»Õŵ¥£¬Ôòµ¥¾ÝºÅÊÇA-2010-05-1, µÚ10Õŵ¥µÄ»°ÊÇA-2010-05-10£¬Ã¿´Îн¨ÊÇÔÚ±¾Ô±¾µ¥Î»µÄ×î´óºÅÉϼÓ1.
ÎÒдµÄÊÇÕâÑù×ӵģ¬µ«ÓÐÎÊÌâ
SQL code:
create table OutgoingNotice (
OutgoingNoticeId NVARCHAR2(15) not null,
CompanyId CHAR(32) not null,
DateCreated Date,
constraint PK_OUTGOINGNOTICE primary key (OutgoingNoticeId)
);
create trigger Trigger_OGNotice_Insert before insert
on OutgoingNotice for each row
declare
newid nvarchar(15);
curMonthMaxId nvarchar(15);
begin
select og.OutgoingNoticeId into curMonthMaxId from OutgoingNotice og order by OutgoingNoticeId
where TO_CHAR(og.datecreated, 'YYYY-MM') = TO_CHAR(:new.datecreated, 'YYYY-MM') and og.CompanyId = :new.CompanyId and rownum = 1
if curMonthMaxId is null
then
newid = CONCAT(TO_CHAR(:new.datecreated, 'YYYY-MM'), '01')
else
newid = CONCAT(TO_CHAR(:new.datecreated, 'YYYY-MM'), TO_CHAR(TO_NUMBER(SUBSTR(curMonthMaxId, 6), '9999'), '9999'))
end if;
:new.OutgoingNoticeId = newid;
end;
ʲôÎÊÌ⣿
ÊÇ¡°±íÒѾ·¢Éú±ä»¯£¬´¥·¢Æ÷²»ÄܶÁÈ¡¡±ÎÊÌâÂð£¿
Â¥Ö÷ ÄãÌ«ÈÃÎÒʧÍûÁË£¬ºÃ¶à´íÎóŶ£¬
Ê×ÏÈÓï¾ä½áÊøÒªÓÃ";"½áÊø
Æä´Î£¬¸³ÖµÓï¾äδ&q
Ïà¹ØÎÊ´ð£º
ÎÒÓÐÒ»¸ö±í£¬½á¹¹ÊÇÕâÑù¡£
ת³ö µ¥Î» תÈ뵥λ ±ÊÊý ½ð¶î
date(Ö÷) outid(Ö÷) inid(Ö÷) num amt
2009 1 2 1 500 Ϊ 1 µ¥Î» ÔÚ2009Ä ......
¼ÙÉètable01 ÖÐÓÐ ÒÔÏÂ×ÊÁÏ
emp_no emp_name
------- ------------
0001 TOM
0002 JOHN
0003 MARY
³£Óõ绰
¶øÎÒÃÇÒªµÃµ½ÒÔϵÄOUTPUT (»òÊǸ÷ÖÖÆäËûµÄoutput)
0001,TOM
0002,JOHN
......
¿´µ½ÓÐÒ»¸öSUNµÄÔªÀÏ´ÓOracle¹«Ë¾´ÇÖ°£¬¶øÇÒÊÇJava´´Ê¼ÈË——´óÃû¶¦¶¦µÄJames Gosling£¬
ÐÄÖÐÏ൱ÊÜ´ò»÷£¡ºÜ±¯Í´£¡
OrableÕâÊÇÔõôÁË£¬ÄѵÀÕâ¾ÍÊÇËùνµÄÈںϣ¨Ö«½â£¬·Ö»¯£¬Ïûʧ£©Âð£¿
SUNµÄÒ»°ïÀÏÔ±¹¤¶ ......
--½¨Á¢Ò»¸ö°üÒÔ¶¨ÒåÒ»¸öÓαê
create or replace package PK_test
as
type cur_test is ref cursor;
end PK_test;
--½¨Á¢Ò»¸ö¹ý³Ì,ͨ¹ýÊäÈëJOBID£¬·µ»ØÒ»¸ö±í¼Ç¼£¨Óα꣩!
create or replace ......
SELECT * from (SELECT A.*, ROWNUM RN from (SELECT * from t_out_logon) A WHERE ROWNUM <= 30)WHERE RN >= 21
SELECT A.* from (SELECT t.*,rownum rn from t_out_logon t WHERE ROWNUM <= 30) A WHERE ......