簡體   English   中英

將參數傳遞給MySQL數據庫的IdbCommand

[英]Passing parameters to IdbCommand for mySQL database

我正在嘗試使用IdbCommand執行相對簡單的操作來執行插入查詢。

這是代碼:

using (IDbConnection conn = DbHelper.GetConnection(DbConnString))
        using (IDbCommand com = conn.CreateCommand())
        {
            com.CommandType = CommandType.Text;
            com.CommandText =
                String.Format(
                    "INSERT INTO {0} (`Date`, User, Type, `Comment`) VALUES (@Date, @User, @Type, @Comment);",
                    TableName);
            conn.Open();

            var parameterDate = com.CreateParameter();
            parameterDate.ParameterName = "@Date";
            parameterDate.Value = entry.Date;
            parameterDate.DbType = DbType.DateTime;
            com.Parameters.Add(parameterDate);

            var parameterUser = com.CreateParameter();
            parameterUser.ParameterName = "@User";
            parameterUser.Value = entry.User;
            parameterUser.DbType = DbType.String;
            com.Parameters.Add(parameterUser);

            var parameterLogType = com.CreateParameter();
            parameterLogType.ParameterName = "@Type";
            parameterLogType.Value = entry.Type;
            parameterLogType.DbType = DbType.Int32;
            com.Parameters.Add(parameterLogType);

            var parameterComment = com.CreateParameter();
            parameterComment.ParameterName = "@Comment";
            parameterComment.Value = entry.Comment;
            parameterComment.DbType = DbType.String;
            com.Parameters.Add(parameterComment);

            com.ExecuteNonQuery();

但是,我不斷收到消息“列'Date'不能為空”的MySqlException。

我所有的選擇都能正常工作,只是這個插入出現了問題,我看不出有任何明顯的問題。

在運行期間,將使用有效的DateTime填充參數。 我認為這可能與Date是保留字並且需要反引號這一事實有關,但這就是在線教程的建議。

有任何想法嗎?

找到了!

由於某種原因而不是@,它需要嗎?

因此,工作代碼為:

        using (IDbConnection conn = DbHelper.GetConnection(DbConnString))
        using (IDbCommand com = conn.CreateCommand())
        {
            com.CommandType = CommandType.Text;
            com.CommandText =
                String.Format(
                    "INSERT INTO {0} (`Date`, User, Type, `Comment`) VALUES (?Date, ?User, ?Type, ?Comment);",
                    TableName);
            conn.Open();

            var parameterDate = com.CreateParameter();
            parameterDate.ParameterName = "?Date";
            parameterDate.Value = entry.Date;
            parameterDate.DbType = DbType.DateTime;
            com.Parameters.Add(parameterDate);

            var parameterUser = com.CreateParameter();
            parameterUser.ParameterName = "?User";
            parameterUser.Value = entry.User;
            parameterUser.DbType = DbType.String;
            com.Parameters.Add(parameterUser);

            var parameterLogType = com.CreateParameter();
            parameterLogType.ParameterName = "?Type";
            parameterLogType.Value = entry.Type;
            parameterLogType.DbType = DbType.Int32;
            com.Parameters.Add(parameterLogType);

            var parameterComment = com.CreateParameter();
            parameterComment.ParameterName = "?Comment";
            parameterComment.Value = entry.Comment;
            parameterComment.DbType = DbType.String;
            com.Parameters.Add(parameterComment);

            com.ExecuteNonQuery();

        }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM