Torna indietro   Hardware Upgrade Forum > Software > Programmazione

WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
Con Midnight, Blizzard tenta il colpaccio: il player housing sbarca finalmente su Azeroth insieme a una Quel'Thalas ricostruita da zero. Tra il dramma della famiglia Ventolesto e il nuovo Prey System, ecco com'è la nuova espansione di World of Warcraft
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 27-04-2003, 13:35   #1
prodan
Member
 
L'Avatar di prodan
 
Iscritto dal: Apr 2003
Messaggi: 177
Problema con SQl,ADo e visual Basic

Torno di nuovo sul forum perchè ogni volta kè faccio sto cavolo de programma ne viene fuori una!!
E poi sulla guida(MSDN) non c'è niente.
Mi affido a voi!!
Allego a questo post il mio programma cosìkè qualcuno mi possa aiutare a risolvere questi piccoli problemi!!
Grazie
prodan è offline   Rispondi citando il messaggio o parte di esso
Old 28-04-2003, 10:03   #2
tas
Senior Member
 
L'Avatar di tas
 
Iscritto dal: Feb 2001
Città: Nordest
Messaggi: 217
Ho visto il tuo programma e ti dico che prima di tutto dovresti essere più ordinato nella stesura del codice. Ti vorrei dare questi suggerimenti:

1. Usa il tasto TAB per allineare i blocchi di codice. In questo modo ti accorgerai se hai dimenticato End If o se ne hai messo uno di troppo.

Codice:
'Esempio non leggibile:
Private Sub cmblistino_Click()

indice = cmblistino.ListIndex

If indice = 0 Then
If MyTable.State = 1 Then MyTable.Close
MyTable.Open "Idraulica", MyDataBase
End If

...
End Sub

'Esempio leggibile:
Private Sub cmblistino_Click()
    
    indice = cmblistino.ListIndex
    
    If indice = 0 Then
        If MyTable.State = 1 Then MyTable.Close
        MyTable.Open "Idraulica", MyDataBase
    End If

    ...
End Sub

'altro esempio leggibile:
    Select Case Index
        Case 0
            If MyTable.State = 1 Then
                ...
            End If
        Case 1
            ...
    End Select
2. Attenzione alla sintassi dell'istruzione If...Then...Else...End If
Nella sub cmdagcat_Click ho trovato diversi errori. In particolare un "Else:" che è alquanto emblematico...
Ci sono due forme per l'istruzione If: in linea e su più linee. Quella in linea è così:

If MyTable.State = 1 Then MyTable.Close

e non richiede nessun End If per la chiusura dell'istruzione.
La forma su più linee è questa:
Codice:
If indice = 0 Then
    attivo = "Idraulica"
Else
    attivo = "Elettrica"
End If
3. Questa dichiarazione:
Codice:
Public MyTable, CC As New ADODB.Recordset
corrisponde a questa dichiarazione:
Codice:
Public MyTable As Variant
Public CC As New ADODB.Recordset
Di conseguenza, MyTable non contiene nessun oggetto Recordset (e probabilmente va bene così) ma soprattutto, digitando il codice, non vedi i membri di MyTable.

4. Nel blocco delle dichiarazioni di ogni modulo o form, come prima riga aggiungi:
Option Explicit
che ti obbliga a dichiarare sempre le variabili che utilizzi, e ti evita un sacco di errori!
Questa riga può essere creata automaticamente per ogni nuovo form o modulo del progetto impostando "Dichiarazione di variabili obbligatoria" nella finestra delle opzioni (menu Strumenti/Opzioni, pagina Editor).

5. L'errore che appare durante il salvataggio di un nuovo articolo è dovuto al fatto che nelle tabelle hai utilizzato nomi di campo contenenti uno spazio. Proprio per questo motivo non è consigliabile utilizzare nomi di campo come "Codice Prodotto" ma è preferibile nomi come "CodiceProdotto" oppure "Codice_Prodotto". In ogni caso, se vuoi utilizzare nomi di campo con spazi, nelle sintassi SQL devi servirti delle parentese quadrate per tenere unito il nome. Inoltre, il nome di un campo non deve essere inserito tra apici.
Al posti di:
SELECT Idraulica.Codice Prodotto FROM Idraulica WHERE ('Codice Prodotto' = '123')
usa:
SELECT Idraulica.[Codice Prodotto] FROM Idraulica WHERE ([Codice Prodotto] = '123')
__________________
Chi non cerca trova.
tas è offline   Rispondi citando il messaggio o parte di esso
Old 29-04-2003, 11:24   #3
prodan
Member
 
L'Avatar di prodan
 
Iscritto dal: Apr 2003
Messaggi: 177

Grazie per avermi risposto!!!
Per quato riguarda l'ordine sò di essere un pò disordinato, ma non avevo voglia di usare le tabulazioni!!!!Ankè se il programma risulterebbe più ordinato!!
LE due tabelle CC e MyTable sono due recordset e non
Public MyTable As Variant
Public CC As New ADODB.Recordset
Ma:
Public MyTable As New ADODB.Recordset Cordset
Public CC As New ADODB.Recordset Cordset
Po se non metto l'end if all'interno del case non funziona il prog!!!
Ora non sbatto più la testa nel muro perkè ieri mattina ho risolto tutti i problemi!!!Relativi alla sintassi dell'SQL, kè fino a ieri mi era poco kiara in quanto non scrivevo una stringa comprensibile dal basic in tempo di esecuzione durante l'istruzione ......execute()
Alla prossima perkè creo kè mi si presenteranno altri problemi!!!
Tra i quali stampare il contenuto di una tabella su carta mediante un report o altri vari modi!!!
prodan è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
Nutanix accelera la migrazione da VMware...
Nutanix apre ai neocloud: piattaforma mu...
Nutanix amplia la piattaforma cloud e st...
Le fotografie dell'eclissi solare e dell...
Oracle AI Database si potenzia con nuove...
Russia offline: blackout internet mobile...
Gemini, Google investe 30 milioni per la...
Roborock Qrevo Edge S5A: 17.000 Pa, acqu...
Resa pubblica la foto della ''Terra che ...
Il robot che ha piegato 200 scatole di f...
SteelSeries Aerox 3 Wireless Gen 2: nuov...
"Quasi sociopatico": Sam Altma...
Star Wars Eclipse in difficoltà: ...
Gestione del team e romance organiche: l...
Intel lancia Core Ultra X9 378H: hardwar...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 03:37.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v