Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Abbiamo provato per voi il nuovo DLC lanciato a sorpresa da Blizzard per Diablo II: Resurrected e quella che segue è una disamina dei nuovi contenuti che abbiamo avuto modo di sperimentare nel corso delle nostre sessioni di gioco, con particolare riguardo per la nuova classe dello Stregone
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Siamo tornati nel parco tecnologico di Trieste per il kick-off del programma che mette a disposizione di cinque startup le infrastrutture di ricerca, dal sincrotrone Elettra ai laboratori di genomica e HPC. Roberto Pillon racconta il modello e la visione
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo
HP OMEN MAX 16-ak0001nl combina RTX 5080 Laptop e Ryzen AI 9 HX 375 in un desktop replacement potente e ben raffreddato, con display 240 Hz e dotazione completa. Autonomia limitata e calibrazione non perfetta frenano l'entusiasmo, ma a 2.609 euro è tra le proposte più interessanti della categoria.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-08-2003, 11:00   #1
dr.stein
Registered User
 
Iscritto dal: Dec 2001
Messaggi: 890
[ACCESS-VBA] Passare un Null come parametro....

Ciao!
Ho questo problema!

Ho questa funzione:

Codice PHP:
Function Formatta(ByVal Str As StringByVal Lung As Integer) As String
        
    
If IsNull(StrThen
        Formatta 
String(Lung" ")
    Else
        
Formatta Str String(Lung Len(Str), " ")
    
End If
    
End Function 
Al quale io passo una stringa e un numero!
Il numero rappresenta la lunghezza fissa che deve avere la stringa restituita!

Ovvero, se io passo "ABC" e 5, mi restituisce "ABC--" (dove - sono spazi), se passo "A" e 5 ho "A-----"

Nel caso la stringa sia vuota, ricevo una stringa di tanti spazi quanto e' il numero del secondo parametro.
Stesso funzionamento dovrebbe avere nel caso di stringa nulla!

Ora esaminiamo il pezzo di codice che richiama questa funzione:

Codice PHP:
Dim Query As Object
Set Query 
CurrentDb.OpenRecordset("INGRESSO")

Dim Riga As String

Riga 
""

.... CUT ....

Riga Riga Formatta(Query!CognomeContr25
INGRESSO e' il nome di una tabella dove ho memorizzati tutti i dati

Ora, il campo CognomeContr e' un campo testo da 25 caratteri, quindi posso avere al suo interno una stringa che va da 0 a 25 caratteri, oppure Null!

Qual'e' il problema ?

Nel caso ci sia Null, Access mi risponde:

Codice PHP:
Errore di runtime '94':

Utilizzo non valido di Null 
Come posso passare Null come parametro ad una funzione ?

Altre idee per risolvere il problema ?

Thx!
dr.stein è offline   Rispondi citando il messaggio o parte di esso
Old 29-08-2003, 11:16   #2
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
String non può essere Null. Devi usare il tipo Variant.
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 29-08-2003, 11:21   #3
dr.stein
Registered User
 
Iscritto dal: Dec 2001
Messaggi: 890
Quote:
Originariamente inviato da ilsensine
String non può essere Null. Devi usare il tipo Variant.
DOH!!!!

Ma ho fatto tanto per evitare il Variant!!!!

Grazie!
dr.stein è offline   Rispondi citando il messaggio o parte di esso
Old 29-08-2003, 14:18   #4
cisky
Member
 
L'Avatar di cisky
 
Iscritto dal: Aug 2001
Città: Gerenzano
Messaggi: 129
Ti consiglio di crearti una comoda funzione che ti gestisce l'uso del Null con le stringhe
Codice:
Function NullStr(v As Variant) As String
    If IsNull(v) Then
        NullStr = ""
    Else
        NullStr = CStr(v)
    End If
End Function
Es: Riga = Riga + Formatta(NullStr(Query!CognomeContr), 25)

Ciao!
__________________
E' quasi tutto relativo!
cisky è offline   Rispondi citando il messaggio o parte di esso
Old 30-08-2003, 11:12   #5
dr.stein
Registered User
 
Iscritto dal: Dec 2001
Messaggi: 890
Quote:
Originariamente inviato da cisky
Ti consiglio di crearti una comoda funzione che ti gestisce l'uso del Null con le stringhe
Codice:
Function NullStr(v As Variant) As String
    If IsNull(v) Then
        NullStr = ""
    Else
        NullStr = CStr(v)
    End If
End Function
Es: Riga = Riga + Formatta(NullStr(Query!CognomeContr), 25)

Ciao!
Uhm... e' un'idea...
ma non e' ridondante a quel punto ?
dr.stein è offline   Rispondi citando il messaggio o parte di esso
Old 31-08-2003, 04:12   #6
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
Re: [ACCESS-VBA] Passare un Null come parametro....

Quote:
Originariamente inviato da dr.stein
Ciao!
Ho questo problema!

....
Se non hai problemi puristico-tipologico di derivazione pascalina (il variant non lo voglio no ! - ma d'altra parte "Null è un sottotipo di Variant utilizzato per indicare che un elemento non contiene dati validi") ti propongo questa più corta e con l'uso della negletta Istruzione Mid (non la Funzione):

Codice:
Function Formatta1(ByVal Str As Variant, ByVal Lung As Integer) As String
         
 Formatta1 = String(Lung, " ")
 If Not IsNull(Str) Then Mid(Formatta1, 1) = Str
     
End Function
a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 01-09-2003, 13:59   #7
cisky
Member
 
L'Avatar di cisky
 
Iscritto dal: Aug 2001
Città: Gerenzano
Messaggi: 129
Quote:
Originariamente inviato da dr.stein
Uhm... e' un'idea...
ma non e' ridondante a quel punto ?

Beh, sicuramente è ridondante ...

... nel senso che và utilizzata per ogni lettura da un campo del Recordset che accetti valori a Null.

Secondo mè il controllo dei valori a Null in fase di recupero dati dal DB è sempre da tenere in considerazione per evitare spiacevoli sorprese con i valori Null; quindi preferisco sempre utilizzare data type non variant nelle routine (Quando è possibile!).
__________________
E' quasi tutto relativo!
cisky è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026 6G, da rete che trasporta dati a rete intelligen...
Amazon, -20% extra su migliaia di prodot...
Firefox per Windows 7 sarà suppor...
La nuova Xiaomi SU7 è pronta: nuo...
Gli agenti IA di Google entrano in servi...
Sconti sulle low cost: 2 scope elettrich...
DDR5 oltre i 10.000 MT/s: ecco le schede...
Questi elettrodomestici vanno a ruba su ...
Il trailer di lancio di Crimson Desert m...
Auto elettriche più economiche? I...
Le 10 offerte di Primavera Amazon su cui...
Amazon svende i robot aspirapolvere: Dre...
L'ex capo di Windows ha elogiato il MacB...
Se manca questo gas, le fabbriche di chi...
NVIDIA celebra 25 anni di GeForce 3: per...
Leapmotor B10: arrivano Android Auto e A...
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: 09:34.


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