How do you create a column with auto-numbering that can be used as a primary key? This is a very simple and probably...
By submitting your email address, you agree to receive emails regarding relevant topic offers from TechTarget and its partners. You can withdraw your consent at any time. Contact TechTarget at 275 Grove Street, Newton, MA.
very common problem. Here is a simple and universal procedure to do this.
1. Create a column in the table with the number datatype; this will be used to hold the auto-generated numbers.
2. Create a sequence that will keep track of the auto number value.
3. Create a trigger that will insert the next value of your auto number into the newly created column every time the new insert occurs.
4. Replace schima_name, sequence_name, trigger_name, table_name, column_name, with appropriate values, like this:
CREATE SEQUENCE schima_name.sequence_name INCREMENT BY 1 NOMAXVALUE MINVALUE 1 NOCYCLE CACHE 20 NOORDER; CREATE OR REPLACE TRIGGER schima_name.trigger_name BEFORE INSERT ON schima_name.table_name REFERENCING OLD AS OLD NEW AS NEW FOR EACH ROW BEGIN SELECT sequence_name.NEXTVAL INTO :NEW.column_name FROM DUAL; END;
For More Information
- What do you think about this tip? E-mail the Editor at firstname.lastname@example.org with your feedback.
- The Best Oracle Web Links: tips, tutorials, scripts, and more.
- Have an Oracle tip to offer your fellow DBA's and developers? The best tips submitted will receive a cool prize--submit your tip today!
- Ask your technical Oracle questions--or help out your peers by answering them--in our live discussion forums.
- Check out our Ask the Experts feature: Our SQL, database design, Oracle, SQL Server, DB2, metadata, and data warehousing gurus are waiting to answer your toughest questions.