c#数据库查询显示,datagridview绑定数据库,编辑的查询生成器语句执行总是错误

错误是说无法将varchar转化为numeric其中有2列HT_PAYED,HT_MONEY属性是numeric。下面是查询语句SELECTHT_ID,HT_NAMEFR... 错误是说无法将varchar转化为numeric
其中有2列 HT_PAYED,HT_MONEY属性是numeric。
下面是查询语句
SELECT HT_ID, HT_NAME
FROM HT_HETONG
WHERE (HT_ID LIKE '% ' + @id + '%') AND (HT_NAME LIKE '%' + @name + '%') AND (HT_MONEY LIKE '%' + @money + '%') AND
(HT_YEAR LIKE '%' + @year + '%') AND (HT_PAYED LIKE '%' + @payed + '%') AND
(HT_STATUS LIKE '%' + @status + '%') AND (HT_DEV_TYPE LIKE '%' + @devtype + '%') AND
(HT_FLAG LIKE '%' + @flag + '%')
展开
 我来答
huanghongw
2013-01-04 · 超过75用户采纳过TA的回答
知道答主
回答量:238
采纳率:100%
帮助的人:160万
展开全部
sql执行的先后顺序是从右到左执行 所以HT_PAYED LIKE '%' + @payed + '%' 执行这句话时 将会先把 '%' + @payed + '%' 转为numeric 这显然不行。如此就需要将HT_PAYED 由numeric 转为varchar才行 如果是HT_PAYED = @payed 就不会报错
HT_PAYED LIKE '%' + @payed + '%' 这句话本身就不对 HT_PAYED是numeric 你需要先把numeric转为varchar型在用 rtrim(to_char(HT_PAYED)) like '%' + @payed + '%'
wyh7954
2013-01-04 · 超过33用户采纳过TA的回答
知道答主
回答量:153
采纳率:50%
帮助的人:46.8万
展开全部
查询语句中 LIKE 的地方写错了,应该是:
WHERE (HT_ID LIKE '% @id %') --@id 是具体的数值。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
耐特青年
2013-01-04 · 超过13用户采纳过TA的回答
知道答主
回答量:122
采纳率:0%
帮助的人:56万
展开全部
查看你数据库对应字段的类型。肯定是数据库字段有varchar的和你代码里面的字段属性不一样了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式