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

เลือกข้อความหลังจากทับสุดท้ายใน MySQL?


คุณต้องใช้ฟังก์ชัน substring_index() จาก MySQL เพื่อเลือกข้อความ

ไวยากรณ์มีดังนี้

SELECT substring_index(yourColumnName,'/',-1) AS anyAliasName FROM yourTableName;

เพื่อให้เข้าใจแนวคิดข้างต้น ให้เราสร้างตาราง แบบสอบถามเพื่อสร้างตารางมีดังนี้

mysql> สร้างตาราง selectTextAfterLastSlashDemo -> ( -> UserId int ไม่ใช่ NULL AUTO_INCREMENT PRIMARY KEY, -> UserPathDirectory varchar(200) -> ); เคียวรีตกลง 0 แถวได้รับผลกระทบ (0.54 วินาที)

แทรกบางระเบียนในตารางโดยใช้คำสั่ง insert

แบบสอบถามมีดังนี้

mysql> แทรกลงใน selectTextAfterLastSlashDemo(UserPathDirectory)values('C:/MyFolder1/MyEntityFramework');Query OK, 1 แถวได้รับผลกระทบ (0.18 วินาที)mysql> แทรกลงใน selectTextAfterLastSlashDemo(UserPathDirectory)values('D:/MyDemo'Fram);แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.14 วินาที)mysql> แทรกลงใน selectTextAfterLastSlashDemo(UserPathDirectory)values('E:/Java/MyRootFolder/Source/AllHibernateDemo'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.14 วินาที) mysql> แทรกลงใน selectTextAfterLastSlashDemo (UserPathDirectory) ค่า ('C:/ProgramFiles/MySQL/Server 8.0'); แบบสอบถามตกลง 1 แถวได้รับผลกระทบ (0.20 วินาที) mysql> แทรกลงใน selectTextAfterLastSlashDemo (UserPathDirectory)values ​​('C:/John/Folder1/Folder2'); แบบสอบถามตกลง ได้รับผลกระทบ 1 แถว (0.10 วินาที)

แสดงระเบียนทั้งหมดจากตารางโดยใช้คำสั่ง select

แบบสอบถามมีดังนี้

mysql> เลือก *จาก selectTextAfterLastSlashDemo;

ต่อไปนี้เป็นผลลัพธ์ที่แสดงเส้นทางในคอลัมน์

<ก่อนหน้า>+---------+----------------------------- ---------+| รหัสผู้ใช้ | UserPathDirectory |+---------+-------------------------------------- --------+| 1 | C:/MyFolder1/MyEntityFramework || 2 | D:/MySpringFrameworkDemo || 3 | E:/Java/MyRootFolder/Source/AllHibernateDemo || 4 | C:/Program Files/MySQL/Server 8.0 || 5 | C:/John/Folder1/Folder2 |+---------+------------------------------------- ---------------+5 แถวในชุด (0.00 วินาที)

นี่คือแบบสอบถามเพื่อรับข้อความหลังเครื่องหมายทับสุดท้าย

mysql> เลือก substring_index(UserPathDirectory,'/',-1) เป็น TextAfterLastSlash จากselectTextAfterLastSlashDemo;

ต่อไปนี้เป็นผลลัพธ์ที่แสดงข้อความหลังเครื่องหมายทับสุดท้าย

<ก่อนหน้า>+-----------------------+| TextAfterLastSlash |+----------------------+| MyEntityFramework || MySpringFrameworkการสาธิต || AllHibernateDemo || เซิร์ฟเวอร์ 8.0 || Folder2 |+-----------------------+5 แถวในชุด (0.00 วินาที)