Skip to main content

Тун хэрэгцээтэй Oracle query-үүд

Query-г зөв, оновчтой бичих нь программын гүйцэтгэлийн амин сүнс болохоос гадна код бичих, тест хийх, бааг илрүүлэх үеийн ажлыг ихээхэн хөнгөвчилдөг. Энэ постоороо түгээмэл тулгардаг асуудлуудыг энгийнээр шийдэх хэдэн query-г  хүргэе. Зарим нь өдөр тутмын хар бор кодчилолд төдийлөн хэрэглэгддэгүй ч байж магадгүй. Гэхдээ харж байгаагүй юм хэрэг болдоггүй гэдэг шиг мэдэж аваад, хэрэглээд сурчихвал юм болгонд л хэрэг болохыг үгүйсгэхгүй.

1. DUAL table

    Oracle дээр 1 мөр, 1 баганатай DUAL table анхнаасаа үүссэн байдаг ба ямар нэгэн илэрхийллийн үр дүнг select хийхэд ашиглавал тохиромжтой. Ж: 
 select SYSDATE from dual -- Системийн огоог харах  
 select 18 * 10 from dual -- Илэрхийллийн үр дүнг харах  

2. Сарын эхний өдрийг харах

 SELECT TRUNC (SYSDATE, 'MONTH') "First day of current month" FROM DUAL  

3. Сарын сүүлийн өдрийг харах

 SELECT TRUNC (LAST_DAY (SYSDATE)) "Last day of current month" FROM DUAL  

4. Сарын өдрийн тоог харах

 SELECT CAST (TO_CHAR (LAST_DAY (SYSDATE), 'dd') AS INT) number_of_days FROM DUAL  

5. Хоёр огнооны хоорон дахь өдрийн тоо

 SELECT TRUNC(sysdate) - TRUNC(p.created_datetime) FROM Person p  

6. Өгөгдсөн нэртэй тэйбл байгаа байгаа эсэхийг шалгах

 SELECT table_name FROM user_tables WHERE table_name = 'TABLE_NAME'  

7. Тэйблийн багануудыг харах, өгөгдсөн нэртэй багана тухайн тэйблд байгаа эсэхийг шалгах

 select * from user_tab_cols where table_name = 'PERSON'  
 select * from user_tab_cols where table_name = 'PERSON' and column_name = 'PERSON_ID'  

8. Table, view-н бүтцийг харах

 SELECT DBMS_METADATA.get_ddl ('TABLE', 'PERSON', 'SCHEMA_NAME') FROM DUAL  
 SELECT DBMS_METADATA.get_ddl ('VIEW', 'VW_PERSON', 'SCHEMA_NAME') FROM DUAL  
Эхний параметр нь тэйбл бол TABLE, view бол VIEW утга авна. Toad юм уу SQL Developer дээр ажиллуулж байгаа бол select-н үр дүнгээр гарч ирэх нүдэнд double click хийж мэдээллийг нь харна.

9. Ажиллаж буй user/schema-г харах

 SELECT SYS_CONTEXT ('userenv', 'current_schema') FROM DUAL  

10. Баазын хувилбарын мэдээлэл харах

 SELECT * FROM v$version  

11. User бүрийн table space, temporary table space, profile-н мэдээлэл харах

 SELECT username, profile, default_tablespace, temporary_tablespace FROM dba_users  

12. Баазын нийт хэмжээг харах

 SELECT SUM (bytes) / 1024 / 1024 / 1024 AS GB FROM dba_data_files  

13. Тухайн user/schema-н хэмжээг харах

 SELECT SUM (bytes / 1024 / 1024) "size" FROM dba_segments WHERE owner = '&owner'  

14. Бааз руу яг одоо холбогдсон байгаа клиентүүдийн жагсаалт харах

 SELECT osuser, username, machine, program FROM v$session ORDER BY osuser  

15. Тооны англи нэрийг харах (үг болгох)

 SELECT TO_CHAR (TO_DATE (198804, 'j'), 'jsp') FROM DUAL  

16. Package, procedure, function г.м-н source code-оос текст хайх

 SELECT * FROM dba_source WHERE UPPER (text) LIKE '%WRITELOG%' AND owner = 'USER_NAME'  

17. Table, view, index г.м бүх объектын жагсаалт харах.

 select object_name, object_type from user_objects  

18. Санамсаргүйгээр (random) өгөгдөл үүсгэх.

Тест хийх явцад мянга мянган мөр үүсгэх шаардлага багагүй тохиолддог учраас үүнийг хэрэглээд суричхвал мөн ч их цаг хэмнэнэ.
 SELECT LEVEL empl_id,  
       MOD (ROWNUM, 50000) deptartment_id,  
       TRUNC (DBMS_RANDOM.VALUE (1000, 500000), 2) salary,  
       DECODE (ROUND (DBMS_RANDOM.VALUE (1, 2)), 1, 'M', 2, 'F') gender,  
       TO_DATE (  
          ROUND (DBMS_RANDOM.VALUE (1, 28))  
        || '-'  
        || ROUND (DBMS_RANDOM.VALUE (1, 12))  
        || '-'  
        || ROUND (DBMS_RANDOM.VALUE (1900, 2010)),  
        'DD-MM-YYYY')  
        BIRTH_DAY,  
       DBMS_RANDOM.STRING ('x', DBMS_RANDOM.VALUE (20, 50)) DESCRIPTION  
    FROM DUAL  
 CONNECT BY LEVEL < 10000  

