alanort
Messages postés16Date d'inscriptionsamedi 10 avril 2010StatutMembreDernière intervention22 avril 2010
-
8 avril 2010 à 20:22
alanort
Messages postés16Date d'inscriptionsamedi 10 avril 2010StatutMembreDernière intervention22 avril 2010
-
8 avril 2010 à 21:29
bonjour ben voila j'ai un code très très moche et j'aimerai beaucoup l'ameliorer en evitant les redondances.
par exemple, j'ai ces meme lignes de codes qui me servent pour tester la connection a la base de donnée et de l'ouvrir qui apparaissent plusieurs fois dans toute mes forms.
Dim ocCommand As New OleDb.OleDbCommand
Public ocConnexion As New System.Data.OleDb.OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=../BDPodoComplete.mdb;User Id=admin;Password=;")
Try
ocConnexion.Open()
MsgBox("la connection a bien ete etablie.")
Catch ex As OleDb.OleDbException
MessageBox.Show(ex.Message)
End Try
Pour eviter que ce code se repete des millions de fois, j'avais dans l'idée de faire une class Connection qui comporterai les attributs ocConnexion comme decrit ci dessus et une méthode GetConnection avec le try Catch et puis faire appelle a la methode quand j'en ai besoin dans mes form.
Est ce que c'est une bonne methode de programmation ou bien dois utiliser un pattern Singleton qu'on m'a recommandé?
Si c'est mieux d'utiliser un pattern Singleton, pourriez me dire quel est vraiment l'interet de l'utiliser dans ce cas ci et comment?
cs_vpoyo
Messages postés363Date d'inscriptionvendredi 14 février 2003StatutMembreDernière intervention20 avril 20106 8 avril 2010 à 21:23
Bonjour,
Le moyen le plus simple pour éviter la redondance de code c'est de le factoriser dans une méthode.
tu peux te faire une classe utilitaire regroupant tes méthodes pour les opérations DB
et mettre ton code dans une méthode public shared
Le pattern singleton te permet d'avoir un objet unique, dans le cas d'une connexion à une base de données ce n'est pas très judicieux.