rikidev Ответов: 2

Исключение типа systemnullrefenceexception sqlserver on select


Hello, I have a problem with this C# code, Then the code below load value from table into database called Distinta, the function is call SetValoriDistinta, when i run this function, the compiler give to me the error of image. How can i solve this error?

<a href="https://imgur.com/a/gMyTd">IMAGE OF ERROR</a>


<pre><pre>FIRST.CS

//Istanzio ля других целей, помимо их Е configuro я parametri да passare все'oggetto других целей, помимо их
Других целей, помимо их Д = новые других целей, помимо их();
д. дБ = дБ;
д = новый других целей, помимо их(CodiceDistinta);
//Carico Дентро'oggetto д л я других целей, помимо их валором
д. SetValoriDistinta();
//Задала Ла текстовое поле кон иль код делла других целей, помимо их
textBoxIdDistinta.Текст = d.GetIdDistinta();
//Ridimensionamento Представить,
pictureBoxImmagineDistinta.SizeMode = PictureBoxSizeMode.StretchImage;
//TOGLIE RIGA VUOTA
dataGridViewComposizioneDistinta.AllowUserToAddRows = false;
//Caricamento по умолчанию для других целей, помимо их валором
labelDataInserimento.Текст = д.DataInserimento;
labelDataUltimaModifica.Текст = д.DataModifica;
textBoxDescrizione.Текст = д.Taunus спортивный;
richTextBoxDescrizioneEstesa.Текст = д.DescrizioneEstesa;
textBoxUnitadiMisura.Текст = d.UM;
textBoxIdDistinta.Текст = d.IdDistinta;
pictureBoxImmagineDistinta.Изображение = d.immagine;

Distinta.CS

 class Distinta
    {
        public int CodiceDistinta;
        public String NomeDistinta,IdDistinta, DataInserimento, DataModifica, Descrizione, DescrizioneEstesa, UM;
        public Database db;
        public Bitmap immagine;

        public Distinta(int CodiceDistinta)
        {
            this.CodiceDistinta = CodiceDistinta;
        }

        public Distinta()
        {
        }

        public String GetIdDistinta()
        {
            String IdDistinta=null;
            try
            {
                String query = "select * from Distinta Where CodiceDistinta=@CodiceDistinta ";
                SqlCommand command = new SqlCommand(query, db.apriconnessione());
                command.Parameters.Add("@CodiceDistinta", SqlDbType.Int).Value = CodiceDistinta;
                SqlDataAdapter da = new SqlDataAdapter(command);
                DataTable dt = new DataTable();
                da.Fill(dt);

                if (dt.Rows.Count > 0)
                {
                    foreach (DataRow dr in dt.Rows)
                    {
                        IdDistinta = dr["IdDistinta"].ToString();
                    }
                }

                db.chiudiconnessione();
            }

            catch (Exception ex)
            {

            }

      
            return IdDistinta;
        }

        public void SetValoriDistinta()
        {
            try
            {
                SqlConnection conn = db.apriconnessione();
                String query = "Select * from Distinta Where CodiceDistinta=@CodiceDistinta";
                SqlCommand command = new SqlCommand(query, conn);
                command.Parameters.Add("@CodiceDistinta", SqlDbType.Int).Value = CodiceDistinta;
                using (var reader = command.ExecuteReader()){

                        while (reader.Read())
                        {
                            DataInserimento = reader["DataInserimento"].ToString();
                            DataModifica = reader["DataModifica"].ToString();
                            Descrizione = reader["Descrizione"].ToString();
                            DescrizioneEstesa= reader["DescrizioneEstesa"].ToString();
                            UM = reader["UnitaMisura"].ToString();
                            IdDistinta= reader["IdDistinta"].ToString();

                            byte[] picData = reader["Images"] as byte[] ?? null;

                            if (picData != null)
                            {
                                using (MemoryStream ms = new MemoryStream(picData))
                                {
                                    immagine = new System.Drawing.Bitmap(ms);

                                }
                            }
                        }

                    }

                db.chiudiconnessione();
                conn.Close();                            
            }

            catch(Exception ex)
            {
               MessageBox.Show("Errore caricamento Immagine:  "+ex);

            }

        }

}




Что я уже пробовал:

Hello, I have a problem with this C# code, Then the code below load value from table into database called Distinta, the function is call SetValoriDistinta, when i run this function, the compiler give to me the error of image. How can i solve this error?

Karthik_Mahalingam

в какой строке вы получаете эту ошибку ?

2 Ответов

Рейтинг:
0

OriginalGriff

Это одна из самых распространенных проблем, которые нам задают, и это также та, на которую мы меньше всего готовы ответить, но вы больше всего готовы ответить сами.

Позвольте мне просто объяснить, что означает ошибка: вы пытались использовать переменную, свойство или возвращаемое значение метода, но оно содержит null - что означает, что в переменной нет экземпляра класса.
Это немного похоже на карман: у вас есть карман в рубашке, который вы используете, чтобы держать ручку. Если вы сунете руку в карман и обнаружите, что там нет ручки, вы не сможете подписать свое имя на листе бумаги - и вы получите очень смешные взгляды, если попытаетесь! Пустой карман дает вам нулевое значение (здесь нет ручки!), поэтому вы не можете сделать ничего, что обычно делали бы, когда вы извлекли свою ручку. Почему он пуст? Вот в чем вопрос - может быть, вы забыли взять ручку, когда уходили из дома сегодня утром, или, возможно, вы оставили ручку в кармане вчерашней рубашки, когда снимали ее вчера вечером.

Мы не можем сказать, потому что нас там не было, и, что еще важнее, мы даже не можем видеть вашу рубашку, не говоря уже о том, что находится в кармане!

Вернемся к компьютерам, и вы каким - то образом сделали то же самое-и мы не можем увидеть ваш код, а тем более запустить его и узнать, что содержит null, когда это не должно быть.
Но вы можете - и Visual Studio поможет вам здесь. Запустите свою программу в отладчике, и когда она выйдет из строя, VS покажет вам строку, в которой она обнаружила проблему. Затем вы можете начать просматривать различные его части, чтобы увидеть, какое значение равно null, и начать просматривать свой код, чтобы узнать, почему. Поэтому поставьте точку останова в начале метода, содержащего строку ошибки, и снова запустите программу с самого начала. На этот раз VS остановится перед ошибкой и позволит вам изучить, что происходит, пройдя через код, глядя на ваши значения.

Но мы не можем этого сделать - у нас нет вашего кода, мы не знаем, как его использовать, если бы он у нас был, у нас нет ваших данных. Так что попробуйте - и посмотрите, сколько информации вы можете узнать!


Рейтинг:
0

PeejayAdams

Мне это кажется неправильным:

Distinta d = new Distinta();
d.db = db;
d = new Distinta(CodiceDistinta);


Вы создаете экземпляр Distinta с пустым конструктором.

Затем вы устанавливаете свойство базы данных этого экземпляра.

Затем вы заменяете этот экземпляр новым - теряя значение db, которое затем пытаетесь использовать в SetValoriDistinta():

SqlConnection conn = db.apriconnessione();


Насколько я могу видеть, db будет здесь нулевым и вызовет исключение.