python中的mysql数据库LIKE操作符详解

LIKE操作符用于在WHERE子句中搜索列中的指定模式,like操作符的语法在文章开头也给大家提到,通过两种示例代码给大家介绍python中的mysql数据库LIKE操作符知识,感兴趣的朋友跟随小编一起看看吧

LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式。

语法:

?

1

2

3

SELECT column_name(s)

FROM table_name

WHERE column_name LIKE pattern

pattern这里就是放指定模板的地方,而这里就要用到“ % ”,也叫做通配符

%如果是放在条件前面,那就是查以…结尾的数据;例如:%李

%如果是放在条件后面,那就是查以…开头的数据;例如:李%

%如果是在条件前后都存在,那就是查包含的数据;例如:%李%

小知识点:

ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '%z' at line 1

1064的错误就是LIKE查询时(语法错误),通配符处没加引号,所以才会报错…

正确展示例如:"%李%"

示例1:终端运行sql且WHERE子句中使用LIKE

查询地址以Hang开头的人员信息

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

root@7c6316b19d80:/# mysql -u root -p

Enter password:

Welcome to the MySQL monitor. Commands end with ; or \\g.

Your MySQL connection id is 140

Server version: 5.6.51 MySQL Community Server (GPL)

mysql> mysql> select * from test_user where address like 'Hang%';

+—-+——–+————-+———-+

| id | name | mobile | address |

+—-+——–+————-+———-+

| 3 | python | 18856565858 | Hangzhou |

| 4 | java | 17756565858 | Hangzhou |

| 5 | php | 15556565858 | Hangzhou |

| 6 | c# | 17748484142 | Hangzhou |

+—-+——–+————-+———-+

4 rows in set (0.00 sec)

mysql>

查询地址以u结尾的人员信息

?

1

2

3

4

5

6

7

8

9

10

11

mysql> select * from test_user where address like '%u';

+—-+——–+————-+———-+

| id | name | mobile | address |

+—-+——–+————-+———-+

| 3 | python | 18856565858 | Hangzhou |

| 4 | java | 17756565858 | Hangzhou |

| 5 | php | 15556565858 | Hangzhou |

| 6 | c# | 17748484142 | Hangzhou |

+—-+——–+————-+———-+

4 rows in set (0.00 sec)

mysql>

示例2:使用python脚本执行含LIKE的sql语句

查询地址包含z字符的人员信息

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

import pymysql

# 连接数据库

connection = pymysql.connect(host="localhost", user="root", password="123456",

database="testing", port=3306, charset='utf8',

cursorclass=pymysql.cursors.DictCursor)

try:

with connection:

with connection.cursor() as cursor:

sql = """

SELECT

*

FROM

test_user

WHERE

address LIKE '%z%';

"""

cursor.execute(sql)

result = cursor.fetchall()

for i in result:

print(i)

except pymysql.err.MySQLError as _error:

raise _error

?

1

2

3

4

5

6

{'id': 3, 'name': 'python', 'mobile': '18856565858', 'address': 'Hangzhou'}

{'id': 4, 'name': 'java', 'mobile': '17756565858', 'address': 'Hangzhou'}

{'id': 5, 'name': 'php', 'mobile': '15556565858', 'address': 'Hangzhou'}

{'id': 6, 'name': 'c#', 'mobile': '17748484142', 'address': 'Hangzhou'}

Process finished with exit code 0

查询地址不包含z字符的人员信息

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

try:

with connection:

with connection.cursor() as cursor:

sql = """

SELECT

*

FROM

test_user

WHERE

address NOT LIKE '%z%';

"""

cursor.execute(sql)

result = cursor.fetchall()

for i in result:

print(i)

except pymysql.err.MySQLError as _error:

raise _error

?

1

2

3

4

{'id': 1, 'name': '张三三', 'mobile': '17748484141', 'address': '浙江杭州'}

{'id': 9, 'name': '111', 'mobile': '18847474549', 'address': '浙江杭州'}

Process finished with exit code 0

至此,使用LIKE操作符查询完毕…

python中的mysql数据库LIKE操作符详解

知识点扩展:python中的mysql数据库like模糊查询

%在python中是个特殊的符号,如%s,%d分别代表了字符串占位符和数字占位符。

大家知道,mysql的模糊查询也需要用到%。

所以,可以先把需要查的字符串抽出来,再以参数方式传入。

?

1

2

args = '%'+subtitle+'%'

sqlQueryTitle="select count(*) from tbl_peng_article where title like '%s'"%args

到此这篇关于python中的mysql数据库LIKE操作符详解的文章就介绍到这了,更多相关python mysql like操作符内容请搜索钦钦技术栈以前的文章或继续浏览下面的相关文章希望大家以后多多支持钦钦技术栈!

原文链接:https://blog.csdn.net/LIFENG0402/article/details/118369315

版权声明:本文(即:原文链接:https://www.qin1qin.com/catagory/6667/)内容由互联网用户自发投稿贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 630367839@qq.com 举报,一经查实,本站将立刻删除。

(0)
上一篇 2022年 7月 29日 10:20:05
下一篇 2022年 7月 29日 10:20:19

软件定制开发公司

相关阅读

发表回复

登录后才能评论
通知:禁止投稿所有关于虚拟货币,币圈类相关文章,发现立即永久封锁账户ID!