0

MySQL クエリで非常に長い間エラーを見つけようとしています。私がやりたいことは、いくつかの値をデータベースに挿入することだけです。「longText」の値を含めない限り、クエリは正常に機能し、この簡単で単純なクエリの問題の原因が完全にわかりました。

MySQL 例外メッセージは次のとおりです。

MySql.Data.MySqlClient.MySqlException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'longText) VALUES ('191', '529', '', '1', 'index', CURRENT_TIMESTAMP, ' at line 1

Zeile 548:        cmd.Connection = con;
Zeile 549:        cmd.CommandText = "INSERT INTO confirmationfreetext (confirmationId, customer, shortText, sorting, addedBy, entryDate, longText) VALUES (@confirmationId, @customer, @shortText, @sorting, @addedBy, CURRENT_TIMESTAMP, @longText)";
Zeile 550:        cmd.ExecuteNonQuery();
Zeile 551:        con.Close();

[MySqlException (0x80004005): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'longText) VALUES ('191', '529', '', '1', 'index', CURRENT_TIMESTAMP, ' at line 1]
   MySql.Data.MySqlClient.MySqlStream.ReadPacket() +275
   MySql.Data.MySqlClient.NativeDriver.GetResult(Int32& affectedRow, Int32& insertedId) +116
   MySql.Data.MySqlClient.Driver.GetResult(Int32 statementId, Int32& affectedRows, Int32& insertedId) +54
   MySql.Data.MySqlClient.Driver.NextResult(Int32 statementId) +132
   MySql.Data.MySqlClient.MySqlDataReader.NextResult() +707
   MySql.Data.MySqlClient.MySqlCommand.ExecuteReader(CommandBehavior behavior) +1620
   MySql.Data.MySqlClient.MySqlCommand.ExecuteReader() +37
   MySql.Data.MySqlClient.MySqlCommand.ExecuteNonQuery() +58
   editConfirmation.saveFreeTextButton_Click(Object sender, EventArgs e) in e:\aspnet_projects\ammon\editConfirmation.aspx.cs:550
   System.Web.UI.WebControls.Button.OnClick(EventArgs e) +9614758
   System.Web.UI.WebControls.Button.RaisePostBackEvent(String eventArgument) +103
   System.Web.UI.WebControls.Button.System.Web.UI.IPostBackEventHandler.RaisePostBackEvent(String eventArgument) +10
   System.Web.UI.Page.RaisePostBackEvent(IPostBackEventHandler sourceControl, String eventArgument) +13
   System.Web.UI.Page.RaisePostBackEvent(NameValueCollection postData) +35
   System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +1724

これは、関連する asp.net c# コードです。

        //connect to database
        MySqlConnection con = new MySqlConnection();
        con.ConnectionString = Helper.CONNECTION_STRING;
        MySqlCommand cmd = null;

        //add freetext to db
        con.Open();
        cmd = new MySqlCommand();
        cmd.Parameters.AddWithValue("@confirmationId", Session["currentConfirmationId"].ToString());
        cmd.Parameters.AddWithValue("@customer", Session["currentCustomerId"].ToString());
        cmd.Parameters.AddWithValue("@shortText", shortText.Text);
        cmd.Parameters.AddWithValue("@longText", longText.Text);
        cmd.Parameters.AddWithValue("@sorting", "1");
        cmd.Parameters.AddWithValue("@addedBy", Session["authenticatedUser"].ToString());
        cmd.Parameters.AddWithValue("@entryDate", "CURRENT_TIMESTAMP");
        cmd.Connection = con;
        cmd.CommandText = "INSERT INTO confirmationfreetext (confirmationId, customer, shortText, sorting, addedBy, entryDate, longText) VALUES (@confirmationId, @customer, @shortText, @sorting, @addedBy, CURRENT_TIMESTAMP, @longText)";
        cmd.ExecuteNonQuery();
        con.Close();

値を次のように変更できます

cmd.Parameters.AddWithValue("@longText", 'blablabla');

または私が望むものは何でも、私はいつも同じエラーを受け取ります。MySQL クエリに手動で値を書き込んでも、同じエラーが発生します。

関連する MySQL テーブルは次のとおりです。

CREATE  TABLE `ammon`.`confirmationfreetext` (
  `id` INT NOT NULL AUTO_INCREMENT ,
  `confirmationId` INT NULL ,
  `customer` INT(11) NULL ,
  `shortText` VARCHAR(255) NULL ,
  `longText` VARCHAR(255) NULL ,
  `sorting` INT NULL ,
  `entryDate` TIMESTAMP NULL DEFAULT '0000-00-00 00:00:00' ,
  `addedBy` VARCHAR(128) NULL ,
  PRIMARY KEY (`id`) );

誰かがこのエラーについて何か言ってくれることを願っています。事前にt​​hx。

4

1 に答える 1

0

次のコードを試してください:

//connect to database
    MySqlConnection con = new MySqlConnection();
    con.ConnectionString = Helper.CONNECTION_STRING;
    MySqlCommand cmd = null;

    //add freetext to db
    con.Open();
    cmd = new MySqlCommand();
    cmd.Parameters.AddWithValue("?confirmationId", Session["currentConfirmationId"].ToString());
    cmd.Parameters.AddWithValue("?customer", Session["currentCustomerId"].ToString());
    cmd.Parameters.AddWithValue("?shortText", shortText.Text);
    cmd.Parameters.AddWithValue("?longText", longText.Text);
    cmd.Parameters.AddWithValue("?sorting", "1");
    cmd.Parameters.AddWithValue("?addedBy", Session["authenticatedUser"].ToString());
    cmd.Parameters.AddWithValue("?entryDate", "CURRENT_TIMESTAMP");
    cmd.Connection = con;
    cmd.CommandText = "INSERT INTO confirmationfreetext (confirmationId, customer, shortText, sorting, addedBy, entryDate, longText) VALUES (?confirmationId, ?customer, ?shortText, ?sorting, ?addedBy, CURRENT_TIMESTAMP, ?longText)";
    cmd.ExecuteNonQuery();
    con.Close();
于 2013-11-13T14:29:27.797 に答える