Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità
ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità
NUC 15 Pro e NUC 15 Pro+ sono i due nuovi mini-PC di casa ASUS pensati per uffici e piccole medie imprese. Compatti, potenti e pieni di porte per la massima flessibilità, le due proposte rispondono in pieno alle esigenze attuali e future grazie a una CPU con grafica integrata, accompagnata da una NPU per la gestione di alcuni compiti AI in locale.
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Dal palco di Proofpoint Protect 2025 emerge la strategia per estendere la protezione dagli utenti agli agenti IA con il lancio di Satori Agents, nuove soluzioni di governance dei dati e partnership rafforzate che ridisegnano il panorama della cybersecurity
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Dopo alcuni anni di assenza dai cataloghi dei suoi televisori, Hisense riporta sul mercato una proposta OLED che punta tutto sul rapporto qualità prezzo. Hisense 55A85N è un televisore completo e versatile che riesce a convincere anche senza raggiungere le vette di televisori di altra fascia (e altro prezzo)
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-08-2003, 10: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, 10: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, 10: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, 13: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, 10: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, 03: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, 12: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


ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondo...
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint Cybersecurity: email, utenti e agenti IA, la nuo...
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti Hisense A85N: il ritorno all’OLED è convi...
Acer TravelMate P6 14 AI: il Copilot+ PC sotto il chilo per il professionista in movimento Acer TravelMate P6 14 AI: il Copilot+ PC sotto i...
Recensione Borderlands 4, tra divertimento e problemi tecnici Recensione Borderlands 4, tra divertimento e pro...
Tante novità in arrivo per OnePlu...
Novità per la smarthome da EZVIZ....
Intel SGX e AMD SEV-SNP aggirabili su pi...
Autovelox, parte il censimento ufficiale...
Adobe Premiere arriva su iPhone: l'app &...
Il Cybertruck di Tesla non può es...
Windows 11 25H2 è stato appena ri...
VMware, con la versione 9 di Cloud Found...
Area B e C Milano, stop alle auto benzin...
Huawei FreeBuds 7i arrivano in Italia: c...
Offerte Amazon Fire TV: smart TV per ogn...
iPhone 11 Pro Max e Apple Watch Series 3...
Toyota ha venduto solo 18 elettriche ad ...
Tutti i Ring in promo Amazon: videocitof...
Taiwan respinge la richiesta USA di tras...
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: 11:32.


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