首页 > 解决方案 > MySQL/VB.NET(Winform) - 如何正确使用@var?

问题描述

我正在 MySQL 和 VB.NET 中开发一个序列,其中,当删除一条记录时,标识它的数字被删除,并将 1 到“n”的序列,序列如下。

这是 MySQL 的说明。

SET @rownum=0;
UPDATE id_line t, (SELECT @rownum:=@rownum+1 rownum, id_line.* FROM id_line WHERE id_line.line_name=59999 and id_line.line_no<>0) r 
SET t.line_no = r.rownum 
WHERE (t.id_line_b = r.id_line_b)

在 VB.net 我用这个

cmdB = New MySqlCommand("SET @rownum=0 UPDATE id_line t, (SELECT @rownum=:@rownum+1 rownum, id_line.* FROM id_line WHERE id_line.line_name='" & TextBox1.Text & "' and id_line.line_no<>0) r ) SET t.line_no = r.rownum WHERE(t.id_line_b = r.id_line_b)", conn)

但 VB 发送此错误

您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以在第 1 行的 'UPDATE id_line t, (SELECT @rownum=:@rownum+1 rownum, id_line.* FROM id_lin' 附近使用正确的语法

你能帮我解决这个错误吗?

更新 1:这是我的字符串连接。

Public conString As String = "Data Source=server_one;port=3306;Initial Catalog=test_db;User Id=root;password=root;Allow User Variables=True"

标签: mysqlvb.netwinforms

解决方案


procedure创建 mysql以删除 mysql 数据查询的其他更好的方法

https://www.tutorialspoint.com/What-is-stored-procedure-and-how-can-we-create-MySQL-stored-procedures


推荐阅读