<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
		xmlns:xhtml="http://www.w3.org/1999/xhtml"
>

<channel>
	<title>仙人の心得 &#187; bigint</title>
	<atom:link href="http://blog.mktime.com/archive/tag/bigint/feed" rel="self" type="application/rss+xml" />
	<link>http://blog.mktime.com</link>
	<description>Just another WordPress weblog</description>
	<lastBuildDate>Tue, 31 Aug 2010 12:04:45 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.1</generator>
	<language>ja</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<xhtml:link rel="alternate" media="handheld" type="text/html" href="http://blog.mktime.com/archive/tag/bigint/feed" />
		<item>
		<title>MySQL:auto_incrementが最大値まで達したとき</title>
		<link>http://blog.mktime.com/archive/46.html</link>
		<comments>http://blog.mktime.com/archive/46.html#comments</comments>
		<pubDate>Sun, 27 Jul 2008 14:07:57 +0000</pubDate>
		<dc:creator>nak</dc:creator>
				<category><![CDATA[mysql]]></category>
		<category><![CDATA[bigint]]></category>
		<category><![CDATA[int]]></category>
		<category><![CDATA[sutoincrement]]></category>

		<guid isPermaLink="false">http://blog.mktime.com/?p=46</guid>
		<description><![CDATA[
auto_incrementにしたカラムの型がintなら2147483647、bigintなら9223372036854775807がautoincrementの最大になる。

実際に最大値までauto_increme [...]]]></description>
			<content:encoded><![CDATA[<p>
auto_incrementにしたカラムの型がintなら2147483647、bigintなら9223372036854775807がautoincrementの最大になる。<br />
<br />
実際に最大値までauto_incrementを進めてみる。<br />
<pre class="console">
 ALTER TABLE table1 AUTO_INCREMENT= 2147483647;
</pre>
auto_incrementが最大値に達するともうそのテーブルには行を追加することはできなくなります。<br />
<br />
oracleのシーケンスならCYCLEオプションがあるけどmysqlのauto_incrementにはそのような機能は無いらしい。<br />
<br />
ではauto_incrementが最大値に達したとき、どうすればよいのか？<br />
<br />
単純に<br />
<pre class="console">
 ALTER TABLE table1 AUTO_INCREMENT= 1;
</pre>
としても、table1に1より大きいキーが存在する限りauto_incrementは1に戻らない。<br />
<pre class="console">
 DELETE FROM table1; --データを全部消す。
 ALTER TABLE table1 AUTO_INCREMENT= 1;
</pre>
ならばauto_incrementは1に戻るので、循環シーケンスと似たような動きにするにはINSERTトリガーで<br />
<br />
1. 対象テーブルのauto_increment値が最大に達しているかチェック。最大なら2.へ<br />
2. 対象テーブルのデータを別テーブルに退避<br />
3. 対象テーブルのデータをDELETE<br />
4. ALTER TABLE～でauto_incrementを初期値に設定<br />
<br />
という流れになるけど、INSERTの度に1.のチェックを走らせるのはちょっと嫌（1/2147483647の為に余計な処理を入れたくない）。また、退避後のデータをどう扱うかも微妙（UNIONするにしても別のキーが要るし・・・）だから<br />
int autoincrementでキーの枯渇が心配ならbigint型にしたほうがよいと思う。<br />
bigintの最大値は9223372036854775807。intの約42億倍もある。<br />
これは1日に1億個のキーを消費しても2億年持つという計算になる。</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.mktime.com/archive/46.html/feed</wfw:commentRss>
		<slash:comments>1</slash:comments>
		<xhtml:link rel="alternate" media="handheld" type="text/html" href="http://blog.mktime.com/archive/46.html" />
	</item>
	</channel>
</rss>
