Landscape トップページ | < 前の日 2004-06-08 2004-06-09 次の日 2004-06-10 >

Landscape - エンジニアのメモ 2004-06-09

TRUNCATE にはオーナー権限が必要


* TRUNCATE にはオーナー権限が必要

この記事の直リンクURL: Permlink | この記事が属するカテゴリ: [Postgres]

夜間バッチ用の Perl スクリプトがうまく動かず、意図した結果にならないという相談を受けた。
テーブルのデータを洗い替えするため、TRUNCATE した後に CSV から読み込んだデータを INSERT していくという Perl スクリプトにおいて、洗い替えがなされないという症状だ。DB は Postgres。 バージョンは未確認だが、7.1 または 7.0 系列だったはず。DB 接続には Pg モジュールを使用。

スクリプトを見たところ、どうも TRUNCATE がうまくいってないような感じがした。スクリプトでは TRUNCATE を実行したときの結果をチェックしていないので、成功しても失敗してもその後の CSV からの INSERT を実行してしまうようだ。Google で TRUNCATE エラー postgres を検索すると、Postgres のメーリングリストの記事がヒット。

[pgsql-jp 21028] TRUNCATE 実行権を与える方法
http://ml.postgresql.jp/pgsql-jp-old/pgsql-jp/2001May/msg000 ...
標題の件ですが、TRUNCATEを実行する権限を
テーブル所有者以外に与える方法はないでしょうか。

GRANT ALL ON [テーブル名] TO [与えたいユーザー ]
ではTRUNCATE実行時に"所有権がない"旨のエラーがでます。

現在はやむを得ずDELETE文を使用していますが
ロールバックが必要になる処理ではないので、
可能であればTRUNCATEを使いたいと思っています。

PostgreSQL 7.0.3 on Vine LINUX 2.1.5

権限の問題の可能性あり。

psql で試してみた。GRANT ALL してもらってるテーブルに対して TRUNCATE を発行する。
hiroaki=> TRUNCATE TABLE the_world;
ERROR:  you do not own class "the_world"
あ、やっぱりダメだ。

hiroaki=> DELETE FROM the_world ;
DELETE 5
DELETE は問題なくできる。

PostgreSQL 7.1.3 ドキュメント(日本語版 1.6) には所有権が必要っていう記述はなかった。
http://osb.sra.co.jp/PostgreSQL/Manual/PostgreSQL-7.1-ja/sql ...

最新の 7.4.2 のドキュメントには参照整合性制約についての記述はあったが、権限についての記述はない。
PostgreSQL 7.4.2 リファレンス TRUNCATE
http://www.postgresql.jp/document/pg742doc/html/sql-truncate ...

すべての記事の見出し (全1029件)
全カテゴリの一覧と記事の数
カテゴリごとに記事をまとめ読みできます。記事の表題だけを見たい場合は、すべての記事の見出し (カテゴリ別表示) へ。

直近30日分の記事
2007-04-23 (Mon)
2007-03-07 (Wed)
2007-02-27 (Tue)
2007-01-17 (Wed)
2007-01-15 (Mon)
2007-01-14 (Sun)
2007-01-08 (Mon)
2006-12-01 (Fri)
2006-11-22 (Wed)
2006-11-20 (Mon)
2006-11-19 (Sun)
2006-09-30 (Sat)
2006-08-29 (Tue)
2006-08-04 (Fri)
2006-07-27 (Thu)
2006-07-23 (Sun)
2006-07-17 (Mon)
2006-07-10 (Mon)
2006-07-06 (Thu)
2006-07-03 (Mon)
2006-06-29 (Thu)
2006-06-28 (Wed)
2006-06-27 (Tue)
2006-06-25 (Sun)
2006-06-19 (Mon)
2006-06-18 (Sun)
2006-06-15 (Thu)
2006-06-11 (Sun)
2006-06-01 (Thu)
2006-05-30 (Tue)
プロファイル
斎藤 宏明。エンジニアです。宇都宮市に住んでいます。
リンク
RSS
スポンサードリンク
Powered by
さくらインターネット

© 斎藤 宏明 Saito Hiroaki Gmail Address
Landscape - エンジニアのメモ http://sonic64.com/
Landscape はランドスケープと読みます。
ひらがなだと らんどすけーぷ です。