ตัวอย่างการใช้ Regular Expressions ใน REGEXP_REPLACE ของ Oracle  สร้างคำถาม

 6,731 view  หมวดหมู่ : สำหรับโปรแกรมเมอร์  วันที่สร้าง : 18/01/2017

ตัวอย่างการใช้ Regular Expressions ใน REGEXP_REPLACE ของ Oracle

Regular Expressions เป็น standard ในการเช็คเงื่อนไขโดยการกำหนด pattern แทน
การเช็คเงื่อนไขแบบเดิมๆ เช่นคำสั่ง IF THEN ELSE ต่างๆ
ก่อนอื่นแนะนำการใช้ Regular Expressions เบื้องต้นก่อนนะครับ เช่น
** underscore(_) ไม่นับเป็น อักขระพิเศษ
. ทุกตัวอักษร+อักขระพิเศษ (ยกเว้นการขึ้นบรรทัดใหม่)
ทดสอบด้วย PL REGEXP_REPLACE
SELECT REGEXP_REPLACE ('XXTE_ST1X23_|', '.', 'Y') FROM dual;
ผลที่ได้คือ : YYYYYYYYYYYYY

\w ทุกตัวอักษร ยกเว้นอักขระพิเศษ
ทดสอบด้วย PL REGEXP_REPLACE
SELECT REGEXP_REPLACE ('XXTE_ST1X23_|', '\w', 'Y') FROM dual;
ผลที่ได้คือ : YYYYYYYYYYYY|

\W เฉพาะอักขระพิเศษ
ทดสอบด้วย PL REGEXP_REPLACE
SELECT REGEXP_REPLACE ('XXTE_ST1X23_|', '\W', 'Y') FROM dual;
ผลที่ได้คือ : XXTE_ST1X23_Y

\d ตัวเลขทุกตัว
ทดสอบด้วย PL REGEXP_REPLACE
SELECT REGEXP_REPLACE ('XTE_ST1X23_|', '\d', 'Y') FROM dual;
ผลที่ได้คือ : XTE_STYXYY_|

\D ที่ไม่ใช่ตัวเลข
ทดสอบด้วย PL REGEXP_REPLACE
SELECT REGEXP_REPLACE ('XTE_ST1X23_|', '\D', 'Y') FROM dual;
ผลที่ได้คือ : YYYYYY1Y23YY

\s whitespace(tab, space, line break)
ทดสอบด้วย PL REGEXP_REPLACE
SELECT REGEXP_REPLACE ('XT E_ST1X2 3_|', '\s', 'Y') FROM dual;
ผลที่ได้คือ : XTYYE_ST1X2Y3_|

\S ทุกตัวอักษร +อักขระพิเศษ ยกเว้น whitespace
ทดสอบด้วย PL REGEXP_REPLACE
SELECT REGEXP_REPLACE ('XT E_ST1X2 3_|', '\S', 'Y') FROM dual;
ผลที่ได้คือ : YY YYYYYYY YYY

[abc]เฉพาะตัวอักษรที่กำหนด อักขระพิเศษ ก็ได้นะ case sensitive
ทดสอบด้วย PL REGEXP_REPLACE
SELECT REGEXP_REPLACE ('XT E_ST1X2 3_|', '[eST|]', 'Y') FROM dual;
ผลที่ได้คือ : XY E_YY1X2 3_Y

[^abc] ทุกตัวที่ไม่ใช่ที่กำหนด
ทดสอบด้วย PL REGEXP_REPLACE
SELECT REGEXP_REPLACE ('XT E_ST1X2 3_|', '[^eST|]', 'Y') FROM dual;
ผลที่ได้คือ : YTYYYYSTYYYYYY|

[a-f] ทุกตัวที่อยู่ระหว่าง a ถึง f
ทดสอบด้วย PL REGEXP_REPLACE
SELECT REGEXP_REPLACE ('XT E_ST1X2 3_|', '[S-X]', 'Y') FROM dual;
ผลที่ได้คือ : YY EYYY1Y2 3YY

^ เริ่มต้น line
$ สิ้นสุด line
\A เริ่มต้นคำ
\z สิ้นสุดคำ
(…) capture group
\1 reference group #1
(a b)
a* ไม่มี a หรือมีก็ได้
a+ a อย่างน้อย 1 ตัว
a? ไม่มี a หรือมี a ได้แค่ 1ตัว
a{5} มี a 5 ตัว
a{2,5} มี a ได้ 2 ถึง 5 ตัว


ถ้าชอบบทความนี้ กด Like เลย :ตัวอย่างการใช้ Regular Expressions ใน REGEXP_REPLACE ของ Oracle
TAGS : PLSQL   Programming   Regular Expressions  
 6,731 view  หมวดหมู่ : สำหรับโปรแกรมเมอร์  วันที่สร้าง : 18/01/2017



SOA,Java,XSLT

 ร่วมแสดงความคิดเห็นได้ที่นี่




× แจ้งเตือน! เราสนับสนุนทุกความคิดเห็น ที่ ใช้ถ้อยคำสุภาพ ไม่ละเมิดผู้อื่น ไม่ก่อให้เกิดความขัดแย้ง

เนื้อหาที่เกี่ยวช้อง

  ตัวอย่าง javascript สลับ ซ่อน แล้ว แสดง โดยใช้ div style value ถามเมื่อ (2013-08-28)   3,890 views  (ดูล่าสุดเมื่อ 4 นาที)

  hashmap กับ hashing เหมือนกันป่ะคะ ถามเมื่อ (2015-09-25)   2,243 views  (ดูล่าสุดเมื่อ 22 นาที)

  วิธีใช้งาน Oracle HINT ถามเมื่อ (2016-12-14)   3,426 views  (ดูล่าสุดเมื่อ 26 นาที)

  PRAGMA AUTONOMOUS TRANSACTION ใน PLSQL ใช้ทำอะไร ถามเมื่อ (2017-03-03)   4,381 views  (ดูล่าสุดเมื่อ 27 นาที)

  การจัดการ Transaction บน Hibernate ถามเมื่อ (2012-05-16)   3,370 views  (ดูล่าสุดเมื่อ 34 นาที)

  Oracle Create Select สร้าง Table ใหม่ตามโครงสร้าง Table เดิม ถามเมื่อ (2013-07-23)   2,763 views  (ดูล่าสุดเมื่อ 34 นาที)

  Span HTML อยากรู้วิธีเปลี่ยน ค่า Attribute ของ Span ด้วย Java Script อยาก set Style ใหม่น่ะครับ ถามเมื่อ (2011-07-26)   2,958 views  (ดูล่าสุดเมื่อ 35 นาที)

  ขอแหล่งความรู้ Java ครับ เว็บไซต์ หรือ blog ก็ได้ ถามเมื่อ (2013-02-22)   3,005 views  (ดูล่าสุดเมื่อ 62 นาที)

  Error 500 วิธีแก้ Error 500 in servlet is an Internal Server Error ถามเมื่อ (2016-08-31)   3,378 views  (ดูล่าสุดเมื่อ 66 นาที)

  php ย่อมาจาก หรือ มีคำแปลว่าอะไรครับ ถามเมื่อ (2013-04-23)   2,845 views  (ดูล่าสุดเมื่อ 66 นาที)


 

บ้านเดียวกันดอทคอม เว็บถามตอบ รวมทุกเรื่องที่คุณอยากรู้ ให้ความรู้ ความบันเทิง มีสาระ
www.ban1gun.com