如何通过 ADO.NET 使用 MySQL 用户变量

发布于 2024-10-16 08:13:38 字数 347 浏览 1 评论 0原文

MySQL SQL 命令可以包含以“@”开头的用户变量。

MySQL ADO.NET 连接器还使用“@”作为命令参数。

有没有办法转义“@”字符,以便我可以在通过 ADO.NET 发送到 MySQL 的 SQL 语句中使用用户变量?


我正在尝试做这样的事情:

UPDATE company 
    SET next_job_id = @jobid:=next_job_id+1 
    WHERE company_id = @companyid; 
SELECT @jobid;

其中@jobid是MySQL用户变量,@companyid是参数。

MySQL SQL commands can contain user variables that start with '@'.

The MySQL ADO.NET connector also uses '@' for command parameters.

Is there a way to escape the '@' character so I can use a user-variable in an SQL statement sent to MySQL via ADO.NET?


I'm trying to do something like this:

UPDATE company 
    SET next_job_id = @jobid:=next_job_id+1 
    WHERE company_id = @companyid; 
SELECT @jobid;

Where @jobid is a MySQL user variable and @companyid is a parameter.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

蓝天白云 2024-10-23 08:13:38

它是一个连接字符串选项 - “Allow User Variables=true”

当设置为 true 时,参数以“?”为前缀。

更新:我已经写了更多相关内容,包括如何使其与 ADO.NET 和 Subsonic 一起使用。 请参见此处

It's a connection string option - "Allow User Variables=true"

When set to true, parameters are prefixed with '?'.

Update: I've written up more on this, including how to get this to work with ADO.NET and Subsonic. See Here.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文