Re: How to generate sequence in MySql
create a real sequence as follows:
"""
create table sequence (
name varchar(64) primary key,
last_val int unsigned not null
) engine=myisam;
INSERT INTO sequence (name, last_val) VALUES ('seq', 0);
"""
now when you want to get the next number in the sequence do:
"""
UPDATE sequence SET last_val=@val:=last_val+1 WHERE name='table_changes';
"""
the key here is that the sequence table is myisam, and so does not respect transactions. if you use a table that respects transactions, you will block when there are multiple transactions trying to get a sequence, whereas what you want is to just get a sequence.
Subject
Views
Written By
Posted
167132
March 13, 2007 08:05AM
73256
March 22, 2007 10:34PM
66780
March 26, 2007 08:49AM
53408
March 26, 2007 09:31PM
30715
April 04, 2007 03:00AM
24372
April 05, 2007 02:37AM
21382
November 10, 2008 06:40AM
26341
November 21, 2007 03:50AM
Re: How to generate sequence in MySql
30051
January 29, 2008 08:33PM
17527
February 06, 2008 12:16PM
18324
October 15, 2008 01:03PM
12254
November 05, 2008 09:50AM
14065
November 10, 2008 06:32AM
15432
December 14, 2008 07:08AM
18233
January 23, 2009 05:38PM
8503
March 16, 2009 09:00AM
10182
March 16, 2009 09:18AM
8404
March 16, 2009 09:51AM
9290
March 16, 2009 10:23AM
8258
April 12, 2009 07:58AM
9809
April 03, 2009 03:07PM
Sorry, you can't reply to this topic. It has been closed.
Content reproduced on this site is the property of the respective copyright holders.
It is not reviewed in advance by Oracle and does not necessarily represent the opinion
of Oracle or any other party.