Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations IamaSherpa on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

Unique ID

Status
Not open for further replies.

nikeloeleven

Programmer
Feb 15, 2005
32
GB
Hi there, i'm going to have primary fields for my database fields such as "Staff ID" where the IDs will be something like "S01" "S02" "S03" etc.... what datatype would you recommend using for this type of field???

I'm guessing Char because the field sizes will consistently be the same...?
Thanks
 
Well this system is for a school. I'm assuming there will never be more than 99 staff members in a school. Shall I therefore use Char(3) or is there another datatype you recommend Geoff?
 
Also, can you please explain to me where a Char should be used instead of Varchar...

and shall i use Varchar instead of Char when the field description doesn't have "not null"?
 
I'm assuming there will never be more than 99 staff members in a school
There might only be 30 staff in a school but you'll keep on using up IDs as these staff leave and new staff enter.

Do you really need the "S"? My default is to use an integer key (I've never yet run out of integers<g>). If the user needs a prefix like "S" or "Inv" then I just add it to the ID whenever I display it.

Geoff Franklin
 
can you explain to me how you make and use an integer key.... it would be helpful if it auto incremented like in Access...
 
It looks like your using Interbase, there is an Interbase Forum.

I recomend an integer field, and Interbase has the capability of building generators which keep track of the numbering. These generators you connect to triggers that fire whenever an event happens inside the database, like before or after posting a record.
A before post event is used to obtain an unique number.
a code snippet:
Code:
CREATE TABLE SURVEYS 
(
  SNUMBER	TAUTOINC,
  START_DATE	TIMESTAMP NOT NULL,
  END_DATE	TIMESTAMP,
  REMARKS	COMMENTS,
 PRIMARY KEY (SNUMBER)
);
SET TERM ^ ;


/* Triggers only will work for SQL triggers */

CREATE TRIGGER SURVEY_INSERT FOR SURVEYS 
ACTIVE BEFORE INSERT POSITION 0
AS BEGIN
  NEW.SNUMBER = GEN_ID(SURVEY_NUMBER_GEN,1);
END

An after post trigger can be used to notify other connected clients of table updates or generate a log..

Steven van Els
SAvanEls@cq-link.sr
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top