Variavel com valor não atribuido dentro de um Laço FOR – c# .net ado.net

Pergunta:


    int i;
    string cpf;
    cpf = "11111111111";
    DbConnection cnx = ADO_Utils.GetConnection();
    DbCommand cmd = ADO_Utils.GetComando(cnx);
    cmd.CommandType = CommandType.Text;
    for (i = 1; i < Convert.ToInt32(txbQtde.Text); i++) ;
    {
        string query;
        query = "insert into tblAcordoParcel (txtCPF, intParcela, dblValorParcel, dtVencimento, blnBaixada) ";
        query = query + "Values (  " + "'" + cpf + "',";
        query = query + i + ",";
        query = query + "" + txbParcel.Text + ",";
        query = query + "'" + txbDt.Text + "',";
        query = query + "0"+ ")";
        try
        {
            cmd.CommandText = query;
            cmd.ExecuteNonQuery();
        }
        catch (Exception ex)
            {
                throw ex;
            }

Ao executar esse código, a variável i assume o valor digitado na tela e não o número 1 que eu declarei dentro do FOR, alguém pode me ajudar a corrigir?

Autor da pergunta João K. Queiroz

Resposta Comunidade:

O erro é que o for não está sendo executado, ele está sendo encerrado antes mesmo de iniciar, afinal logo no início dele já há um ; que o encerra. O correto seria ter um bloco de comandos em seguida, assim:

var cpf = "11111111111"; //se não for só um teste não precisa da variável
DbConnection cnx = ADO_Utils.GetConnection();
DbCommand cmd = ADO_Utils.GetComando(cnx);
cmd.CommandType = CommandType.Text;
for (var i = 1; i < Convert.ToInt32(txbQtde.Text); i++) { // <==== note que não tem o ;
    cmd.CommandText = @"insert into tblAcordoParcel (txtCPF, intParcela, dblValorParcel, 
dtVencimento, blnBaixada) Values (@cpf, @i, @parcel, @dt, 0)";
    cmd.Parameters.AddWithValue("@cpf", cpf);
    cmd.Parameters.AddWithValue("@i", i);
    cmd.Parameters.AddWithValue("@parcel", txbParcel.Text);
    cmd.Parameters.AddWithValue("@dt", txbDt.Text);
    cmd.ExecuteNonQuery();

Note que eu fiz alguma mudanças.

Retirei a exceção porque ela não estava fazendo nada útil. Se não tem algo útil para fazer com a exceção, não a capture.

Simplifiquei colocando a declaração e atribuição na mesma linha, não existe motivo para fazer em linhas separadas. Em alguns casos usei o var que simplifica também.

E principalmente usei o comando certo para montar a query de forma segura. O que estava sendo feito era uma temeridade.

Usar um tipo double para valor monetário é outra temeridade.

Tem outras coisas que parecem esquisitas, mas como não estou vendo o todo não vou me pronunciar. Um deles é o uso de notação húngara nos nomes das colunas. Tem outros.

Se os tipos de dblValorParcel e dtVencimento são numérico e data, provavelmente precise fazer uma conversão antes de usá-lo, já que o que vem de fora vem como string. Se alguma conversão der errado por alguma razão (um texto que não produz um número, por exemplo), haverá uma exceção e será um erro de programação. Isto vale até para o Convert já existente. O ideal seria tratar isto de outra forma e evitar a exceção, mas é outro assunto.

Fonte

Related Posts:

Qual a diferença entre AppCompatActivity e Activity? – android android-activity
Pergunta: Qual a diferença da AppCompatActivity para Activity ? A partir de qual versão a AppCompatActivity foi adicionada ao Android? Autor da pergunta Luhhh A diferença reside ...
Como abreviar palavras em PHP? – php string
Pergunta: Possuo informações comuns como nome de pessoas e endereços, e preciso que elas contenham no máximo 30 caracteres sem cortar palavras. Exemplo: 'Avenida Natalino João Brescansin' ...
Qual é a finalidade de um parêntese vazio numa declaração Lambda? – c# expressões-lambda característica-linguagem
Pergunta: Criei um exemplo de uma declaração Lambda sem argumentos, entretanto, estou com duvidas referente a omissão do parêntese vazio () na declaração. Veja o exemplo: class ...
Boas práticas para URI em API RESTful – api rest restful
Pergunta: Estou com dúvida em relação às URIs de alguns recursos da api que estou desenvolvendo. Tenho os recursos projetos e atividades com relação 1-N, ...
Dúvidas sobre a integração do MySQL com Java – java mysql netbeans
Pergunta: Estou criando um sistema no NetBeans, utilizando a linguagem Java e o banco de dados MySQL. Escrevi o seguinte código para realizar a conexão ...
Qual é a finalidade da pasta Model do framework Inphinit? – php inphinit
Pergunta: No Inphinit micro-framework existe a pasta Model que fica dentro da pasta application, e nela é onde ficam as classes, mas eu estou muito ...
Uso do ‘@’ em variáveis – javascript typescript coffeescript
Pergunta: Vejo em algumas linguagens que compilam para javascript, como TypeScript e CoffeeScript, o uso do @ em variáveis, como também, casos em que o ...
Qual tamanho máximo um arquivo JSON pode ter? – json arquivo
Pergunta: Vou dar um exemplo para conseguir explicar minha duvida: Preciso recuperar informação de imagens vindas de uma API, esse banco de imagens me retorna JSON's ...
O que é Teste de Regressão? – terminologia engenharia-de-software testes
Pergunta: Na matéria de Teste de Software o professor abordou um termo chamado Teste de Regressão, isto dentro da disciplina de teste de software. Sendo ...
O que é um construtor da linguagem? – php característica-linguagem
Pergunta: Em PHP, já li e ouvi várias vezes a respeito dos Construtores da Linguagem. Os casos que sempre ouvi falar deles foi em casos ...
Função intrínseca para converter numérico para string – cobol
Pergunta: Estou a tentar saber se existe alguma função intrínseca do COBOL para converter um data numérico para string sem precisar usar a cláusula REDEFINES: ( ...
Porque usar implements? – java android
Pergunta: Qual a diferença entre usar btn.setOnClickListener(new OnClickListener() { e public class MainActivity extends Activity implements OnClickListener{ Estive fazendo um curso de Android e meu professor falou que ...
O que é XHTML e quando deve ser usado? – html xml xhtml
Pergunta: O que eu sei é que o XHTML precisa ser XML válido. Isso implica, por exemplo, que todas as tags precisam ser fechadas. Por ...
Uma placa aceleradora de vídeo pode melhorar o desempenho não-gráfico? [fechada] – desempenho
Pergunta: Para desenvolver em Ruby on Rails, eu utilizo aqui uma máquina virtual do VirtualBox com Ubuntu Server 14.04 sem interface gráfica instalada. Recentemente descobri uma ...
Concat() VS Union() – c# .net
Pergunta: Qual a diferença entre Concat() e Union() ? Quando usar Concat() e quando usar Union() ? Somente pode ser usado em list ? ...

Deixe uma resposta

O seu endereço de email não será publicado. Campos obrigatórios marcados com *