diogom Posted June 5, 2013 at 03:07 PM Report #511157 Posted June 5, 2013 at 03:07 PM Olá, Tenho o seguinte código: OleDbCommand cmd = new OleDbCommand("SELECT top 1 InicInt FROM BlFactManuais where Loja ='" + DropLoja2.SelectedItem.Text + "'and Estado ='Aberto'", conn); OleDbCommand cmd2 = new OleDbCommand("SELECT top 1 FimInt FROM BlFactManuais where Loja ='" + DropLoja2.SelectedItem.Text + "'and Estado ='Aberto'", conn); Count = (int)cmd.ExecuteScalar(); Count2 = (int)cmd2.ExecuteScalar(); cmd.Connection = conn; cmd.ExecuteNonQuery(); cmd2.Connection = conn; cmd2.ExecuteNonQuery(); conn.Close(); O problema é quando os dois counts vêm sem nada da´-me erro: a referência de objeto não foi definida como uma instância de um objecto. Se coloco a verificação antes, retorna sempre como null. Se meto dp, dá-me sempre o tal erro. Como faço a verificação?
nelsonr Posted June 5, 2013 at 03:16 PM Report #511161 Posted June 5, 2013 at 03:16 PM (edited) Provavelmente um desses select não está a retornar nenhum registo, e o ExecuteScalar retorna um objecto com null, e estas a fazer o cast para int. Edited June 5, 2013 at 03:16 PM by nelsonr
diogom Posted June 5, 2013 at 03:22 PM Author Report #511164 Posted June 5, 2013 at 03:22 PM Provavelmente um desses select não está a retornar nenhum registo, e o ExecuteScalar retorna um objecto com null, e estas a fazer o cast para int. Não está. Como faço para dar uma mensagem a dizer que não existe registos.
nelsonr Posted June 5, 2013 at 03:27 PM Report #511166 Posted June 5, 2013 at 03:27 PM Poes a variavel Count do tipo object. Depois fazes algo assim: Count = cmd.ExecuteScalar(); if(Count!=null) { // Aqui já podes usar o cast para int }
diogom Posted June 5, 2013 at 03:34 PM Author Report #511170 Posted June 5, 2013 at 03:34 PM Poes a variavel Count do tipo object. Depois fazes algo assim: Count = cmd.ExecuteScalar(); if(Count!=null) { // Aqui já podes usar o cast para int } Isso já tinha feito. Como tinha dito na criação do tópico, quando meto uma mensagem dp dá-me erro. Executa esta linha Count = (int)cmd.ExecuteScalar(); e como vem null passa para o catch
nelsonr Posted June 5, 2013 at 03:37 PM Report #511172 Posted June 5, 2013 at 03:37 PM Isso já tinha feito. Como tinha dito na criação do tópico, quando meto uma mensagem dp dá-me erro. Executa esta linha Count = (int)cmd.ExecuteScalar(); e como vem null passa para o catch Mas leste o que escrevi? Não poes o casts ai, só fazes o cast depois de confirmares que a variavel não é null.
diogom Posted June 5, 2013 at 03:59 PM Author Report #511180 Posted June 5, 2013 at 03:59 PM Mas leste o que escrevi? Não poes o casts ai, só fazes o cast depois de confirmares que a variavel não é null. Desculpa, com a pressa n reparei bem. Só falta o object antes do Count. 👍
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now