[表示 : 全て 最新50 1-99 101- 201- 301- 401- 501- 601- 2chのread.cgiへ]
Update time : 05/09 11:31 / Filesize : 193 KB / Number-of Response : 651
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

PostgreSQL 2テーブル目



1 名前:nobodyさん [03/03/11 02:34 ID:9JR4latc]
PostgreSQLについて語って2万テーブルをめざしましょう。
関連アプリケーション特有の話題は、以下のスレッドへ。
pgsql-mlのヲチもここで。

前スレ
[PostgreSQL]
pc2.2ch.net/test/read.cgi/php/989375812/

☆関連スレッド
[PHP + PostgreSQL]
pc2.2ch.net/test/read.cgi/php/983128806/
[PerlでPostgreSQL]
pc2.2ch.net/test/read.cgi/php/999249463/
[MySQL vs PostgreSQL]
pc2.2ch.net/test/read.cgi/php/989341364/



196 名前:195の続き [03/05/27 17:46 ID:dZ0fIA92]

つまり上の例からSQL文で取得した結果を
id   name   point   date
4    え     0    5月27日 (3日以内のものが上にきている)
5    お    10    5月26日 (3日以内)
3    う     22    5月5日 (↓それ以外はpointの降順)
1    あ     5     5月1日
2    い     1    5月16日
という風にしたいのです。しかし、SQL文が思いつきません。
select * from (
(select * from テーブル名 where (検索条件) and dateが3日以内 )
UNION
(select * from テーブル名 where (検索条件) )
) order by date desc , point desc;
のようにしても、dateの降順になるだけでした。
(検索条件)というのは今回ある条件でレコードを引っ張ってくるので
その条件のことなのですが、これは非常に処理が重く
なんとか1回ですませられないかとも思っています。

長文になってしまいましたが、アドバイスをよろしくおねがいします。
あつかましくてすみません・・・

197 名前:nobodyさん mailto:sage [03/05/27 18:23 ID:???]
>>196
UNIONって実践で使おうとして結局ボツにした事しかないから
あんまり詳しい挙動は良くわかんないんだけど、

(select * from テーブル名 where (検索条件) and dateが3日以内 )

