Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
259 views
in Technique[技术] by (71.8m points)

.net - MySQL binding multiple parameters to a single query

I have a MySql database, and I'm connecting to it from a .Net app using Dapper. I have the following code:

await connection.ExecuteAsync(
    "DELETE FROM my_data_table WHERE somedata IN (@data)", 
    new { data = datalist.Select(a => a.dataitem1).ToArray() },
    trans);

When I do this with more than a single value, I get the following error:

MySqlConnector.MySqlException: 'Operand should contain 1 column(s)'

Is what I'm trying to do possible in MySql / Dapper, or do I have to issue a query per line I wish to delete?

question from:https://stackoverflow.com/questions/65936367/mysql-binding-multiple-parameters-to-a-single-query

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

Your original code was almost fine. You just need to remove the parentheses around the parameter. Dapper will insert those for you:

await connection.ExecuteAsync(
    "DELETE FROM my_data_table WHERE somedata IN @data", 
    new { data = datalist.Select(a => a.dataitem1).ToArray() },
    trans);

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...