Comments

Popular posts from this blog

4 бэрх

Нүүдэлчдийн эртний тоглоомуудын нэг болох шагайгаар тоглож үзээгүй хүн бараг байхгүй биз. Маниусыг ухаан орж байх үед зах зээл хэмээгч рүү дөнгөж орж байсан болоод ч тэр үү, шагайнаас өөр тоглочихмоор юм ч бараг байдаггүй байсан. Морь уралдуулах, шагай таалцах, шагай шүүрэх, дөрвөн бэрх орхих гээд л мөн ч сайхан тоглоомууд байж билээ. Гэснээс зарим хоолны газрууд ширээн дээрээ 4 шагай, мэргэлэх хүснэгтийн хамт тавьсан харагддаг. Хүснэгт нь 24 боломжтой байдаг ба заримдаа тохирох хувилбар олдохгүй, самгардах үе бишгүй тохиолддог. Ингэхэд 4 шагайг хаяхад нийтдээ хэдэн янзаар буух вэ? Алгебрын аргаар амархан тооцоолчхож болно л доо. Гэхдээ илүү хялбар аргаар, ө.х random буюу санамсаргүйгээр тоо сонгох аргаар бодъё. 1, 2, 3, 4 нь харгалзан морь, тэмээ, хонь, ямаа байг. Тэгвэл нэлээн хэдэн удаа (бүх боломжоор буухаар) давтаж санамсаргүйгээр 4 тоо сонгоод, уг 4 тоо өмнө сонгогдсон эсэхийг шалгаад, сонгогдоогүй бол боломжийн тоогоо нэмэгдүүлээд явна гэсэн үг. Нийт боломж (давхардсан тоогоо...

Regular expression-ий түгээмэл хэрэглээ

    Regular expression нь string буюу текстээс тодорхой бүтэц бүхий хэсгийг хайж олох зорилготой загвар (pattern) юм. Regular expression-г regex гэж товчилдог. Бүх программчлалын хэл дээр regex-тэй ажилладаг класс, функцүүд байдаг ба тухайн хэлний онцлогоос хамаарч класс, функц нь элдэв янзаар бичигддэг боловч regex нь яг адилхан, нэг стандартын дагуу бичигдэнэ. Өдөр тутмын амьдралд түгээмэл тохиолддог зарим асуудал(бодлого)-ыг жава дээр regex ашиглаж хэрхэн хялбар шийдэж болохыг жишээгээр тайлбарлая.     Жава дээр Pattern , Matcher класуудын тусламжтайгаар хэрэгжүүлнэ. 1. Регистрийн дугаар шалгах (Эхний хоёр орон кирил том үсэг, араас нь 8 оронтой тоо) Pattern ptrn = Pattern.compile("([А-Я|Ө|Ү]{2})(\\d{8})"); Matcher matcher1 = ptrn.matcher("БИ88042515"); Matcher matcher2 = ptrn.matcher("AB88042515"); System.out.println(String.format("1: %s; 2: %s", matcher1.matches(), matcher2.matches())); Хариу: 1: true; 2: false Pattern...

Текстээс хайх Aho-Corasick алгоритм

Alfred V. Aho болон Margaret J. Corasick нарын эрдэмтэд 1975 онд зохиосон. Текстэн өгөгдлөөс олон дэд текстийг нэгэн зэрэг буюу параллель хайж олоход зорилго нь оршдог. Бичих, уншихад хялбар болгох үүднээс текстэн өгөгдлөө текст , хайж олох текстүүдээ үг  гээд нэрлэчихье (Англиар харгалзан  text , dictionary эсвэл text string , pattern string гэж нэрлэдэг). Үг бүрээр давтаж, давталтын алхам бүрд текстийг эхнээс нь дуустал нь давтах байдлаар бол хэн ч олчихно л доо. Харамсалтай нь маш өндөр өртөгтэй, текст уртсаж, үг олшрох тусам тэсвэрлэхийн аргагүй удаан ажиллах учраас тэгж программ бичиж, хүнд хэрэглүүлнэ гэж бол ёстой гонж. Бодит амьдралд ийм төрлийн ямар жишээнүүд байдаг вэ? Текстэн дэх товчилсон үг болон нэр томьёо бүрд тайлбар оруулах Утасны жагсаалт өгөгдсөн бол эздийг нь харгалзуулах Гений дарааллаас тодорхой бүтэцтэй генүүдийг илрүүлэх г.м бичээд байвал дуусашгүй их юм бий. Тэгээд яг яаж вэ?     Гол санаа нь ижил эхлэлтэй үгнүүдийн...