Condividi tramite

ATTIVAZIONE DI UNA MSGBOX AL VERIFICARSI DI UNA CONDIZIONE

Anonimo
2015-02-20T08:46:32+00:00

Buongiorno

mi chiamo Luca e da qualche tempo mi diverto a realizzare un Dbase gestionale che fino ad oggi, e per le finalità per cui è nato, mi funziona correttamente. Voglio precisare che sono alle prime armi con access  e il codice non lo mastico per niente (grazie ad access 2007 e alle creazioni guidate sono riuscito a realizzare un dbase funzionale).

Adesso volevo implementare il mio Dbase con una funzione che mi attivi una Box di messaggio al verificarsi di una o più condizioni. Ho girato un pò in internet ma al momento non sono riuscito a trovare la soluzione, per cui ho deciso di scrivere su questa Community che nel passato, grazie a Mimmo, è riuscita a dare la soluzione ad un problema.

bene adesso vi illustro cosa ho pensato di fare.

Il mio Dbase contiene, tra l'altro, alcune informazioni tra cui ID_Progetto, l'importo del progetto e l'importo delle spese sostenute (vedi Tabella 1); poi ho una seconda tabella dove vengono riportati gli step per richiedere acconto 1, acconto 2, etc. (vedi tabella 2) ed infine ho una query di riepilogo dove, tra l'altro calcolo la % di avanzamento della spesa rispetto all'importo del progetto (vedi tabella query).

Io vorrei realizzare un controllo nella maschera "Tabella query" che in apertura mi faccia comparire un messaggio di avviso (MsgBox) al verificarsi delle seguenti condizioni:

Se la “Percentuale avanzamento” > “30,00%<”60,00” aprire MsgBox con messaggio “PUOI CHIEDERE ACCONTO N. 1”

Se la “Percentuale avanzamento” > “60,00%”<95,00% aprire MsgBox con messaggio “PUOI CHIEDERE ACCONTO N. 2”

Se la “Percentuale avanzamento” > “95,00%”<100,00% aprire MsgBox con messaggio “PUOI CHIEDERE ACCONTO N. 3”

In rete non ho trovato una spiegazione chiara di come applicare o scrivere il codice per raggiungere questo risultato.

Per cui mi rivolgo a quale buona anima che mi aiuti.

Grazie mille

Luca

Microsoft 365 e Office | Access | Per la casa | Windows

Domanda bloccata. Questa domanda è stata eseguita dalla community del supporto tecnico Microsoft. È possibile votare se è utile, ma non è possibile aggiungere commenti o risposte o seguire la domanda.

0 commenti Nessun commento

Risposta accettata dall'autore della domanda

Anonimo
2015-02-20T16:36:14+00:00

Senza urlare, però. Grazie. (TUTTOMAIUSCOLO = Urlare. Che poi si fa anche fatica a leggere.)

Tutto chiaro, ora. Io avevo capito che le percentuali fossero fisse in base all'avanzamento.

Prova così:

Option Compare Database

Option Explicit

Private Sub Form_Current()

Dim intAcc  As Integer

Dim sngAvan As Single

  With Me

    .Visible = True

    sngAvan = .Avanzamento.Value

    If sngAvan > .Acconto3.Value And Not (.ynAcconto3.Value) Then

      intAcc = 3

    ElseIf sngAvan > .Acconto2.Value And Not (.ynAcconto2.Value) Then

      intAcc = 2

    ElseIf sngAvan > .Acconto1.Value And Not (.ynAcconto1.Value) Then

      intAcc = 1

    Else

      intAcc = 0

    End If

    If intAcc Then

      If MsgBox("Vuoi richiedere il " & CStr(intAcc) & "° acconto?" _

              , vbYesNo Or vbQuestion _

              , "Acconto") = vbYes Then

        Select Case intAcc

        Case 1: .ynAcconto1.Value = True

        Case 2: .ynAcconto2.Value = True

        Case 3: .ynAcconto3.Value = True

        Case Else

          ' DO NOTHING

        End Select

        DoCmd.OpenForm FormName:="frmAcconti" _

                     , View:=acNormal _

                     , WhereCondition:="[ID_Progetto]=" & .ID_Progetto

      End If

    End If

  End With

End Sub

La risposta è stata utile?

0 commenti Nessun commento

57 risposte aggiuntive

Ordina per: Più utili
  1. Anonimo
    2015-02-20T15:00:29+00:00

    Maurizio,

    ho riguardo i campi e anche i dati, ma non funziona in modo corretto.

    Come posso inviartelo?

    Grazie

    Luca

    La risposta è stata utile?

    0 commenti Nessun commento
  2. Anonimo
    2015-02-20T14:32:32+00:00

    Ciao luca ambrosini,

    controlla quello che hai scritto o i dati della tabella, perché a me funziona su tutti i record. La percentuale è una sola per ogni record (Avanzamento) e viene valutata in un solo modo.

    La risposta è stata utile?

    0 commenti Nessun commento
  3. Anonimo
    2015-02-20T14:30:31+00:00

    Ciao luca ambrosini,

    la risposta esatta è: dipende. ;-)

    Dipende perché non ho elementi per essere preciso. Suppongo che tu non voglia aprire una nuova maschera e basta, ma aprirla sul record corretto, corrispondente al progetto in questione. 

    Potrebbe bastare aggiungere la riga di codice in grassetto:

            Case Else

              ' DO NOTHING

            End Select

    DoCmd.OpenForm FormName:="frmAcconti" _

    , View:=acNormal _

    , WhereCondition:="[ID_Progetto]=" & .ID_Progetto

    Ovviamente coi tuoi nomi di maschera e di campo.

    La risposta è stata utile?

    0 commenti Nessun commento
  4. Anonimo
    2015-02-20T13:44:55+00:00

    Maurizio

    ho verificato il funzionamento e devo dire che funziona solo con il primo record. Per gli altri record (nella prova ne ho inserito 3 (complessivamente) non funziona.

    Tieni presente che per ogni progetto ci possono essere diverse percentuali

    CIao

    Luca

    La risposta è stata utile?

    0 commenti Nessun commento