gpt4 book ai didi

C# Sql 客户端 - 无法插入名称以数字开头的参数化列

转载 作者:太空宇宙 更新时间:2023-11-03 23:29:29 27 4
gpt4 key购买 nike

在我的SqlClient 类中,我以这种方式实现了Insert 方法。我必须将带有对(列名、值)的 Dictionary 传递给 Insert 方法,然后该方法构造参数化查询并执行命令。

    public void Insert(string table, Dictionary<string, object> values)
{
// build INSERT query
string query = "INSERT INTO " + table + " (";

foreach (KeyValuePair<string, object> pair in values)
query += pair.Key + ",";

query = query.Substring(0, query.Length - 1) + ")";
query += "VALUES (";

foreach (KeyValuePair<string, object> pair in values)
query += "@" + pair.Key + ",";

query = query.Substring(0, query.Length - 1) + ")";

// create command from query
using (SqlCommand command = new SqlCommand(query, connect))
{
foreach (KeyValuePair<string, object> pair in values)
command.Parameters.Add(pair.Key, pair.Value);

// execute command
command.ExecuteNonQuery();
}
}

但是,我发现当值列表中有一些名称以数字开头的列时它不起作用,例如 1column。 (我知道这是糟糕的变量名,请告诉数据库所有者)。你能建议我一些方法让它工作吗?此外,您肯定会发现我的查询构建方式并不理想,所以如果您提出任何意见,我将不胜感激。

编辑:

  • 用双引号将列名称括起来 ("1column") 没有帮助。

最佳答案

用方括号将列名括起来,例如[1 列].

  string query = "INSERT INTO " + table + " (";

foreach (KeyValuePair<string, object> pair in values)
query += "[" + pair.Key + "],";

关于C# Sql 客户端 - 无法插入名称以数字开头的参数化列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32781217/

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