(select * from テーブル名 where (検索条件)
をくっつけるってことは、distinctかけるか"(検索条件)and dateが3日以上前"
にしないと重複行がでるような。。


あと、"くっつけた後"のレコードに対してorder by date desc , point desc;してるんだから、
この時点で3日以内のレコードが一番上とか関係ないし。

(select * from テーブル名 where (検索条件) and dateが3日以内 )
という結果と
(select * from テーブル名 where (検索条件) and dateが3日以上前 order by date desc , point desc);
という結果をUNIONしないとだめっぽ。


それ以前に、単純に新しい日付順に並べるのが一番楽だろうになんでまたこんな奇怪な
仕様になってるんですか?
印刷するにしてもブラウザに表示するにしても、一言注意書きが必要になっちゃうような
インターフェースは避けるべきかと。

日常的に直近3日のデータしか使わないようなら、(Webアプリなら)直近3日を表示するページを作って、
全体表示をするページへのリンクを貼るようにするとか仕様変更も検討しては?

198 名前:nobodyさん mailto:sage [03/05/27 19:33 ID:???]
今197がいいこと言った!!!

199 名前:nobodyさん [03/05/28 12:30 ID:37obhOpS]
>>196
select * from
(select *,1 AS tmp from テーブル名 where (検索条件) and dateが3日以内 )
union
(select *,2 AS tmp from テーブル名 where (検索条件)
order by tmp, date desc , point desc
ってのは?

200 名前:あぼーん mailto:あぼーん [あぼーん]
あぼーん

201 名前:あぼーん mailto:あぼーん [あぼーん]
あぼーん

202 名前:nobodyさん mailto:sage [03/05/28 13:41 ID:???]
単発で質問スレを立てないように。終了。

203 名前:195 [03/05/28 20:14 ID:8u4ScsfX]
>>197さん
変な質問に付き合っていただき、どうもありがとうございます。
確かに、おっしゃるとおりでした。最後のソートがよくないです
UNIONは和集合なので、一応重複したレコードは1つになります。
結局、
select * from (
(select * from テーブル名 where (検索条件) and dateが3日以内 )order by date desc
UNION ALL
(select * from テーブル名 where (検索条件) )order by point desc;
)
のようにしているのが現状です。UNION ALLだと、そのままくっつけてくれて、
検索条件のところで互いに重ならないような条件をくわえています。

これ、確かに設計がわるいです・・
たとえば、検索エンジンで、新し物を表示し、アクセスうが多いものを
表示しようという嗜好なのですが・

204 名前:nobodyさん [03/05/29 00:24 ID:l3/TekvE]
PostgreSQL 7.3.3 Now Available for Download
Posted on 2003-05-27 by press@postgresql.org

The PostgreSQL Global Development Group has released PostgreSQL 7.3.3.
It is highly recommended that those running earlier version of the 7.3
branch upgrade at their earliest convenience.

www.t.ring.gr.jp/archives/misc/db/postgresql/source/v7.3.3/



205 名前:nobodyさん mailto:sage [03/05/29 17:54 ID:???]
squid で proxy 作って、WEB 見るときはそれを使うようにした。
そしたら、日本 PostgreSQL ユーザー会のページ(postgresql.jp)が見れなくなった。
他のページは見れるし、proxy 外したらユーザー会のページもOKなのに。
なんでだろう。

・・・スレ違いだね。ごめん。

206 名前:あぼーん mailto:あぼーん [あぼーん]
あぼーん

207 名前:あぼーん mailto:あぼーん [あぼーん]
あぼーん

208 名前:nobodyさん [03/05/31 23:38 ID:NfBpY+67]
Release rush ですね

>>204
postgresql 7.3.3
php 4.3.2


...Mozilla 1.4 RC1

209 名前:nobodyさん [03/06/03 11:27 ID:LFu6QbCl]
こんにちは。

decimal型で、&演算子を用いて演算する方法は無いでしょうか?
1ビットごとに意味を持たせておいて、&でマスクをかけて検索している
のですが、int8の64ビットだと、64種類までなので、
それては不足しています。

そこで、decimal型でやりたいのですが、int型しか&を使えない
というエラーが出てしまいます。intにcastしても、その時点で
int8の最大値を超えているとエラーが出てしまうので、
困っています。

よい解決方法がありましたら、ご教授ください。

210 名前:nobodyさん mailto:sage [03/06/03 14:50 ID:???]
bit型を使うわけにはいけない?
もしくはバイナリをつっこむとか。
文字列で表現する方法もあるし。

そもそもdecimalのデータ格納効率はintなどと比べて悪いんじゃない?

211 名前:209 [03/06/03 16:24 ID:LFu6QbCl]
そうだったんですか・・・ありがとうございます。
indexをはりたかったので、decimalでしました。
いろいろやった結果、
floor ( decimalカラム / 探したい数値 ) % 2 = 1
という式でなりました。お世話になりました(^^

格納効率も、次回から考慮してみますね

212 名前:あぼーん mailto:あぼーん [あぼーん]
あぼーん

213 名前:nobodyさん [03/06/04 14:29 ID:7jLojF8m]
PostgreSQL7.3.2です。

あるDBへ接続できなくなってしまいました。
psql sample
とすると、
psql: FATAL: catalog is missing 5 attribute(s) for relid 1262

と出てしまいます。pg_dumpとろうとしても、

pg_dump: [archiver (db)] connection to database "sample" failed: FATAL: catalog is missing 5 attribute(s) for relid 1262
と出てしまいます。

バックアップはとっていません。。削除するわけにもいかない事情があります。
どうにかして復旧することはできませんか。。。
(つか、意外にひ弱なPostgreSQL?)


214 名前:あぼーん mailto:あぼーん [あぼーん]
あぼーん



215 名前:nobodyさん [03/06/04 14:45 ID:ulcLr4fi]
でいつWindows版は出るわけ?

216 名前:nobodyさん mailto:sage [03/06/04 18:24 ID:???]
>>215
osb.sra.co.jp/PowerGres/index.php

217 名前:nobodyさん mailto:sage [03/06/04 22:45 ID:???]
7.4はWindowsでもビルドできるって?

218 名前:213 [03/06/05 00:19 ID:tKeK+oMF]
213です。すんません、どなたか>>213の解決策、ご存じの方いらっしゃいませんか…まじ困ってます(;´Д`)
Google探しまくってますが有効策みあたりません。。
おながいします"_m(_'_)m_"


219 名前:nobodyさん [03/06/05 00:52 ID:eid+uK9F]
こんばんは。
CREATE TABLE heaven (
name text,
karma int
);

karmaを10下げる関数を書いたんですけど、そんなこと
しなくても単純なSQL文で実行出来ますか?後学のため
に教えてください。

UPDATE heaven SET kerma = kerma - 10 WHERE name = 'hoge';

みたいなことがしたいんです。。


220 名前:nobodyさん mailto:sage [03/06/05 00:53 ID:???]
>>219
やってみたら出来た。試す前に投稿した自分を許して下さい。。

221 名前:nobodyさん mailto:sage [03/06/05 02:28 ID:???]
>>213
カタログ情報が壊れているのかな
なんか相当ヘンなことしなかった?

>バックアップはとっていません。。

日時のダンプくらい取れYO・・・

>(つか、意外にひ弱なPostgreSQL?)

他人のせいにして・・・
もうダメぽ・・・

データファイルから本体のデータを復旧するツールってないのかな?
もしなくても
デキる香具師なら
ソース読んで2,3日で作れそうだが

222 名前:213 [03/06/05 09:20 ID:8BFr2soT]
>>221
>>日時のダンプくらい取れYO・・・

そのとーりです。はい。取る前におきてしまったんでつ。もう、どうしようもないです。

>>他人のせいにして・・・

それが私の特徴です(←こら AccessとかMS-SQL Server2000じゃこんなことゼッタイ無かったのにぃ〜と嘆いています。

使い始めて9日目…やっぱ復旧ツールって無いんですね…これこそダメぽ……

223 名前:nobodyさん mailto:sage [03/06/05 11:49 ID:???]
Jet使うとしょっちゅう壊れると思うんだが。
復旧できるからまだしも、そうでなかったらどうしようもない。

224 名前:nobodyさん [03/06/10 15:30 ID:+sYGrsNt]
windowsからlinux上にインストールしたpostgresqlサーバに
アクセスして、テーブルとかをいじれるツールってあるのでせうか?

ODBCとか使って、accessからアクセスできないかななんちゃって(サムイ



225 名前:nobodyさん mailto:sage [03/06/10 16:13 ID:???]
>>224
access は知らんが、CSE はできる。

226 名前:nobodyさん mailto:sage [03/06/10 18:37 ID:???]
>>224
激しくできます。ぐぐって見てください。

227 名前:224 mailto:sage [03/06/11 01:48 ID:???]
>>225
CSE試してみました。
まだじっくりいじっていないのですが、
SQLコマンドを打ち込む補助ツールのようですね。
SQL初心者には、まだまだわからないことがいっぱいです。
もっと、GUIでテーブル操作とか、リレーションとかしてみたいです。

>>226
ありました!
ttp://www.hizlab.net/app/pgwin.html
こことかで解説みて、成功しましたが、
テーブルの作成やプロパティの変更、クエリの作成などは
出来ないのエスね。。。

228 名前:nobodyさん [03/06/11 12:40 ID:dVQT51zl]
>>227
access server を買って使ってくれ・・・

229 名前:postgresql勉強始めました [03/06/12 23:09 ID:aCqR/moW]
ここで、質問しても良いのでしょうか・・・?

postgresqlの勉強を始めたばかりで、わからないことばかりなのですが、
いったん作成したテーブルに、新たな列を後から追加・削除することは可能でしょうか?



230 名前:nobodyさん [03/06/12 23:30 ID:b2p7Tjjy]
>>229
バージョンによるが、可能。
詳しくは >>179 のドキュメントに書いてあるよ。


231 名前:nobodyさん mailto:sage [03/06/12 23:30 ID:???]
ALTER TABLEを使う
ttp://www.postgresql.jp/document/pg732doc/user/ddl-alter.html

基本的なことは>>2のユーザー会のマニュアルを見るべし。
DBは突っ込んで勉強するとけっこう深い。ガンガレ

232 名前:231 mailto:sage [03/06/12 23:31 ID:???]
かぶったーよ

233 名前:nobodyさん mailto:sage [03/06/12 23:37 ID:???]
>>1 のテンプレにはマニュアルへのリンクを張った方が良いな。
前スレへのリンクはあまり利用価値が無いと思う。


234 名前:nobodyさん [03/06/14 02:40 ID:8UJU9HVd]
initlocationをつかって、
DBの作成する場所を変えようと思ってるんだけど、
なんかしんないけど、
エラー出るんですよ。
誰かわかりますかね。

su - postgres
export PGDATA2=/var/lib/pgsql/data
initlocation PGDATA2
createdb test -D 'PGDATA2'

ERROR: Postmaster environment variable 'PGDATA2' not set
createdb: database creation failed





235 名前:234 [03/06/14 04:22 ID:8UJU9HVd]
234です。
事故解決しました。

postmasterを起動するときに、
export も同時にやるとうまくいったよ。


236 名前:  mailto: [03/06/16 16:41 ID:???]
すいません、PHP + PostgreSQL スレにも書いたんですけど
あまり人いないようなのでこちらにもお邪魔させてください。

別の外注が作ったシステムの移行を頼まれたのですが、
PostgreSQL 7.2 ⇒ 7.3 での非互換な項目

 空の文字列 ('') は、整数フィールドに対する入力として
 許可されなくなりました。 以前は、これは暗黙的に 0 と
 解釈されていました。

に引っ掛かってしまいました。べらぼうな数のテーブルと
べらぼうな数のPHPソースがあり、これを一つ一つ

$SQL = "UPDATE table SET int_value = '$int_value'";

から例えば

$int_value += 0;
$SQL = "UPDATE table SET int_value = $int_value";

のような感じに変更するのはかなり厳しい状況です。

バージョンを下げる以外に何か対応策はないですかね?
postgresql.conf とかで切り替えられたらいいんですが。。。

237 名前:nobodyさん mailto:sage [03/06/16 17:27 ID:???]
>>236
コピペ?
あまりにも典型的なハマリ(ry

もし実話だったら
とりあえず新幹線に乗って
京都・奈良で寺巡りでもして来い

壮大な歴史の中では
自分がいかにちっぽけな存在であるか
よーく分かるはずだ

238 名前:nobodyさん mailto:sage [03/06/16 23:54 ID:???]
>>236
まぁ、Postgresのバージョン間の互換性には期待するな、ということで。

239 名前:236 mailto: [03/06/17 16:12 ID:???]
>>237
違うよ。はまりたくてはまってるわけではないけど
頼むから register_globals を期待しないで欲しい>前の業者

>>238
漏れは期待してません。PHPに関しても然り。
その上でどうやったらこの問題を解決できるか知りたいのれす。
神はここにはいらっしゃいませんか。

240 名前:あぼーん mailto:あぼーん [あぼーん]
あぼーん

241 名前:nobodyさん mailto:sage [03/06/17 19:28 ID:???]
>>239
整数のフィールドを持つテーブルに対して、一つ一つトリガを作るとか。
手間はかかるがコードの修正よりは単純作業だし、漏れが出にくいよ(w
UPDATEやINSERTが必ず通る道で待ち伏せするわけだから。

テーブルの一覧をざっと眺めて、半日なり1日なり単純作業をすれば見切り発車はできるかと。
で、後からじっくりマターリとコードを直して行く。。。
すんごい小手先だけど、コード多い・時間無い・エラーが出るのはマズイって状況なら
これぐらいしか思いつかん。

設定で一発でなんとかできりゃあ良いんだろうけど、俺は知りませぬ。


#もしシステムのユーザが一般人ではなくてオペレータとかだったら、「空白入れんなヴォケ!」
#ってマニュアル対応で逃(ry

242 名前:236 mailto:sage [03/06/17 19:32 ID:???]
なるほど、トリガですか。何とかなるかな…
ちょっと盲点だったかもしれません。
ありがとうございます、助かりました。

243 名前:nobodyさん [03/06/18 02:42 ID:SST1kRd8]
Win2Kに cygwin で PostgreSQL7.3 をインストールして、同じ端末につみきWEBのCSEをインストールしました。
で、データベースに接続しようとしたところ

FATAL 1: Database ""testdb"" does not exist in the system catalog

というエラーが発生して繋がりません。

他のSQLエディタで(psqledit)設定を一緒にしたところ、うまくつながりました。
なので、データベース名を囲むダブルクオテーションが二重になってるのが原因だと思うのですが、同じところでハマって居る人いませんか?
データベース名を指定しないと、ユーザ名がデータベース名になるのですが、そのときは"testdb"というように一重になり、繋がります。

どなたか解決方法を知っている人がいれば、ご教授願います。

244 名前:229 mailto:sage [03/06/18 04:02 ID:???]
>>230
>>231
遅レスすいません。
ありがとうございました。
おかげで解決いたしました。



245 名前:nobodyさん mailto:sage [03/06/22 09:55 ID:???]
>>243
なんか libqp.dll があやしそう。libpq.dll をいれなおしてみては?

246 名前:nobodyさん [03/06/22 09:57 ID:SKC4SEC9]
「PostgreSQL構築・運用ガイド」期待age
ttp://ml.postgresql.jp/pipermail/pgsql-jp/2003-June/005336.html


247 名前:nobodyさん mailto:sage [03/06/22 09:59 ID:???]
ml.postgresql.jp/pipermail/pgsql-jp/2003-June/005336.html

248 名前:あぼーん mailto:あぼーん [あぼーん]
あぼーん

249 名前:nobodyさん mailto:sage [03/06/22 10:19 ID:???]
本書は,PostgreSQLの導入方法はもちろん,
企業情報システムでの利用を前提にした,運用方法や信頼性,
可用性を高めるための方法,企業情報システムで広く使われている
Oracleデータベースとの比較なども紹介し,
企業ユーザーにとって有用な情報をお届けします。

ml.postgresql.jp/pipermail/pgsql-jp/2003-June/005336.html
bpstore.nikkeibp.co.jp/item/main/148222234340.html
bpstore.nikkeibp.co.jp/item/image/h_4822223434.gif

250 名前:nobodyさん mailto:sage [03/06/22 10:28 ID:???]
で、これは何本って言えばいいんだ?
うぐい本か?日本野鳥○会の人 解説きぼん。

251 名前:nobodyさん mailto:sage [03/06/22 10:53 ID:???]
>>250
ぽすぐれ本

252 名前:nobodyさん mailto:sage [03/06/22 11:15 ID:???]
なんで魚なんだ?>ヲレ
自己突っ込み完了しますた。
次の話題どぞ。

253 名前:nobodyさん mailto:sage [03/06/22 16:44 ID:???]
>>246
なんかまたペンギンの影があるね。
亀は使えないのかな?

254 名前:成功者! [03/06/22 23:57 ID:pFJThKfu]
誰でも仕事が出来ます。
資本金0円でスタート
ココを見てください!
www.c-gmf.com/farewell/box10.htm



255 名前:nobodyさん [03/06/23 20:54 ID:dxcUTx3u]
Java+PostgreSQLでwebアプリを作る場合、文字コードは何にするのが一般的ですか?
webページをSJIS、DB内はEUCにしようかと思ってますが、EUCにすると
全角半角どちらも1文字扱いになるらしいので、どうしようかな〜って感じです。

本番サーバはLinuxでApache+Tomcat、開発はwindowsで同じ環境作ってやってます。
winでの開発はJISが楽ですよね、やっぱり・・・

256 名前:あぼーん mailto:あぼーん [あぼーん]
あぼーん

257 名前:nobodyさん mailto:sage [03/06/23 22:12 ID:???]
>>255
PostgreSQLはunicodeでエンコーディングしないと、全角ハイフンなどが化けます。

258 名前:nobodyさん mailto:sage [03/06/25 12:22 ID:???]
バグ出しさせてください、おながいします。

259 名前:nobodyさん mailto:sage [03/06/25 13:52 ID:???]
>>258
環境を教えてください

260 名前:nobodyさん [03/06/26 23:18 ID:UmxIAMQr]
>>285-259ワラタ

261 名前:nobodyさん [03/06/27 20:33 ID:r28icV76]
Postgres自体でSQLの実行ログがどこかに保存される設定とかってあるのでしょうか?
自前で実装する(SQL実行時にテキストに書き出す or DBにテーブルを作成して書き込む等)
しか仕方ないですよね?

262 名前:nobodyさん [03/06/27 22:35 ID:Fj3NiizR]
>>
あるよ。
$PGDATA/postgresql.conf に

log_statement = true

と書き込んでからpostmasterを再起動すれば完了したクエリがログに
記録されるようになります。
ログファイルは、

$ pg_ctl -D /usr/local/pgsql/data -l pgsql.log start

のように指定しる。




263 名前:nobodyさん [03/06/28 02:05 ID:14usrn45]
PHP+PostgreSQLで排他処理を行いたいと思うのですが、
解説本か、サイトあれば教えてください。

無ければ、簡単にご説明くださいませんか?

264 名前:あぼーん mailto:あぼーん [あぼーん]
あぼーん



265 名前:nobodyさん mailto:sage [03/06/28 04:20 ID:???]
>>263
ロックする。以上。

266 名前:nobodyさん [03/06/28 05:20 ID:14usrn45]
DBのロックってできるの?

267 名前:nobodyさん mailto:sage [03/06/28 07:37 ID:???]
>>266
マニュアル読めや

268 名前:nobodyさん mailto:sage [03/06/28 09:59 ID:???]
ID:14usrn45はDB使わない方が(・∀・)イイヨイイヨー

269 名前:nobodyさん mailto:sage [03/06/29 19:33 ID:???]
PostgreSQL-7.3.2をPlamo Linux上で使ってるんですが、
同じ環境の方に聞きたいです。
libplpgsql.so postgres.h libpq.h の3ファイルって存在
してますか?4月号のSoftware Design見ながらXMLPGSQLの
導入を試みてるんですが make でこけてしまうので。。上記
の3ファイルの場所を指定しろって言われてるんだけどそも
そもそんなファイルがないのです。

270 名前:261 [03/06/30 11:26 ID:5q6N3/KD]
>>262
当方、バージョンが少し古くて、log_statement = trueではエラーが出たので
ググってみたところdebug_print_query = trueという指定でできました!
ありがとうございます。


271 名前:あぼーん mailto:あぼーん [あぼーん]
あぼーん

272 名前:nobodyさん [03/06/30 12:26 ID:5tKrGL8Q]
データベース板できました
pc2.2ch.net/db/


273 名前:nobodyさん mailto:l [03/06/30 12:40 ID:???]
pc2.2ch.net/test/read.cgi/db/1056944337/

274 名前:nobodyさん mailto:sage [03/06/30 12:48 ID:???]
>>272
ひでぇ有様だな(w
スレ一覧みてワロタ



275 名前:nobodyさん mailto:sage [03/06/30 12:59 ID:???]
i.2ch.net/m30.html
明らかにデータベース板

276 名前:nobodyさん mailto:sage [03/07/01 00:31 ID:???]
>>274 ← 何気にマジレスっぽ(プ

277 名前:nobodyさん mailto:sage [03/07/01 02:20 ID:???]
ドラゴンボールヲタ?>>276

278 名前:nobodyさん [03/07/01 09:23 ID:oVA7Xb+Q]
>>274=>>277 マジレス図星だったようだなw


279 名前:274 mailto:sage [03/07/01 09:40 ID:???]
>>278
新板の荒れ様を見てワロタっていう素直な感想を書いただけだから、
確かにマジレスには違いないけど。。

何を無理やり煽り文体にしてるの?
何で絡まれてるの?俺。

280 名前:nobodyさん mailto:sage [03/07/01 11:21 ID:???]
ドラゴンボール関連のスレは消されたみたい。
やっぱりデータベース板だそうだ。

281 名前:nobodyさん mailto:sage [03/07/02 01:55 ID:???]
>280
ついさっきまで確信が持てなかったヲレ。

282 名前:nobodyさん mailto:sage [03/07/02 17:01 ID:???]
>>280
www.ff.iij4u.or.jp/~ch2/bbsmenu.html
データベースだし。

283 名前:nobodyさん mailto:sage [03/07/04 04:50 ID:???]
激烈初心者です。

数値のデータ型で、
int2で指定したところに「0001」という数字を代入すると、
1になりますよね?
これを、000の部分を残すためには、文字列型しかないですか?

284 名前:nobodyさん mailto:sage [03/07/04 09:35 ID:???]
「0001」は文字列だから、数値型のカラムに突っ込んで
勝手に「1」になるのは仕方が無いんじゃない?

表示する時に0埋めするようにすれば?
"0000"と文字列にコンバートした1とか10を右から4文字切り取って
表示するとかなら、SQLでできるし。



285 名前:nobodyさん [03/07/10 16:23 ID:57Eu1LHu]
PostgreSQL 7.2.3
php4.1.2
kernel 2.4.7-10
gcc 2.96

という環境で、webアプリを稼動させています。
cronで一日一回「vacuum full」を実行しています。

テーブルは約50個あり、しばらく運用していると
データを保存しているハードディスク領域(/usr/local/pgsql/data/base/XXXXXXXX)が徐々に肥大していきます。
肥大化していくと、insertや、dropが比較的多めのテーブルがあるのですが、
そのテーブルのレスポンスも悪くなっていきます。
そのテーブルをdumpして、dumpファイルからの復帰をすると改善するようです。

別のマシンに同じDBを持ってきて、問題のDBをDUMPし、一旦そのDBをdropdb。
そして、createdbし、dumpからの復帰
psql -e db < dumpfile
をするとハードディスク領域(/usr/local/pgsql/data/base/XXXXXXXX)は約1/3程度になりました。

定期的にdumpして、そのdumpファイルからの復帰という作業は非効率的ですので
このような作業をせずに肥大化を防げる方法はありませんでしょうか。

286 名前:nobodyさん [03/07/10 16:51 ID:ubgylsck]
>>285

REINDEX

287 名前:nobodyさん [03/07/10 18:09 ID:8n4LR913]
BEGIN
処理A
BEGIN
処理B
COMMIT
処理C
ABORT
としても処理AとBはコミットしちゃいますよね?

288 名前:あぼーん mailto:あぼーん [あぼーん]
あぼーん

289 名前:nobodyさん mailto:sage [03/07/10 19:40 ID:???]
>287
つか、nested transactionは処理できない。
使おうとしている時点で間違い。


290 名前:nobodyさん mailto:sage [03/07/10 19:40 ID:???]
>>287
BEGINからCOMMITまでがトランザクションだから、
現在のトランザクションはありませんってエラーがでるんでないの?

291 名前:290 mailto:sage [03/07/10 19:42 ID:???]
>>289
>>287ネストさせようとしてたのか!

292 名前:nobodyさん mailto:sage [03/07/10 20:16 ID:???]
>291
どう見てもネストしてるじゃん。

ちなみに、beginした後でもう一度beginしると、
「もうトランザクション始まってんのじゃボケェ」と言われます。


293 名前:287 mailto:sage [03/07/10 22:42 ID:???]
どうもです。
できるのを前提にコードを書いていたので、
一番外側でだけクエリを発行するようなラッパー関数つくって回避しました。
(途中のアボートは例外処理)

調べてみたらトランザクションのネストができない実装の方が一般的なんですね。

294 名前:285 mailto:sage [03/07/11 15:47 ID:???]
>>286
ありがとうございます。一応reindexを毎日するように設定してしばらく様子見てみます。

ちなみにreindexとvacuum fullは順番的にはどちらを先にした方が良いのでしょうか?



295 名前:nobodyさん [03/07/11 17:21 ID:C9rBOC2S]
test=# vacuum;
NOTICE: Some databases have not been vacuumed in over 2 billion transactions.
You may have already suffered transaction-wraparound data loss.
VACUUM
test=#

とvacuumで上のNOTICEが出た場合はどういう対処をすれば良いのでしょうか。


296 名前:nobodyさん mailto:sage [03/07/12 02:17 ID:???]
>20億トランザクション越えたのにvacuumされませんですた。
>トランザクションID使い果たして、データの喪失が発生しますた。







[ 続きを読む ] / [ 携帯版 ]

前100 次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧]( ´∀`)<193KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef