Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> MySQL

เราจะแบ่งที่อยู่ IP ออกเป็นสี่ octets ตามลำดับโดยใช้ฟังก์ชัน MySQL SUBSTRING_INDEX () ได้อย่างไร


สมมติว่าเรามีตารางชื่อ 'ipaddress' ซึ่งมีที่อยู่ IP เป็นค่าในคอลัมน์ 'IP' ดังนี้ -

mysql> Select * from ipaddress;
+-----------------+
| ip              |
+-----------------+
| 192.128.0.5     |
| 255.255.255.255 |
| 192.0.255.255   |
| 192.0.1.5       |
+-----------------+
4 rows in set (0.10 sec)

ด้วยความช่วยเหลือของฟังก์ชัน SUBSTRING_INDEX() ในแบบสอบถามต่อไปนี้ เราสามารถแบ่งที่อยู่ IP ออกเป็นสี่ออคเต็ต -

mysql> Select IP, SUBSTRING_INDEX(ip,'.',1)AS '1st Part',
    -> SUBSTRING_INDEX(SUBSTRING_INDEX(ip,'.',2),'.',-1)AS '2nd Part',
    -> SUBSTRING_INDEX(SUBSTRING_INDEX(ip,'.',-2),'.',1)AS '3rd Part',
    -> SUBSTRING_INDEX(ip,'.',-1)AS '4th Part' from ipaddress;
+-----------------+----------+----------+----------+----------+
| IP              | 1st Part | 2nd Part | 3rd Part | 4th Part |
+-----------------+----------+----------+----------+----------+
| 192.128.0.5     | 192      | 128      | 0        | 5        |
| 255.255.255.255 | 255      | 255      | 255      | 255      |
| 192.0.255.255   | 192      | 0        | 255      | 255      |
| 192.0.1.5       | 192      | 0        | 1        | 5        |
+-----------------+----------+----------+----------+----------+
4 rows in set (0.05 sec)