如何使用 MySQL SOUNDEX() 函数和 LIKE 运算符从表中检索记录?


众所周知,SOUNDEX() 函数用于返回 SOUNDEX,一种用于索引按照英语发音读起来听起来一样的名字的音标算法,它是字符串的字符串。在以下示例中,我们从“student_info”表中获取数据,并使用带有 LIKE 运算符的 SOUNDEX() 函数从表中检索特定记录−

mysql> Select * from Student_info;
+------+---------+------------+------------+
| id   | Name    | Address    | Subject    |
+------+---------+------------+------------+
| 101 | YashPal  | Amritsar   | History    |
| 105 | Gaurav   | Chandigarh | Literature |
| 125 | Raman    | Shimla     | Computers  |
+------+---------+------------+------------+
3 rows in set (0.00 sec)

mysql> Select * from student_info where SOUNDEX(Name) LIKE '%G%';
+------+--------+------------+------------+
| id   | Name   | Address    | Subject    |
+------+--------+------------+------------+
| 105  | Gaurav | Chandigarh | Literature |
+------+--------+------------+------------+
1 row in set (0.00 sec)

我们已经使用了列的名称作为 SOUNDEX() 函数的参数,它返回的 SOUNDEX 值 LIKE %G% 的行。

请记住,SOUNDEX() 函数的输出始终包含作为参数传递的字符串的第一个字母。例如,如果我们将“Ram”作为 SOUNDEX() 函数的参数传递,那么请看输出,它包含“R”作为第一个字符−

mysql> Select SOUNDEX('Ram');
+----------------+
| SOUNDEX('Ram') |
+----------------+
| R500           |
+----------------+
1 row in set (0.00 sec)

mysql> Select SOUNDEX('ram');
+----------------+
| SOUNDEX('ram') |
+----------------+
| R500           |
+----------------+
1 row in set (0.00 sec)

更新于: 2020 年 6 月 22 日

248 次浏览

开启您的 职业生涯

完成课程,获得认证

开始
广告
© . All rights reserved.