|
|
|
![]() |
|
Strumenti |
![]() |
#1 | |
Senior Member
Iscritto dal: Jun 2005
Città: bari
Messaggi: 470
|
Creare un sistema di numerazione progressiva automatica in un campo testo di Access
Non so se questa è la sezione giusta per esporre il mio problema... tuttavia:
quello che vorrei fare è di creare un sistema di numerazione progressiva automatica in un campo testo di Access. Il campo rappresenta un codice identificativo composto da 5 cifre progressive e da quattro cifre indicanti l'anno: es.: 00001/1999; 00002/1999; 00003/1999; 00001/2000; 00002/2000 ecc. ecco le caratteristiche del campo sul quale creare un sistema automatico di avanzamento correlato all'anno: ![]() su http://www.sitocomune.com/ nella voce del menù GENERAL ho trovato questo: 6.17 Numerazione crescente per fatture ed altro. URL http://www.sitocomune.com/general/general017.htm Io ho provato a inserire in "Valore predefinito" quanto segue, ricavato dalle indicazioni fornite sul sito: Quote:
Perché mi dà questo errore? Lo posso aggirare in qualche modo? Qualcuno conosce un altro sistema per risolvere il mio problema? Ultima modifica di simonzo : 04-02-2006 alle 15:30. |
|
![]() |
![]() |
![]() |
#2 | |
Senior Member
Iscritto dal: Jun 2005
Città: bari
Messaggi: 470
|
Quote:
Questa è l'espressione corretta che bisognerebbe inserire nel campo ID però non nella Tabella (ecco perché mi dava l'errore ![]() Tuttavia questo non risolve il problema in quanto è vero che mi dà in automatico il numero progressivo, ma assegna anche come anno fisso il 2006 ed invece io voglio poter inserire l'anno e poi, andando nel campo da compilare successivo, avere il numero progressivo esatto. Poi vorrei sapere: se lascio questa espressione, cosa succede nel 2007? Mi conserva i record inseriti negli anni precedenti o vanno persi? |
|
![]() |
![]() |
![]() |
#3 |
Senior Member
Iscritto dal: Jun 2005
Città: bari
Messaggi: 470
|
nessuno sa darmi una risposta?
![]() |
![]() |
![]() |
![]() |
#4 |
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Mmmhhh...suddividi i campi anno e id progressivo... Poi fai una chiave composta da entrambi gli attributi e sei a cavallo...
|
![]() |
![]() |
![]() |
#5 | |
Senior Member
Iscritto dal: Jun 2005
Città: bari
Messaggi: 470
|
Quote:
Se non ho capito male dovrei creare due campi diversi: ID Codice: Testo, Dupl. non amm.; Maschera di Input: 99999\/. ID Anno: Testo, Dupl. non amm.; Maschera di Input: 9999;0;#. Quindi dovrei creare un terzo campo cui assegnare la chiave primaria e che dovrebbe prelevare i valori dagli altri due campi? Oppure devo semplicemente assegnare un'espressione nella maschera, in corrispondenza del campo dove voglio che "appaia" il codice composto da "ID Codice" e da "ID Anno" (99999\/9999;0;#)? Ho un altro campo a disposizione che forse potrebbe servire: il tipo di dati è Data/ora e la maschera di input è "00/00/0000;0;_". Ovviamente l'anno di questo campo corrisponde a l'anno che deve apparire nel codice di ogni record, quindi potrei servirmene per fare assegnare in maniera automatica un numero progressivo e per far prelevare le ultime 4 cifre della data da inserire come anno e nel caso come si fa per fargli tener conto di tutti gli altri record dello stesso anno e avere il numero giusto ogni volta? forse non è molto chiaro ![]() spero che si riesca a capire ![]() grazie per l'interessamento ![]() Ultima modifica di simonzo : 06-02-2006 alle 19:30. |
|
![]() |
![]() |
![]() |
#6 |
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Io intendevo un semplice campo Anno e un campo IDProgressivo...
Poi dopo selezioni le righe relative ai due campi e li setti come Chiave Primaria... Ecco, a questo punto la coppia Anno/Progressivo non può essere ripetuta all'interno del database... Poi dalla maschera l'unica cosa che dovrai fare quando crei una nuova fattura è incrementare il progressivo... |
![]() |
![]() |
![]() |
#7 | |
Senior Member
Iscritto dal: Jun 2005
Città: bari
Messaggi: 470
|
Quote:
![]() Si tratta di un archivio per cartelle cliniche. Il problema è che ad ogni paziente deve essere assegnato un codice identificativo composto esattamente da un numero progressivo e dall'anno (00001/2000) ed il numero progressivo deve ripartire da 1 per ogni anno (00001/1999; 00002/1999....10000/1999; 00001/2000; 00001/2001 ecc.). L'espressione ="" & Format(IIf(IsNull(DMax("[ID]";"[Cartella clinica Generale]";"[ID] like '?????/" & Format(Date();"aaaa") & "'"));1;Mid(DMax("[ID]";"[Cartella clinica Generale]";"[ID] like '?????/" & Format(Date();"aaaa") & "'");1;5)+1);"00000") & "/" & Format(Date();"aaaa") inserita nel "valore predefinito" della maschera che richiama la Tabella (Cartella Clinica Generale) funziona egregiamente nel caso si inseriscano nuovi pazienti dell'anno in corso e penso che dovrebbe funzionare bene anche in futuro (nel 2007, 2008...2020 ![]() Il problema fontamentale è che io adesso devo inserire 2 o 3000 cartelle che vanno dal 1997 al 2006 e purtroppo il materiale cartaceo è stato ordinato in modo alfabetico e non in base all'anno ![]() Vorrei evitare di separae i due campi anche perché il database è praticamente finito e sono state impostate tutte le relazioni e non vorrei ricominciare da zero... sono convinto che deve esserci un modo per far assegnare automaticamente il numero una volta inserito l'anno nelle ultime quattro posizioni del campo oppure una volta inserita la data nell'altro campo di cui parlavo e da cui il campo "ID Codice/Anno" potrebbe prelevare in automatico le quattro cifre della data corrispondenti all'anno e poi assegnare il numero progressivo giusto confrontando il record con tutti gli altri record dello stesso anno (e quindi il numero del nuovo record dell'anno x sarà uguale al numero più alto dello stesso anno x aumentato di 1). E' giusto? Io purtroppo non conosco linguaggi di programmazione e non saprei da dove cominciare ![]() |
|
![]() |
![]() |
![]() |
#8 |
Senior Member
Iscritto dal: Jun 2005
Città: bari
Messaggi: 470
|
non c'è nessuno che mi può aiutare?
|
![]() |
![]() |
![]() |
#9 |
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Il discorso non cambia... Può essere qualsiasi cosa...ma mi sembra che nel modo in cui ti ho detto io sia la soluzione migliore...
|
![]() |
![]() |
![]() |
#10 |
Senior Member
Iscritto dal: Jun 2005
Città: bari
Messaggi: 470
|
ma non c'è nessun altro modo?
|
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 16:30.