C#调用Access数据库 Like通配符的使用

本文介绍了在C#中通过OleDb连接Access数据库时,使用LIKE通配符进行查询遇到的问题。当在Access数据库中直接执行SQL`select * from product where product_name like '*金*'`可以正常返回结果,但在C#代码中执行相同的查询却无结果。问题在于ANSI-89和ANSI-92 SQL语法中通配符的区别,前者使用*,后者使用%。因此,解决方法是将C#中的SQL语句中的*替换为%。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

select * from product where product_name like '*金*'

这句sql语句,直接在Access数据库中执行正常,有结果。

但是在C# 代码里组装该sql语句,然后通过OleDb连接Access执行查询,却一直没有结果。

经过查阅资料发现:


这是因为运行这些SQL语句时所使用的数据库引擎语法不同所致,ANSI-89 SQL 语法,通配符为*。 ANSI-92 SQL 语法,通配符为“%”。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值