人力検索はてな
モバイル版を表示しています。PC版はこちら
i-mobile

mysqldump -d でデータベースの定義が吐き出せると思うのですがAUTO_INCREMENT=Xの値が不要です。
定義だけ出す方法を教えてください。

↓の例でいうところの、
AUTO_INCREMENT=2
が不要です。

CREATE TABLE `diary` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`member_id` int(11) NOT NULL,
`title` text NOT NULL,
`body` text NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

●質問者: rysk92
●カテゴリ:コンピュータ インターネット
✍キーワード:BODY ENGINE innodb Key データベース
○ 状態 :終了
└ 回答数 : 2/2件

▽最新の回答へ

1 ● a-kuma3
●35ポイント

unix 系の OS だとして、↓ということ?

% mysqldump -d ... | sed -e 's/AUTO_INCREMENT=[0-9]*//'

オプションでも何とかできるのかもしれないけど、削っちゃいたいものがはっきりしてるなら、削った方が面倒が無いかな、なんて。


http://dev.mysql.com/doc/refman/5.1/ja/mysqldump.html


2 ● typista
●35ポイント

http://d.hatena.ne.jp/sakaik/20101029/dangerous_mysqldump

http://kwappa.txt-nifty.com/blog/2010/02/mysql-ebf8.html

MySQL独自オプションを外す指定は可能ですが、ENGINE=InnoDB も一緒に

無くなってしまうので、1番目の回答者の方のようにsedで文字列置換

するほかなさそうです。

ENGINE=InnoDB も一緒に無くなってしまって良いなら

mysqldump -d --skip-create-options

です。

関連質問


●質問をもっと探す●



0.人力検索はてなトップ
8.このページを友達に紹介
9.このページの先頭へ
対応機種一覧
お問い合わせ
ヘルプ/お知らせ
ログイン
無料ユーザー登録
はてなトップ