1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571
| Option Explicit
Dim FilmsGenre As String
Dim DebutLettre As String
Dim ref As Integer
Private Sub init_boutons()
' debut
Cmd_Ajouter.Enabled = False
Cmd_Modifier.Enabled = False
Cmd_Valider.Enabled = False
Cmd_Supprimer.Enabled = False
Cmd_Imprimer.Enabled = False
Cmd_Annuler.Enabled = False
End Sub
Private Sub init_zones()
' debut
Txt_FilmsNum.Text = ""
Txt_TitreFilm.Text = ""
Txt_Acteurs.Text = ""
Txt_Année.Text = ""
Txt_Format.Text = ""
Txt_Duree.Text = ""
Lst_Genre.Text = ""
Lst_Realisateurs.Text = ""
Lbl_affichage.Caption = ""
End Sub
Private Sub Cmd_annuler_click()
' debut
init_zones
Lst_GenreFilm.Text = FilmsGenre
Lst_DebutLettre = DebutLettre
desactiver
Lbl_affichage.Caption = ""
End Sub
Private Sub Cmd_Fermer_Click()
Unload Me
End Sub
Public Sub Liste_DebutLettre()
Dim i As Integer
' début
' remplir la liste des films
Lst_DebutLettre.Clear
Lst_DebutLettre.AddItem "TOUS"
For i = 65 To 90
Lst_DebutLettre.AddItem Chr$(i)
Next i
End Sub
Public Sub Liste_GenreFilm()
' début
' remplir la liste des genres
Lst_GenreFilm.Clear
sql = "select GENRE_LIBELLE FROM GENRES"
rst_genre.Open sql, cnx
Lst_GenreFilm.AddItem "TOUS"
If Not rst_genre.EOF Then
Do
Lst_GenreFilm.AddItem rst_genre.Fields("GENRE_LIBELLE")
rst_genre.MoveNext
Loop Until rst_genre.EOF
End If
rst_genre.Close
End Sub
Public Sub liste_Genre()
' début
' remplir la liste des genres
Lst_Genre.Clear
sql = "select GENRE_LIBELLE FROM GENRES"
rst_genre.Open sql, cnx
If Not rst_genre.EOF Then
Do
Lst_Genre.AddItem rst_genre.Fields("GENRE_LIBELLE")
rst_genre.MoveNext
Loop Until rst_genre.EOF
End If
rst_genre.Close
End Sub
Public Sub liste_Realisateurs()
'debut
'remplir la liste des réalisateurs
Lst_Realisateurs.Clear
sql = "SELECT REALISATEURS_NOM FROM REALISATEURS"
rst_realisateurs.Open sql, cnx
If Not rst_realisateurs.EOF Then
Do
Lst_Realisateurs.AddItem rst_realisateurs.Fields("REALISATEURS_NOM")
rst_realisateurs.MoveNext
Loop Until rst_realisateurs.EOF
End If
rst_realisateurs.Close
End Sub
Private Sub Lst_GenreFilm_Click()
'début
init_zones
MSF_Film.Enabled = True
FilmsGenre = Lst_GenreFilm.Text
Lst_Genre.Text = FilmsGenre
'alimentation de la grille films
grille
Cmd_Ajouter.Enabled = True
End Sub
Private Sub Lst_DebutLettre_click()
'debut
init_zones
MSF_Film.Enabled = True
DebutLettre = Lst_DebutLettre
'alimentation de la grille films
sql = "SELECT FILMS_TITRE, FILMS_ACTEUR, FILMS_DUREE, FILMS_SORTIEANNEE, FILMS_FORMAT, FILMS_GENRE, FILMS_REALISATEURS FROM FILMS"
sql = sql + "WHERE FILMS_TITRE LIKE '" & Lst_DebutLettre.List(Lst_DebutLettre.ListIndex) & "%';"
grille
End Sub
Private Sub entete_grille()
' debut
'entête de la grille personnel
MSF_Film.Clear
MSF_Film.Rows = 2 'nb de lignes
MSF_Film.Cols = 9 'nb de colonnes
MSF_Film.Row = 0
MSF_Film.Col = 0
MSF_Film.Text = "Numéro"
MSF_Film.Col = 1
MSF_Film.Text = "Titre"
MSF_Film.Col = 2
MSF_Film.Text = "Acteurs"
MSF_Film.Col = 3
MSF_Film.Text = "Genre"
MSF_Film.Col = 4
MSF_Film.Text = "Année"
MSF_Film.Col = 5
MSF_Film.Text = "Durée"
MSF_Film.Col = 6
MSF_Film.Text = "Réalisateurs"
MSF_Film.Col = 7
MSF_Film.Text = "Format"
MSF_Film.ColWidth(0) = 650
'colwidth définit la largeur de la colonne spécifiée
MSF_Film.ColWidth(1) = 3000
MSF_Film.ColWidth(2) = 3000
MSF_Film.ColWidth(3) = 800
MSF_Film.ColWidth(4) = 800
MSF_Film.ColWidth(5) = 800
MSF_Film.ColWidth(6) = 900
MSF_Film.ColWidth(7) = 3000
End Sub
Private Sub Cmd_ajouter_click()
Dim modif As Integer
' DEBUT
modif = 0 'initialisation
init_zones
init_boutons
activer
' rechercher le numéro du film
sql = "select max(FILMS_NUM) as Nb From FILMS"
rst_films.Open sql, cnx
If rst_films.EOF Then
Txt_FilmsNum.Text = 1
Else
Txt_FilmsNum.Text = (Val(rst_films.Fields("nb")) + 1)
End If
rst_films.Close
Frame_Films.Enabled = True
Cmd_Valider.Enabled = True
Cmd_Annuler.Enabled = True
Lbl_affichage.Caption = "Saisir TOUS les informations puis valider"
End Sub
Private Sub desactiver() 'permet de desactiver les champs textes
' debut
Txt_TitreFilm.Enabled = False
Txt_Acteurs.Enabled = False
Txt_Année.Enabled = False
Txt_Duree.Enabled = False
Txt_Format.Enabled = False
Lst_Genre.Enabled = False
Lst_Realisateurs.Enabled = False
End Sub
Private Sub activer() 'permet d'activer les champs textes
' debut
Frame_Films.Enabled = True
Txt_TitreFilm.Enabled = True
Txt_Acteurs.Enabled = True
Txt_Année.Enabled = True
Txt_Duree.Enabled = True
Txt_Format.Enabled = True
Lst_Genre.Enabled = True
Lst_Realisateurs.Enabled = True
End Sub
Private Sub Cmd_effacer_Click()
' debut
Call Liste_GenreFilm
Call liste_Genre
Call Liste_DebutLettre
'fonction
grille
Lbl_affichage = ""
init_boutons
init_zones
MSF_Film.Enabled = True
entete_grille
End Sub
Private Sub Cmd_Valider_Click()
Dim codeGenre As Integer
Dim codeRealisateur As Integer
'début
' il faut vérifier les différentes informations saisies
msg = " voulez vous vérifier : "
verifier
If verifok Then
If modif = 0 Then
' il s'agit d'une saisie
'récupérer la référence du genre
sql = "select GENRE_CODE FROM GENRES Where GENRE_LIBELLE = '" & Lst_Genre & "'"
rst_genre.Open sql, cnx
codeGenre = rst_genre.Fields("GENRE_CODE")
rst_genre.Close
'récupérer la référence du réalisateur
sql = "SELECT REALISATEURS_NUM FROM REALISATEURS WHERE REALISATEURS_NOM = '" & Lst_Realisateurs & "'"
rst_realisateurs.Open sql, cnx
codeRealisateur = rst_realisateurs.Fields("REALISATEURS_NUM")
rst_realisateurs.Close
sql = "insert into FILMS "
sql = sql + " values (" & Val(Txt_FilmsNum.Text) & ", '" & Txt_TitreFilm.Text & "', '" & Txt_Acteurs.Text & "', '" & Txt_Année.Text & "', '" & Txt_Duree.Text & "', '" & Txt_Format.Text & "', " & codeGenre & ", " & codeRealisateur & ")"
' execution de la requête d'insertion
cnx.Execute sql
msg = " Enregistrement effectué "
init_zones
grille
Else
' il s'agit d'une modification
'mise à jour des coordonnées du membre de l'emprunteur
sql = "update FILMS set "
sql = sql + " FILMS_TITRE = '" & Txt_TitreFilm.Text & "',"
sql = sql + " FILMS_ACTEUR='" & Txt_Acteurs.Text & "', "
sql = sql + " FILMS_SORTIEANNEE='" & Txt_Année.Text & "',"
sql = sql + " FILMS_DUREE='" & Txt_Duree.Text & "',"
sql = sql + " FILMS_FORMAT='" & Txt_Format.Text & "'"
sql = sql + " where FILMS_NUM = " & Val(Txt_FilmsNum.Text)
cnx.Execute sql
msg = " Modification effectuée"
init_zones
init_boutons
grille
End If
End If
Lbl_affichage = msg
End Sub
Private Sub verifier()
'début
verifok = True
' vérifier le type et la saisie des différentes informations
If Txt_TitreFilm.Text = "" Or IsNumeric(Txt_TitreFilm) Then
msg = msg + " le titre ,"
verifok = False
End If
If Txt_Acteurs.Text = "" Or IsNumeric(Txt_Acteurs) Then
msg = msg + "les acteurs,"
verifok = False
End If
If Txt_Année = "" Then
msg = msg + " l'année,"
verifok = False
End If
If Txt_Duree = "" Then
msg = msg + " la durée,"
verifok = False
End If
If Lst_Genre.Text = "" Then
msg = msg + "le genre,"
verifok = False
End If
If Lst_Realisateurs.Text = "" Then
msg = msg + " le réalisateur,"
verifok = False
End If
If verifok Then
' verifier si il y a un doublon dans le cas ou la saisie des données est complète
If modif = 0 Then
sql = " select COUNT(FILMS_NUM) AS NB FROM FILMS where FILMS_TITRE = '" & Txt_TitreFilm.Text & "'"
Else
sql = " select COUNT(FILMS_NUM) AS NB FROM FILMS where FILMS_TITRE = '" & Txt_TitreFilm.Text & " '"
sql = sql + " and FILMS_NUM <> " & Txt_FilmsNum.Text
End If
' exécuter la requête qui vérifie le doublon
rst_films.Open sql, cnx
If rst_films.Fields("nb") > 0 Then
msg = Txt_TitreFilm.Text & " existe déjà !"
verifok = False
End If
rst_films.Close
End If
End Sub
Private Sub Cmd_Imprimer_Click()
Frm_Films.PrintForm
End Sub
Private Sub cmd_modifier_click()
' debut
modif = 1
activer
Cmd_Modifier.Enabled = False
Cmd_Valider.Enabled = True
Lbl_affichage.Caption = "Modifier puis valider"
End Sub
Private Sub Cmd_Supprimer_Click()
' debut
MSF_Film.Col = 0
' il faudrait vérifier la présence du personnel
confirmer
If supp Then
sql = "DELETE * FROM FILMS where FILMS_NUM = " & MSF_Film.Text & " "
cnx.Execute sql
Lbl_affichage = "Suppression réussie"
' maj de la grille personnel
grille
End If
' modifications des contrôles
init_zones
init_boutons
Cmd_Ajouter.Enabled = True
End Sub
Private Sub confirmer()
Dim var
' DEBUT
'demander confirmation de la suppression
var = MsgBox("Etes-vous sûr de vouloir supprimer ?" & Txt_TitreFilm, vbYesNo + vbExclamation, "Supprimer")
If var = 6 Then
supp = True
Else
supp = False
End If
End Sub
Private Sub Form_Load()
Dim i As Integer
' debut
Connec
'Remplir la liste film
Call Liste_GenreFilm
liste_Genre
liste_Realisateurs
Call Liste_DebutLettre
' afficher entete grille
entete_grille
MSF_Film.Enabled = False
End Sub
Private Sub recupdetail()
' debut
MSF_Film.Col = 0
sql = "select * FROM FILMS "
sql = sql + " where FILMS_NUM = " & Val(MSF_Film.Text)
rst_films.Open sql, cnx
If Not rst_films.EOF Then
Txt_FilmsNum.Text = rst_films.Fields("FILMS_NUM")
Txt_TitreFilm.Text = rst_films.Fields("FILMS_TITRE")
If IsNull(rst_films.Fields("FILMS_ACTEUR")) Then
Txt_Acteurs.Text = ""
Else
Txt_Acteurs.Text = rst_films.Fields("FILMS_ACTEUR")
End If
If IsNull(rst_films.Fields("FILMS_SORTIEANNEE")) Then
Txt_Année.Text = ""
Else
Txt_Année.Text = rst_films.Fields("FILMS_SORTIEANNEE")
End If
If IsNull(rst_films.Fields("FILMS_FORMAT")) Then
Txt_Format.Text = ""
Else
Txt_Format.Text = rst_films.Fields("FILMS_FORMAT")
End If
If IsNull(rst_films.Fields("FILMS_DUREE")) Then
Txt_Duree.Text = ""
Else
Txt_Duree.Text = rst_films.Fields("FILMS_DUREE")
End If
' rechercher le nom du genre
sql = "select GENRE_LIBELLE from GENRES where GENRE_CODE = " & rst_films.Fields("FILMS_GENRE")
rst_genre.Open sql
Lst_Genre.Text = rst_genre.Fields("GENRE_LIBELLE")
rst_genre.Close
'rechercher le nom du réalisateur
sql = "SELECT REALISATEURS_NOM FROM REALISATEURS WHERE REALISATEURS_NUM = " & rst_films.Fields("FILMS_REALISATEURS")
rst_realisateurs.Open sql
Lst_Realisateurs.Text = rst_realisateurs.Fields("REALISATEURS_NOM")
rst_realisateurs.Close
End If
rst_films.Close
End Sub
Private Sub grille()
' debut
' corps de la grille film
'déclaration de la variable qui permettre d'afficher le ou les films recherché(s)
Dim sql As String
'début de la requête pour effectuer la recherche
sql = "SELECT FILMS_NUM, FILMS_TITRE, FILMS_ACTEUR, FILMS_DUREE, FILMS_SORTIEANNEE, FILMS_FORMAT, FILMS_GENRE, FILMS_REALISATEURS FROM FILMS"
'maj de la flexgrid
MSF_Film.Clear
entete_grille
'si le choix du titre du film est différent du mot "Tous"
If Lst_DebutLettre <> "TOUS" Then
'alors on affiche le résultat correspondant à la lettre choisie
sql = sql + " WHERE FILMS_TITRE LIKE '" & Lst_DebutLettre.List(Lst_DebutLettre.ListIndex) & "%'"
End If
'trie le nom par ordre alphabétique lorsque le mot "TOUS" est sélectionné
sql = sql + " ORDER BY FILMS_TITRE"
'si le choix du genre est différent du mot TOUS
If Lst_GenreFilm = "TOUS" Then
sql = "select FILMS_NUM, FILMS_TITRE, FILMS_ACTEUR, FILMS_DUREE, FILMS_SORTIEANNEE, FILMS_FORMAT, FILMS_GENRE, FILMS_REALISATEURS FROM FILMS "
Else
sql = "select FILMS_NUM, FILMS_TITRE, FILMS_ACTEUR, FILMS_DUREE, FILMS_SORTIEANNEE, FILMS_FORMAT, FILMS_GENRE, FILMS_REALISATEURS "
sql = sql + " FROM FILMS , GENRES"
sql = sql + " where FILMS_GENRE = GENRE_CODE"
sql = sql + " AND GENRE_LIBELLE ='" & FilmsGenre & "'"
End If
'trie le nom des films dans l'ordre lorsque "tous" est selectionné => meilleure visibilité
sql = sql + "ORDER BY FILMS_TITRE"
'exécution de la requête par un curseur permettant de parcourir la bdd qui est de type public déclaré dans le module variable
rst_films.Open sql, cnx
'initialisation du nbre de lignes à 0
ligne = 0 'nbre de lignes
If Not rst_films.EOF Then 'tant que l'on est pas en fin de résultat
Do 'on répète l'action
'on remplit lignes de la grille une par une
ligne = ligne + 1
rst_films.MoveNext
Loop Until rst_films.EOF 'tant que l'on est pas arrivé à la fin de la bdd
MSF_Film.Rows = ligne + 1
'lecture du résultat enregistré
rst_films.MoveFirst
'boucle pour permettant de parcourir l'ensemble des données enregistrées dans la bdd
For i = 1 To (ligne)
MSF_Film.Row = i
MSF_Film.Col = 0
MSF_Film.Text = rst_films.Fields("FILMS_NUM")
MSF_Film.Col = 1
MSF_Film.Text = rst_films.Fields("FILMS_TITRE")
MSF_Film.Col = 2
If IsNull(rst_films.Fields("FILMS_ACTEUR")) Then
MSF_Film.Text = " "
Else
MSF_Film.Text = rst_films.Fields("FILMS_ACTEUR")
End If
MSF_Film.Col = 3
If IsNull(rst_films.Fields("FILMS_GENRE")) Then
MSF_Film.Text = ""
Else
MSF_Film.Text = rst_films.Fields("FILMS_GENRE")
End If
MSF_Film.Col = 4
If IsNull(rst_films.Fields("FILMS_SORTIEANNEE")) Then
MSF_Film.Text = ""
Else
MSF_Film.Text = rst_films.Fields("FILMS_SORTIEANNEE")
End If
MSF_Film.Col = 5
If IsNull(rst_films.Fields("FILMS_DUREE")) Then
MSF_Film.Text = ""
Else
MSF_Film.Text = rst_films.Fields("FILMS_DUREE")
End If
MSF_Film.Col = 6
If IsNull(rst_films.Fields("FILMS_REALISATEURS")) Then
MSF_Film.Text = ""
Else
MSF_Film.Text = rst_films.Fields("FILMS_REALISATEURS")
End If
MSF_Film.Col = 7
If IsNull(rst_films.Fields("FILMS_FORMAT")) Then
MSF_Film.Text = ""
Else
MSF_Film.Text = rst_films.Fields("FILMS_FORMAT")
End If
rst_films.MoveNext
Next i
Else
Lbl_affichage = " aucun film"
End If
'fermeture du curseur une fois les données parcourues et affichées
rst_films.Close
End Sub
Private Sub MSF_Film_Click()
' DEBUT
recupdetail
If Not MSF_Film.Text = "" Then
ref = MSF_Film.Text
Lbl_affichage = ""
init_boutons
Cmd_Modifier.Enabled = True
Cmd_Supprimer.Enabled = True
Cmd_Annuler.Enabled = True
Frame_Films.Enabled = False
End If
End Sub |
Partager