首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在vb中出错,但在sql查询中更正。

在vb中出错,但在sql查询中更正。
EN

Stack Overflow用户
提问于 2014-02-07 05:45:50
回答 3查看 47关注 0票数 0

在vb中出错,但在sql查询中更正。有人能纠正我的VB代码吗。

这是我在VB中的错误代码

代码语言:javascript
复制
cmd = New Odbc.OdbcCommand("SELECT * FROM tblvendorpartnumber WHERE vendorpnumber ='" & Trim(TextBox11.Text.TrimEnd()) & " OR vendorpnumber ='" & Trim(TextBox2.Text.TrimEnd()) & "'", con)

这是mysql查询中的正确代码。

代码语言:javascript
复制
SELECT *
FROM pcba_info.tblvendorpartnumber
WHERE partnumber = '' or vendorpnumber = '';
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2014-02-07 05:53:31

必须解决SQL注入中的问题。

你忘了包括另一对单引号。

从…

代码语言:javascript
复制
TextBox11.Text.TrimEnd()) & " OR

代码语言:javascript
复制
Trim(TextBox11.Text.TrimEnd()) & "' OR

形成为

代码语言:javascript
复制
cmd = New Odbc.OdbcCommand("SELECT * FROM tblvendorpartnumber WHERE vendorpnumber ='" & TextBox11.Text.Trim().Replace("'", "''") & "' OR vendorpnumber ='" & TextBox2.Text.Trim().Replace("'", "''") & "'", con)
票数 0
EN

Stack Overflow用户

发布于 2014-02-07 05:49:47

您需要避免将VB字符串函数与SQL字符串函数混在一起。在引号中写入整个查询以确保在SQL中工作。

票数 0
EN

Stack Overflow用户

发布于 2014-02-07 05:57:39

试着像这样

Trim将从字符串中修剪任何前导或尾随空格。因此,如果字符串是" Text“,那么Trim将为您删除这些空格,只留下”Text“。

代码语言:javascript
复制
Dim S1,S2  as String
S1 = TextBox11.Text
S2 = TextBox12.Text
cmd = New Odbc.OdbcCommand("SELECT * FROM tblvendorpartnumber WHERE vendorpnumber ='" & S1.Trim & " OR vendorpnumber ='" & S2.Trim & "'", con)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21620226

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档