Fórum Sobrecarga de Métodos #428227

07/11/2012

0

Bom dia!

Gostaria de saber se na sobreCarga de Métodos eu posso mudar juntamente com os parâmetros os tipo de retorno também ?

Por ex:

public bool executarComando(string p_strSql, List<SqlParameter> p_obParams)
public int executarComando(string p_strSql, List<SqlParameter> p_obParams)

Vlw Pessoal

Alan Miranda

Alan Miranda

Responder

Posts

07/11/2012

Tiago

Bom dia Alan,

Claro que pode meu amigo.Para ser uma sobrecarga a mudança dos parâmetros é obrigatória. Então se você tem um método que não muda os parâmetros mas muda o tipo de retorno, isto não é uma sobrecarga.No entanto se os parâmetros e o tipo de retorno forem mudados, então isso é uma sobrecarga válida.

Espero ter ajudado.
Responder

Gostei + 0

07/11/2012

Robson Alves

Exatamente, se você precisa de um mesmo método que retorne um tipo diferente, você precisa repensar nos seus métodos!

Como boa prática um método deve ter apenas uma responsabilidade.

(Caso não seja o seu caso e apenas uma dúvida, pelo menos você aproveita como dica :D)
Responder

Gostei + 0

07/11/2012

Alan Miranda

Ok, só um pergunta eu consigo utilizar o ExecuteScalar para Update e Delete ?
Ai não irei precisar mudar ou criar um novo método!

Vlw pessoal!
Responder

Gostei + 0

07/11/2012

Robson Alves

Ok, só um pergunta eu consigo utilizar o ExecuteScalar para Update e Delete ?
Ai não irei precisar mudar ou criar um novo método!

Vlw pessoal!



Não pode,o SCALAR não realiza comandos DML, além do que ele é um READER ele vai esperar o retorno da proc.

Para INSERT/UPDATE/DELETE (DML) usa-se o ExecuteNonQuery, por ser performático e correto.
Responder

Gostei + 0

07/11/2012

Alan Miranda

Então o problema é que com ExecuteNonQuery eu não consigo recuperar o indentity do último usuário que foi cadastrado neh ?

Vlww
Responder

Gostei + 0

07/11/2012

Robson Alves

Entendi, neste caso você pode utilizar o Scalar...

Pq seu último comando vai ser :

select @@IDENTITY. então ele vai capturar e retornar!

Sucesso.
Responder

Gostei + 0

07/11/2012

Alan Miranda

Então pos isso que vou ter que criar dois metodos neh ? :(
Responder

Gostei + 0

07/11/2012

Robson Alves

Sim e é o correto a se fazer!

Ficará mais legível quando o nome do método retorna sucintamente tudo o que ele pretende realizar.

Então crie dois métodos, nomeie bem e pronto!
Responder

Gostei + 0

08/11/2012

Alisson Santos

Amigo gostaria de saber se conseguiu sanar sua duvida??
Responder

Gostei + 0

Utilizamos cookies para fornecer uma melhor experiência para nossos usuários, consulte nossa política de privacidade.

Aceitar