gpt4 book ai didi

c# - 's' 附近的语法不正确。字符串 ')'后的引号不闭合

转载 作者:行者123 更新时间:2023-11-30 13:39:21 25 4
gpt4 key购买 nike

我在编程方面有点菜鸟,我想知道我在这里做错了什么 - 有人可以帮助我吗?

我正在制作一个控制台应用程序,它可以在其中同步两个数据库,但是当我尝试将数据插入表中时,它会抛出此异常;代码是:

public static void AddInterationPath(SqlConnection conDS_ReleaseCri, DataRow dr)
{
SqlCommand insertNewAreaPath = new SqlCommand("INSERT INTO InterationPath (ID,NodePath) VALUES(" + dr[0].ToString() + ",'" + dr[2].ToString() + "')", conDS_ReleaseCriterions);
insertNewAreaPath.ExecuteNonQuery();
}

public static void AddAreaPath(SqlConnection conDS_ReleaseCri, DataRow dr)
{
SqlCommand insertNewAreaPath = new SqlCommand("INSERT INTO AreaPath (ID,NodePath) VALUES(" + dr[0].ToString() + ",'" + dr[2].ToString() + "')", conDS_ReleaseCriterions);
insertNewAreaPath.ExecuteNonQuery();
}

我得到以下异常:

incorrect syntax near 's'. unclosed quotation mark after the character string ')'

最佳答案

您要插入的数据可能包含单引号等特殊字符。更改为参数化查询,以便正确转义值。一个很好的例子和解释是 http://www.codinghorror.com/blog/2005/04/give-me-parameterized-sql-or-give-me-death.html .

[编辑:添加了一个例子。 ]

例如,将第一个函数的内容替换为:

SqlCommand insertNewAreaPath = new SqlCommand(
"INSERT INTO InterationPath (ID, NodePath) VALUES(@ID, @NodePath)",
conDS_ReleaseCriterions);
insertNewAreaPath.Parameters.Add("@ID", dr[0]);
insertNewAreaPath.Parameters.Add("@NodePath", dr[2]);
insertNewAreaPath.ExecuteNonQuery();

关于c# - 's' 附近的语法不正确。字符串 ')'后的引号不闭合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12244540/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com