【问题标题】:Syntax error near: When connecting to mysql database附近的语法错误:连接到 mysql 数据库时
【发布时间】:2019-02-09 01:05:46
【问题描述】:

我已经阅读了很多主题,但它们都没有真正起作用,这就是为什么我要问一个新问题。

好吧,所以我正在尝试将值插入到我的 MySQL 数据库中,但我遇到了错误。

MySql.Data.MySqlClient.MySqlException: '你的 SQL 有错误 句法;检查与您的 MySQL 服务器版本相对应的手册 在 'Desc, Detectors, DetectorNos, Question1, Question2, SpecialPrec, OfficerSign, Of' at line 1'

我找不到问题出在哪里。我已经尝试了几个小时没有任何结果,甚至通读了一百遍,但仍然没有运气。所以我需要其他人来看看。

 public string detector = "";
    public string questions = "";
    public string question2 = "";
    public string capOrCheif = "";

    private void btn_send_Click(object sender, EventArgs e)
    {
        if(cbox_detectors_yes.Checked == true)
        {
            detector = "Yes";
        }
        if(cbox_yes1.Checked == true && cbox_yes3.Checked == true && cbox_yes4.Checked == true && cbox_yes5.Checked == true && cbox_yes6.Checked == true && cbox_yes7.Checked == true)
        {
            questions = "Yes";
        }
        if(cbox_yes2.Checked == true)
        {
            question2 = "Yes";
        }
        if(cbox_cheif.Checked == true)
        {
            capOrCheif = "Cheif Engineer";
        }
        else if(cbox_captain.Checked == true)
        {
            capOrCheif = "Captain";
        }
        else if(cbox_na2.Checked == true)
        {
            question2 = "N/A";
        }
        else if(cbox_detectors_na.Checked == true)
        {
            detector = "N/A";
        }

        string constring = "Server = **; Database = **; User Id = **; Password = ***; Sslmode = none;";
        string Query = "INSERT INTO tbl_permit (Username, Ship, Date, TimeFrom, TimeTo, Location, Desc, Detectors, DetectorNos, Question1, Question2, SpecialPrec, OfficerSign, OfficerName, OfficerPos, CheifSign, CheifName, CaptainSign, CaptainName, PrecAddedBy, PrecBox) values(@Username, @Ship, @Date, @TimeFrom, @TimeTo, @Location, @Desc, @Detectors, @DetectorNos, @Question1, @Question2, @SpecialPrec, @OfficerSign, @OfficerName, @OfficerPos, @CheifSign, @CheifName, @CaptainSign, @CaptainName, @PrecAddedBy, @PrecBox);";
        MySqlConnection con = new MySqlConnection(constring);
        MySqlCommand cmdDatabase = new MySqlCommand(Query, con);

        cmdDatabase.Parameters.Add("@Username", MySqlDbType.VarChar, 50).Value = login.username;
        cmdDatabase.Parameters.Add("@Ship", MySqlDbType.VarChar, 50).Value = txtbox_ship.Text;
        cmdDatabase.Parameters.Add("@Date", MySqlDbType.VarChar, 50).Value = txtbox_date.Text;
        cmdDatabase.Parameters.Add("@TimeFrom", MySqlDbType.VarChar, 50).Value = txtbox_timeFrom.Text;
        cmdDatabase.Parameters.Add("@TimeTo", MySqlDbType.VarChar, 50).Value = txtbox_timeTo.Text;
        cmdDatabase.Parameters.Add("@Location", MySqlDbType.VarChar, 50).Value = txtbox_location;
        cmdDatabase.Parameters.Add("@Desc", MySqlDbType.VarChar, 50).Value = txtbox_work_desc.Text;
        cmdDatabase.Parameters.Add("@Detectors", MySqlDbType.VarChar, 50).Value = detector;
        cmdDatabase.Parameters.Add("@DetectorNos", MySqlDbType.VarChar, 50).Value = txtbox_detector_desc.Text;
        cmdDatabase.Parameters.Add("@Question1", MySqlDbType.VarChar, 50).Value = questions;
        cmdDatabase.Parameters.Add("@Question2", MySqlDbType.VarChar, 50).Value = question2;
        cmdDatabase.Parameters.Add("@SpecialPrec", MySqlDbType.VarChar, 50).Value = txtbox_precautions.Text;
        cmdDatabase.Parameters.Add("@OfficerSign", MySqlDbType.VarChar, 50).Value = txtbox_officer_sign.Text;
        cmdDatabase.Parameters.Add("@OfficerName", MySqlDbType.VarChar, 50).Value = txtbox_officer_name.Text;
        cmdDatabase.Parameters.Add("@OfficerPos", MySqlDbType.VarChar, 50).Value = txtbox_officer_pos.Text;
        cmdDatabase.Parameters.Add("@CheifSign", MySqlDbType.VarChar, 50).Value = txtbox_cheif_sign.Text;
        cmdDatabase.Parameters.Add("@CheifName", MySqlDbType.VarChar, 50).Value = txtbox_cheif_name.Text;
        cmdDatabase.Parameters.Add("@CaptainSign", MySqlDbType.VarChar, 50).Value = txtbox_captain_sign.Text;
        cmdDatabase.Parameters.Add("@CaptainName", MySqlDbType.VarChar, 50).Value = txtbox_captain_name.Text;
        cmdDatabase.Parameters.Add("@PrecAddedBy", MySqlDbType.VarChar, 50).Value = capOrCheif;
        cmdDatabase.Parameters.Add("@PrecBox", MySqlDbType.VarChar, 50).Value = txtbox_restrictions.Text;

        MySqlDataReader myReader;
        if (cbox_read.Checked == true)
        {
            con.Open();
            myReader = cmdDatabase.ExecuteReader();
            while (myReader.Read())
            {
            }

            MessageBox.Show("Hot Work Permit Form has been sent to the Cheif Engineer");
        }
        else
        {
            MessageBox.Show("You have to read it through and accept it!");
        }

    }

【问题讨论】:

  • date 是保留字,用反引号转义。
  • @AlexK。我怎样才能在那个词上用后棍逃脱?你能给我举个例子吗? :) 非常感谢您的回答!
  • "对于日期,您可以在 [Date] 列周围加上方括号。" @user3352617 错误,这不是 SQL Server (MSSQL),而是 MySQL 使用括号会出现语法错误。

标签: c# mysql .net


【解决方案1】:

DATE 不是保留字,尽管上面有评论。您可以在此处获取保留字列表:https://dev.mysql.com/doc/refman/8.0/en/keywords.html

该页面列出了关键字,但只有一部分保留,由列表中的 (R) 注释指示。

错误信息告诉你是哪个词导致解析器变得混乱:

...查看与您的 MySQL 服务器版本相对应的手册,了解在 'Desc, Detectors, ... 附近使用的正确语法。

它对DESC 这个词感到困惑。 MySQL 中的语法错误总是向您显示查询的部分开始在它混淆的地方。

DESC 是在这种情况下导致问题的保留字。 DESC 在我链接的关键字列表中有(R) 注释。

您应该分隔与保留字冲突的标识符:

string Query = "INSERT INTO tbl_permit (... Location, `Desc`, Detectors, ...

【讨论】:

  • 非常感谢您的帮助!我太愚蠢了,我无法命名它 Desc...我猜我的大脑已经下班了。 :s 但这很好用!谢谢!
猜你喜欢
  • 1970-01-01
  • 2015-12-01
  • 1970-01-01
  • 1970-01-01
  • 2021-04-28
  • 2018-04-10
  • 1970-01-01
  • 2017-01-28
  • 1970-01-01
相关资源
最近更新 更多