IDB2 соединение не разрешено с C # - PullRequest
0 голосов
/ 28 мая 2019

У меня небольшая проблема с подключением к AS400. Я использую c #.Когда я хочу сделать SQL-оператор вставки в таблицу, он выдает следующее сообщение

SystemInvalidOperationException: эта операция не может быть успешной, поскольку соединение в IBM.Data.DB2.iSeries.iDB2Command не разрешено.verifyConnection ();в IBM.Data.DB2.iSeries.iDB2Command.ExecuteNonQuery ();

здесь дано мое определение строки подключения

    public static string userID;
    public static string passwd;
    public static string system;
    public string query;
    public iDB2Connection conn = new iDB2Connection("DataSource=" + system + ";UserID=" + userID + ";Password=" + passwd + ";DataCompression=true;");

и кода, который содержит оператор вставки

       public  void insert(Programs prog, int nbfiche)
        {
        //conn.Open();
        try
        {


            string sqlQuery = "INSERT INTO DIIAB.FICDET(MTPRO,MTFICH,MTPGM,MTNSRC,MTLSRC,MTTYP,MTOBJT) VALUES('" + Progiciel + "','" + nbfiche + "','" + prog.program_name +
                "','" + prog.source_program + "','" + LIB + "','" + prog.element_type + "','" + prog.program_type + "')";


            iDB2Command iDB2Command = conn.CreateCommand();
            iDB2Command.CommandText = sqlQuery;
            iDB2Command.ExecuteNonQuery();
            sqlQuery = "select MTFICH from DIIAB.FICDET where MTFICH='" + nbfiche + "'";
            iDB2Command command = conn.CreateCommand();
            command.CommandText = sqlQuery;
            iDB2DataReader reader = command.ExecuteReader();
            while (reader.Read())
            {

                if (reader[0].ToString().Contains(nbfiche.ToString()))
                {
                    System.Windows.MessageBox.Show("Un programme à été rajouté à la fiche.");
                }



            }

            System.Windows.MessageBox.Show("Les programmes ont été rajouté à la fiche", "Information");


        }
        catch (Exception e)
        {
            System.Windows.MessageBox.Show(e.ToString());
        }

    }

и код, который вызывает метод вставки с параметрами

         edit.userID = userID;
                            edit.passwd = passwd;
                            edit.system = system;
                            edit editeur = new edit();

                            editeur.nbfiche = Convert.ToInt32(daoficnbr.fICNBR.nb_fiche);
                            editeur.fiche_status = Statuss.Text;
                            editeur.Progiciel = PRO.Text;
                            editeur.getpgm(arcad.lib,daoficnbr.fICNBR.nb_fiche);
                            foreach (Programs p in editeur.content)
                            {
                                editeur.insert(p, editeur.nbfiche);
                            }

Может помочь, пожалуйста, уже 2 дня я застрял на этом

1 Ответ

0 голосов
/ 28 мая 2019

Решение заключалось в том, чтобы строка подключения была завершена точкой с запятой и чтобы conn.Open () успешно завершился перед выполнением команд или запросов.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...