PostgreSQL 2テーブル目at PHP
PostgreSQL 2テーブル目 - 暇つぶし2ch159:nobodyさん
03/05/06 16:42
>>158文を SELECT 1 WHERE true; みたく単純にしてみて、同じコトをやってみたら?

160:nobodyさん
03/05/10 12:46
>>158
PostgreSQLに接続するユーザーの問題では?
ユーザーを明示的に指定してやったらどうよ?

161:nobodyさん
03/05/13 09:51 77a0e79m
プログラミングではなく、運用の質問なんですが、
Postgresの監視って、プロセス上がってるかどうか
程度でいいですかねぇ?

162:nobodyさん
03/05/13 11:44
>>161
・プロセスあがってるかどうか監視
・最大プロセス超えてないかどうか監視
・クエリーの応答時間が甚だしく増えていないかどうか監視

くらいじゃねーの?
ディスク容量とかも必要かも試練が
こっちは鯖の監視の範疇に入るかな

163:nobodyさん
03/05/13 11:47 sZdPhQWk
>>161
接続できるかどうかぐらいはテストしたら?

164:161
03/05/13 17:15 77a0e79m
>>162
サンクスです。

>>163
シェルで一発で済ましてしまいたんですよ。
ベンダにやってもらうので
そこまでやってもらうと
お金の問題が出てきそうなんですよね。
mysqladmin pingみたいのがあれば
と思ったんですが・・・・・・。
ありがとうでした。

165:nobodyさん
03/05/14 05:36 aknt5UHd
原因がまったく解明しないため、質問させていただきます。

今までどおり、

if($r->resultStatus ne PGRES_TUPLES_OK){ return 0; }

このようにselectが正常にとおってるかサブルーチン内で
チェックさせていたのですが、ある時からなぜか
PGRES_TUPLES_OKがそのまま「PGRES_TUPLES_OK」
となってしまい、この照合も「2 ne PGRES_TUPLES_OK」
となり、照合エラーとなってしまいます。

考えられる原因があれば、どうかご教授ください。
よろしくお願いいたします。

166:nobodyさん
03/05/14 07:26
>>165
この情報からだとスペルミスか、何らかの理由で定数のimportが
できなかったのかというくらいしか思いつかんが。

原因はわからんが、そういうミスを事前にチェックできるよう、use strict; を
使うのが常識。あと、PGRES_TUPLES_OKは整数なので、比較は ne じゃ
なくて != でよい。


167:165
03/05/14 21:34 aknt5UHd
原因が判明しました。しかし、その意味がどうしてもわかりません。

if($r->resultStatus ne PGRES_TUPLES_OK){ return 0; }
という処理は「db.pl」というファイルの中のサブルーチン「db_command」
内で行っていたのですが、このファイルのパッケージ名を「db(package db;)」
としました。

違うファイル「select.cgi」より「db.pl」をrequireし、サブルーチン
「db_command」を「db::db_command($sql)」と呼び出していたの
ですが、この呼び出し方に問題がありました。
パッケージ管理せず、「db_command($sql)」と呼び出すと、結果が
返ってきます。strictでも何にもエラーがはかれません。

原因はわかりましたが、その意味が不明です。
勉強不足で申し訳ないです。

168:165
03/05/14 23:48
またもや自己解決。。。ようやくわかりました。

Pg::PGRES_TUPLES_OK

これだけです。これで解決しました。
いろいろと失礼致しました。

169:nobodyさん
03/05/18 19:21 EvuGQeIP
「40万件有るデー」って、いなかのスーパーの安売りみたいですね。

170:nobodyさん
03/05/18 20:08
>>169
漏れは関西弁かとおもたYO!!!

171:nobodyさん
03/05/18 20:08
しょーもないカキコでageるなコラ。

172:nobodyさん
03/05/18 21:06 5+xOckh5
PostgreSQLはなんでshift-jisのエンコーディングをサポートしてくれないの?

173:あぼーん
あぼーん
あぼーん

174:あぼーん
あぼーん
あぼーん

175:あぼーん
あぼーん
あぼーん

176:あぼーん
あぼーん
あぼーん

177:nobodyさん
03/05/19 20:20
UNIX積算秒を timestamp型にUPDATE文でセットするにはどのような方法があるのでしょうか?

マニュアルの date_trunc() や timestamp() 関数を見てもそれらしいのが見あたら
なくてなやんでいます。

178:nobodyさん
03/05/20 20:28 tVu/NkZD
すんまそん、
緊急の為、過去ログ見ないで聞きます

文字コードを設定する方法を教えてくだつぁい

困りはてました・・・
環境はapache(Linux)+PostgreSQL+PHP
もう日本語めひゃくひゃ・・・


179:nobodyさん
03/05/20 22:01 7LQQ/2dr
PostgreSQL 7.3.2 付属ドキュメント
URLリンク(www.postgresql.jp)

180:nobodyさん
03/05/20 22:13
緊急で

文字コードを設定する方法を教えてくだつぁい

って疑問にぶち当たるシチュエーションってのが想像つかん。

181:nobodyさん
03/05/20 22:43 mI4NkyBO
Serialを指定したテーブルからNextValの値を取得したいと
思っています。
Javaで行う場合に、
REsultSet rs = executeQuery("select nextval('zzz_id_seq')");
としているのですが、これからどのように取得すればいいのでしょうか?
それとも、根本的に取得の方法が間違っていますか?



182:nobodyさん
03/05/20 23:42
>>178
名前の欄に
fushianasan
と書けばOKです!!!

183:山崎渉
03/05/22 01:59
━―━―━―━―━―━―━―━―━[JR山崎駅(^^)]━―━―━―━―━―━―━―━―━―

184:nobodyさん
03/05/22 10:32 JcOANcCI
オマイら
dbの容量計算の仕方教えて下さい。

185:nobodyさん
03/05/22 14:27
>>184

select count(*) from hogehoge;


186:nobodyさん
03/05/24 20:17 aDXBSjIE
ポスグレ!

187:nobodyさん
03/05/24 23:21
( ゚-゚)b

188:nobodyさん
03/05/24 23:26
略すなYO!!!

189:nobodyさん
03/05/27 10:31 oAIrGLTh
select count(*) from hogehoge;
って件数じゃん

190:あぼーん
あぼーん
あぼーん

191:nobodyさん
03/05/27 13:02 ehUv/K+8
で、hogehogeってなに?

192:あぼーん
あぼーん
あぼーん

193:nobodyさん
03/05/27 13:44
(´-`).。oO(いつもながらツッコミが遅いです・・・)

194: 
03/05/27 15:44
(1) create table t1 (ts timestamp);

ってしますよね。で、日本時間15:37ごろに

(2) insert into t1 values (now());

ってしますよね。で、

(3) select * from t1;

ってやると

2003-05-27 15:37:54.748034

んな感じで値が帰ってくるかと思うのですが、

(4) これを php から epoch 形式で取得して、date() 関数に渡すと

28日の0時になってしまいます。

これは↑のうちのどこが悪いのでしょう?

195:nobodyさん
03/05/27 17:46 dZ0fIA92
次のようなテーブルがあるとして、思ったような
操作ができずに困っています。どなたかよい方法を
ご存知の片がおられましたら、教えてください。よろしくお願いします。

下のようなテーブルがあったとします。
Id    name    point     date
1     あ       5      5月1日
2     い       1      5月16日
3     う       22     5月5日
4     え       0      5月27日
5     お      10      5月26日

このテーブルから、例えば本日が5月27日だとすると
本日から3日以内のdateのものを優先的に取得し、
そのレコードより後ろに、それ以外のデータを
pointの降順で並べたいのです。

196:195の続き
03/05/27 17:46 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さん
03/05/27 18:23
>>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さん
03/05/27 19:33
今197がいいこと言った!!!

199:nobodyさん
03/05/28 12:30 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:あぼーん
あぼーん
あぼーん

201:あぼーん
あぼーん
あぼーん

202:nobodyさん
03/05/28 13:41
単発で質問スレを立てないように。終了。

203:195
03/05/28 20:14 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 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.

URLリンク(www.t.ring.gr.jp)

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

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

206:あぼーん
あぼーん
あぼーん

207:あぼーん
あぼーん
あぼーん

208:nobodyさん
03/05/31 23:38 NfBpY+67
Release rush ですね

>>204
postgresql 7.3.3
php 4.3.2


...Mozilla 1.4 RC1

209:nobodyさん
03/06/03 11:27 LFu6QbCl
こんにちは。

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

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

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

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

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

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

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

212:あぼーん
あぼーん
あぼーん

213:nobodyさん
03/06/04 14:29 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:あぼーん
あぼーん
あぼーん

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

216:nobodyさん
03/06/04 18:24
>>215
URLリンク(osb.sra.co.jp)

217:nobodyさん
03/06/04 22:45
7.4はWindowsでもビルドできるって?

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


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

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

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

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


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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

225:nobodyさん
03/06/10 16:13
>>224
access は知らんが、CSE はできる。

226:nobodyさん
03/06/10 18:37
>>224
激しくできます。ぐぐって見てください。

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

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

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

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

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



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


231:nobodyさん
03/06/12 23:30
ALTER TABLEを使う
URLリンク(www.postgresql.jp)

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

232:231
03/06/12 23:31
かぶったーよ

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


234:nobodyさん
03/06/14 02:40 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 8UJU9HVd
234です。
事故解決しました。

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


236: 
03/06/16 16:41
すいません、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さん
03/06/16 17:27
>>236
コピペ?
あまりにも典型的なハマリ(ry

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

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

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

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

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

240:あぼーん
あぼーん
あぼーん

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

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

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


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

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

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

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

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

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

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

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

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

246:nobodyさん
03/06/22 09:57 SKC4SEC9
「PostgreSQL構築・運用ガイド」期待age
URLリンク(ml.postgresql.jp)


247:nobodyさん
03/06/22 09:59
URLリンク(ml.postgresql.jp)

248:あぼーん
あぼーん
あぼーん

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

URLリンク(ml.postgresql.jp)
URLリンク(bpstore.nikkeibp.co.jp)
URLリンク(bpstore.nikkeibp.co.jp)

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

251:nobodyさん
03/06/22 10:53
>>250
ぽすぐれ本

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

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

254:成功者!
03/06/22 23:57 pFJThKfu
誰でも仕事が出来ます。
資本金0円でスタート
ココを見てください!
URLリンク(www.c-gmf.com)

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

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

256:あぼーん
あぼーん
あぼーん

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

258:nobodyさん
03/06/25 12:22
バグ出しさせてください、おながいします。

259:nobodyさん
03/06/25 13:52
>>258
環境を教えてください

260:nobodyさん
03/06/26 23:18 UmxIAMQr
>>285-259ワラタ

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

262:nobodyさん
03/06/27 22:35 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 14usrn45
PHP+PostgreSQLで排他処理を行いたいと思うのですが、
解説本か、サイトあれば教えてください。

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

264:あぼーん
あぼーん
あぼーん

265:nobodyさん
03/06/28 04:20
>>263
ロックする。以上。

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

267:nobodyさん
03/06/28 07:37
>>266
マニュアル読めや

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

269:nobodyさん
03/06/29 19:33
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 5q6N3/KD
>>262
当方、バージョンが少し古くて、log_statement = trueではエラーが出たので
ググってみたところdebug_print_query = trueという指定でできました!
ありがとうございます。


271:あぼーん
あぼーん
あぼーん

272:nobodyさん
03/06/30 12:26 5tKrGL8Q
データベース板できました
URLリンク(pc2.2ch.net)


273:nobodyさん
03/06/30 12:40
スレリンク(db板)

274:nobodyさん
03/06/30 12:48
>>272
ひでぇ有様だな(w
スレ一覧みてワロタ

275:nobodyさん
03/06/30 12:59
URLリンク(i.2ch.net)
明らかにデータベース板

276:nobodyさん
03/07/01 00:31
>>274 ← 何気にマジレスっぽ(プ

277:nobodyさん
03/07/01 02:20
ドラゴンボールヲタ?>>276

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


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

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

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

281:nobodyさん
03/07/02 01:55
>280
ついさっきまで確信が持てなかったヲレ。

282:nobodyさん
03/07/02 17:01
>>280
URLリンク(www.ff.iij4u.or.jp)
データベースだし。

283:nobodyさん
03/07/04 04:50
激烈初心者です。

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

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

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

285:nobodyさん
03/07/10 16:23 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 ubgylsck
>>285

REINDEX

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

288:あぼーん
あぼーん
あぼーん

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


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

291:290
03/07/10 19:42
>>289
>>287ネストさせようとしてたのか!

292:nobodyさん
03/07/10 20:16
>291
どう見てもネストしてるじゃん。

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


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

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

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

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

295:nobodyさん
03/07/11 17:21 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さん
03/07/12 02:17
>20億トランザクション越えたのにvacuumされませんですた。
>トランザクションID使い果たして、データの喪失が発生しますた。


297:山崎 渉
03/07/15 11:07

 __∧_∧_
 |(  ^^ )| <寝るぽ(^^)
 |\⌒⌒⌒\
 \ |⌒⌒⌒~|         山崎渉
   ~ ̄ ̄ ̄ ̄

298:nobodyさん
03/07/23 23:29


299:nobodyさん
03/07/24 12:05 TEX2oC6v
ラージオブジェクトって、pg_dumpでバックアップできるの?
7.1からだっけ?

300:あぼーん
あぼーん
あぼーん

301: 
03/07/24 15:51
ちょっとお尋ねしますが、PostgreSQLでトーナメント表って実現できますか?

チームテーブルと対戦テーブルを用意するところまではできたのですが、
全ての対戦結果を一覧表示させる方法がわかりません。

チームテーブルの内部結合の結果に対して
対戦テーブルを外部結合すればいいかと思ったのですが、
複数のテーブルに対して外部結合というのはできないもんなんでしょうか?

イメージでいうとこんな感じです。

select a.name, b.name, m.score from team a, team b left outer join match m on m.home = a.id and m.visitor = b.id;


302:nobodyさん
03/07/25 03:00 IBsY8pQ4
PHP + PostgreSQL
PERL + PostgreSQL
C + PostgreSQL

どれが一番高速でアクセスできますか?


303:nobodyさん
03/07/25 12:25 oPyKjtod
>>302
ミドル次第。

304:nobodyさん
03/07/26 17:34 grYAyx0u
PostgreSQLってRollBack使えないんすか?

305:nobodyさん
03/07/26 22:34
ハァ?

306:nobodyさん
03/07/27 23:23 guTNEK25
>>304
使えよ

307:nobodyさん
03/07/28 09:21 b/HKh3mz
投稿者が女名だと、同じ内容の回答が続くね。

308:nobodyさん
03/07/28 09:44 b/HKh3mz
しかも、「紹介者がいないときは自分自身になります」って条件読んでないし。

309:nobodyさん
03/07/28 10:13
おいらも今度から女の名前で質問しよう。

310:nobodyさん
03/07/28 11:55
>>309
人格つくりすぎて、あぼーんするハメにならんようにな。

311:nobodyさん
03/07/28 23:51
旦那になって戻ってくるから大丈夫。

312:ももこ
03/07/29 00:11
>>311
もどってきてね♥

313:nobodyさん
03/08/01 07:34 fLmmiO+8
すいません。postgresql-7.2.3で日本語環境が構築できません。
psql -lとしても、EUC_JPとか言語環境がでてきません。
List of databases
Name | Owner
-----------+----------
template0 | postgres

./configure --enable-mutibyte=EUC_JP
と指定もしています。

createdb -E EUC_JP test2
/usr/local/pgsql/bin/createdb: /usr/local/pgsql/bin/pg_encoding: No such file or directory
createdb: "EUC_JP" is not a valid encoding name
↑こんなエラーもでてます。




314:nobodyさん
03/08/01 07:50 esvzZjrA
祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り

ニーノさんのホームページ作り2
スレリンク(entrance板)
ニーノ ◆p9GipySMGk によってラウンジにたてられたこのスレで、

URLリンク(page.freett.com)
【ニーノさんのホームページ】
というサイトが作られた。(現在もコンテンツは爆発的に増えてるよ。)

さぁ、君もアイディアを出して、2CHネラーだけの最強サイトをつくろう!

祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り

315:nobodyさん
03/08/01 07:50
>>313
euc-jpじゃないのかage。

316:315
03/08/01 07:51
ageてねーや。でもspamカキコがくるからageなくていいや。

317:nobodyさん
03/08/01 22:20 bI0qs527
createdb -E EUC_JP データベース名


318:nobodyさん
03/08/01 23:09 vlQX/M9J
URLリンク(www.vesta.dti.ne.jp)
ここなら簡単に見れたぞ

319:山崎 渉
03/08/02 02:20
   ∧_∧
  (  ^^ )< ぬるぽ(^^)

320:ぼるじょあ ◆ySd1dMH5Gk
03/08/02 04:48
     ∧_∧  ∧_∧
ピュ.ー (  ・3・) (  ^^ ) <これからも僕たちを応援して下さいね(^^)。
  =〔~∪ ̄ ̄ ̄∪ ̄ ̄〕
  = ◎―――◎                      山崎渉&ぼるじょあ

321:nobodyさん
03/08/02 07:48
FAQになってる予感がするけど、列制約を変更したくなりました。
create table asでも列制約は新しく定義できないみたいだし。
あと1列だけ型も変更したい。

慎重に設計しなかった自分が悪いわけですが、なんか突破口
ないですか?手で再入力だけは避けたいです。。

322:nobodyさん
03/08/03 08:56
>>321
突破口って。。。
マニュアル読めばいいだけと違うの?

323:_
03/08/04 16:26
CREATE TABLE account_table ( expire_date TIMESTAMP, name TEXT );

のようなものがあって、

SELECT * FROM account_table WHERE expire_date > now() AND name = 'foobar';

のような問い合わせを頻繁に行なっています。実際にはテーブルも問い合わせ
ももっと複雑です。

ここで、上記SELECT文を、1引数('foobar' 部分)のPL/pgSQLの関数にしてしま
いたいのですが、そういうことは可能でしょうか?

CREATE FUNCTION get_account( TEXT ) RETURNS ??? AS 'BEGIN ???; END' LANGUAGE 'plpgsql' ;

のような概観になるかなとは思うのですが、戻りの型などがわかりません。
EXECUTEを使うのでしょうか? 教えてください。

# Viewのほうが無難でしょうか? プログラム側にwhere句を書き忘れる可能性
# があるのが嫌なんですよね…

324:nobodyさん
03/08/05 03:24
CREATE FUNCTION get_account( text ) RETURN SETOF RECORD AS '
[...snip...]
' LANGUAGE 'plpgsql';


325:nobodyさん
03/08/05 13:23
すこしスレ違いかもしれませんが、どちらに質問していいかわからなかったので、
ここで質問させてください。

ある大きな2つのテーブルをJOINしたいのですが、そのままJOINすると
時間が掛かりそうなので、片方を一時テーブルに書き出して、それをJOINしようと
思ったのですが、一時テーブルを作った後、違うページで一時テーブルとJOINしようと
するとテーブルが存在しないと言われてしまいます。
PHPから一時テーブルを作成した場合、その一時テーブルにアクセスできるのは
どのタイミングまでなのでしょうか?
マニュアルにはセッションの終わりまでのようなことが書いてありますが、
PHPのセッションは終了してません。
それとも、一時テーブルを作成しないでもいい方法などありませんでしょうか?
よろしくお願いします。

環境は、PHP 4.2.3 PostgreSQL 7.2.3です。

326:308
03/08/05 13:57
すいません、自己解決しました。


327:nobodyさん
03/08/05 15:59
>325
pconnect使わなければ、PHPからPostgreSQLへのセッションは
毎回切った張ったされますが。


328:nobodyさん
03/08/05 16:25
>>325
一時テーブルをVIEWにするかサブクエリにするのが一般的だけど、
性能上の問題からその一時テーブルの結果を使いまわしたいなら
名前をつけてテーブル作成するしかないかな。

pg_pconnect使ってもApache/PHPの状態によってはDBセッションが同一にならないから、
ページを跨いだ一時テーブルの利用はできない。

329:nobodyさん
03/08/05 18:56
PostgreSQL 7.2 のPL/pgSQLについて教えてください。
CREATE TABLE reg ( d TIMESTAMP );
なるテーブルがあり、d には「現在からn秒後の時刻」をINSERTするようにし
ています。現在はプログラムから
INSERT INTO reg VALUES ( NOW() + INTERVAL ''100 sec'' );
のようにしているのですが、これをPL/pgSQLで書きなおそうとしています。
で、
CREATE FUNCTION f( BIGINT ) RETURNS BOOL AS '
BEGIN
INSERT INTO reg VALUES ( NOW() + INTERVAL ''$3 sec'' );
RETURN TRUE;
END
' LANGUAGE 'plpgsql';
としてみたのですが、$3 が展開されないのか、足し算が行なわれません。
どのように書いたら望む結果になりますでしょうか? 教えてください。

330:325
03/08/05 21:08
>>327, 328

ありがとうございました。
pconnectを使って、ページをまたいで一時テーブルを使おうとしてたので、
テーブルが残ってるのか残ってないのか、よくわからなくて混乱してました。

pg_connectを使って、なんとか同じページ内で一時テーブルを使って処理してます。

VIEWは、まだ勉強中なので試行錯誤してみます。

331:nobodyさん
03/08/06 04:59 7sg7mWSc
教えてください。
DISK障害でテーブル内データのほとんどが消えました。
実体の/usr/local/pgsql/data/base/内は無事のようです。
/base/DB名からなんとかリカバリできないでしょうか?
postgresql6.5.3です。

332:nobodyさん
03/08/08 10:59
ZDNetの誤字ひどいな。
『SRA 最新PostGreSQLをベースにした「PoerGres on Linux」「PowerGres Plus」を発表』
URLリンク(www.zdnet.co.jp)

333:nobodyさん
03/08/18 01:33
age


334:nobodyさん
03/08/25 03:03
perl、DBIでのトランザクションについてなんですが、
今日のレコード数を持ってきて、それを+1した値で、
新たにINSERTするというときは、
↓みたいな感じでOKなのでしょうか?
(他のユーザが登録している場合でも、値のずれが生じないですよね?)

よろしくお願いします。

$dbh->{AutoCommit} = 0;
$dbh->{RaiseError} = 1;
eval {
$val = get_value("SELECT count(*)+1 FROM a WHERE 今日のもの");
$ret = insert_value("INSERT INTO a (foo, ...) values ($val, ...)");
$dbh->commit;
};
if ($@) {
warn "Transaction aborted because $@";
$dbh->rollback; # undo the incomplete changes
}


335:nobodyさん
03/08/25 21:37 r6wfNhzL
7.4の自動バキュームって使えそう?
フルバキュームまで自動でやってくれるの?


336:nobodyさん
03/08/27 12:18
何を勘違いしたか今までポスタージャSQLって読んでたよ…

337:nobodyさん
03/09/01 22:46
私信に近い雑談をMLに流すな~!

338:nobodyさん
03/09/01 22:57
>>334
ズレはしないかもしれないが、カチ合う可能性はあるよ。
それを防ぐには、SERIALIZABLEにするか明示的にテーブルロックする。

339:nobodyさん
03/09/01 23:02
cygwinインストール中に落ちてしまって、インストールできないのですが
どうすれば。。あっここで聞くことじゃないですか。。そうですか。。

340:nobodyさん
03/09/01 23:31
>335
contrib/pg_autovacuum/README.pg_autovacuum より。
vacuum fullに関しては、xid使い切りに関しては考えてるけど、
普段はvacuum止まりということかな。

Vacuum and Analyze:
-------------------

pg_autovacuum performs either a vacuum analyze or just analyze depending
on the quantity and type of table activity (insert, update, or delete):

- If the number of (inserts + updates + deletes) > AnalyzeThreshold, then
only an analyze is performed.

- If the number of (deletes + updates ) > VacuumThreshold, then a
vacuum analyze is performed.

deleteThreshold is equal to:
vacuum_base_value + (vacuum_scaling_factor * "number of tuples in the table")

insertThreshold is equal to:
analyze_base_value + (analyze_scaling_factor * "number of tuples in the table")

The AnalyzeThreshold defaults to half of the VacuumThreshold since it
represents a much less expensive operation (approx 5%-10% of vacuum), and
running it more often should not substantially degrade system performance.



341:nobodyさん
03/09/07 02:48 yFWWpiPw
PostgreSQL 7.2.1使ってるんですけど、
運用中にREINDEXとかDROP INDEX~CREATE INDEXとかの
INDEXの再生成って行って良いんですかね?

念のため運用を一時的に止めた方が良いんでしょうか?

342:nobodyさん
03/09/07 04:52
やってもいいっすよ。ロックかかるけど。

343:nobodyさん
03/09/16 10:01 Wb82WrlA
バッチグーage

344:nobodyさん
03/09/16 10:29
MLヲチスレでつか?(藁

345:nobodyさん
03/09/16 15:02 Wb82WrlA
>>344
1をみてくらさい。

346:/
03/09/16 22:32 GYSWeRnL
おまえら、7.4 は高速化が図られてるようですよ。

【PostgreSQLウォッチ】第1回 PostgreSQLの次期版7.4の性能を検証
URLリンク(itpro.nikkeibp.co.jp)

347:nobodyさん
03/09/17 11:21 An2EWdc3
select hoge,hogehoge from table group by hoge;
をしたいのですがどのようにしたら実現できますか?
グループ化してないhogehogeもselectしたいのです

348:nobodyさん
03/09/17 12:17
select hoge,hogehoge from table group by hoge,hogehoge;

349:nobodyさん
03/09/23 22:55 PMiaWnnI
>>347
hoge|hogehoge
aaaa|bbbb
aaaa|cccc

とあったら、何を出せバインダー

350:nobodyさん
03/09/24 01:47 Mc741Fcx
おもろい
URLリンク(www.39001.com)

351:nobodyさん
03/09/24 05:33 namugEPq
>>350
「メル友みっけ」か...

352:nobodyさん
03/09/24 05:41
ここが一番上にきとる。
移転したんじゃなかったっけ?

PostgreSQL 2テーブル目
スレリンク(db板)

353:nobodyさん
03/09/24 05:56
バイナリデータの挿入の仕方がマニュアルに書いてない
気がするんですが、どうやるんでしょう。
create table images (imagname text, img bytea);
このimg列に /tmp/hoge.jpg を挿入したいです。

354:nobodyさん
03/09/24 06:17
>>352
しらんかった。
っていうか、ドラゴンボール板さわぎのどさくさで、気付いてなかった。

ということで

--- 糸冬 了 ---

355:tes
04/01/15 23:32
tes

356:nobodyさん
04/06/25 15:10
適当な文字列が入っているcolumnにたいして、
大文字小文字関係なく、検索文字をマッチさせるにはどうしたらいいの?

select * from foo where text_column ^ lower('BAR') or text_column ^ upper('BAR')

とかだと、「Bar」みたいのはヒットしないんだよなぁ。




357:nobodyさん
04/06/25 15:12
あげとく

358:nobodyさん
04/06/25 16:09
>>356
text_column ~* 'BAR'

DBのみのネタはDB板へ
URLリンク(pc5.2ch.net)


359:356
04/06/25 16:33
>>358
THX

~が^になっていた orz

360:nobodyさん
04/07/01 16:49
■   PostgreSQLのことならここで聞け   ■
スレリンク(db板)

361:nobodyさん
04/07/14 02:54 IeDlw13K
postgres7.3を使用予定ですが、REINDEXの使用方法を教えてください。

REINDEX対象のテーブル名をpg_stat_user_tablesより
取得しながら、REINDEXを全テーブルに順番にかけるシェルを作ろうと思っています。
その際、pgbashを使用し、cronで自動実行を予定しています。

もしソースコードがわかれば教えて下さい。
またみなさんはどんな方法で、行っていますか?

362:nobodyさん
04/07/14 02:55 IeDlw13K
postgres7.3を使用予定ですが、REINDEXの使用方法を教えてください。

REINDEX対象のテーブル名をpg_stat_user_tablesより
取得しながら、REINDEXを全テーブルに順番にかけるシェルを作ろうと思っています。
その際、pgbashを使用し、cronで自動実行を予定しています。

もしソースコードがわかれば教えて下さい。
またみなさんはどんな方法で、行っていますか?

363:nobodyさん
04/08/26 20:45 QkQTY22p

ネットワークから接続しているユーザのIPを
抜き出してログを取りたいのですが
SQLコマンドで、自分はどこから接続しているかを
確認できる関数ってPostgresにはありませんか?

とにかく、接続しているクライアントのIPさえ分かればOKです。
宜しくお願いします。


364:nobodyさん
04/08/26 21:22 vvcjm84y
管理人が拳銃発砲!!!
URLリンク(bbs2.orange-e.net)

365:nobodyさん
04/09/03 11:18 dro8VJ79
apache2.0.5とPostgreSQL7.4の環境でmod_auth_pgsqlを使ってBasic認証を
行なっているのですが、認証するたびにpostgresユーザーで下のようなプロセスが
溜まっていきます。
postgres: apache database 127.0.0.1 idle
そして挙げ句の果てに
mod_auth_pgsql database connection error reset failed FATAL:
connection limit exceeded for non-superusers とメッセージが出てサーバーエラー
になってしまいます。多分mod_auth_pgsqlがパスワードのデータベースへ接続した後、
切断してくれないからじゃないかと思うのですが、どこか明示的に設定しなければ
ならない場所があるのでしょうか?

366:nobodyさん
04/09/03 12:21
>>365
Auth_PG_connection_reuse がonだとコネクションプーリングするみたいですよ。
デフォルトはoffのようだが。

367:nobodyさん
04/09/03 13:48 dro8VJ79
レスありがとうございます。早速 Auth_PG_connection_reuse off を設定して
みました。(それ以前は、Auth_PG_connection_reuseは何も設定していません。)すると
Invalid command 'Auth_PG_connection_reuse', perhaps mis-spelled or defined
by a module not included in the server configuration
となりサーバーエラーが返ってきました。別の原因は考えられますか?
ちなみにmod_auth_pgsqlは2.0.1、ディストリは fedora core 2です。

368:366
04/09/03 19:40
>>367
ざっとソースを眺めてみた限りにおいて、2.0.1では切断をしていなさそうだ。
postgresqlの設定を変更して接続許可数を増やすか、
2.0.2b1にUpするしかないんじゃないか。

369:nobodyさん
04/09/03 21:48
わざわざ調べて頂いてありがとうございます。バージョン特有の問題なのですね。
当面の間は、max_connectionsを増やして、cronで定期的に service httpd graceful
を走らせてしのごうと思います。お世話になりました。

370:nobodyさん
04/09/04 17:32
>>368
fedore core 2 の mod_auth_pgsql-2.0.1-4.1.src.rpm のSPECファイルの
バージョンを書き換えたらそのままmod_auth_pgsql-2.0.2b1.tar.gzから
rpmをbuildできました。早速アップデートしましたところ、当該不具合は
めでたく解消されました。重ねてお礼申し上げます。

371:nobodyさん
04/09/09 18:47 xemAm0Ui
行き詰まってしまって解決できなくなってしまったので、
質問させて頂きます。

TESTというテーブルの中に、A,Bというカラムがあり、
Aでgroup byしてから、Bをdistinctしたものの
カウントを取りたかったくて、下のようなSQLを組んだのですが、
Bをdistinctできてないものをgroup byした結果が、
出てきてしまいます。
私が意図したSQLはどうすれば実現できるかご教授おねがいします。

SELECT A,count(distinct(B)) FROM TEST group by A;


372:nobodyさん
04/09/09 19:21
>>371
質問の意図を取り間違っているかもしれないが。

SELECT a,count(*) FROM text GROUP BY a,b;

以後、DBのみの話ならDB板へ
■   PostgreSQLのことならここで聞け   ■
スレリンク(db板)
PostgreSQL & pgsql-jp ML 3テーブル目
スレリンク(db板)

373:371
04/09/09 22:19 xemAm0Ui
>372
意図したこととは違いましたが、そのSQL見てて、
ふと思いつき、解決できました。ありがとうございます。

374:nobodyさん
04/09/30 06:39:58
データが8000件位入ったテーブルtestに
さらに8000件近いレコードを追加したいのですが
insert文をエクセルで8000個作ることまではできたのですが、
これをポスグレに読ませる際、一括でコピペするとパースエラーになってしまいました。
10件位づつこまめにコピペするとエラーは起きないのですが
時間がかかりすぎるのでファイルから読み込ませたいのです。
ググった所"copy"だと扱えるデータがタブ区切り形式らしいのですが
insert文が書かれたファイルを読み込ます事はできるのでしょうか?
PostgreSQL7.2.3です。

375:nobodyさん
04/09/30 07:13:18
>>374
psql -f filename

376:374
04/09/30 07:38:51
>>375
レスありがとうございます。
早速ググりましたが
psql -f filename db名で
URLリンク(jpug.postgresql.jp)
にありました。
ありがとうございました!

377:nobodyさん
04/10/05 15:22:15 xTnP4bvw
不安なのでちょっと質問して宜しいでしょうか。
timestamp型のmodify_dateというカラムがあったときに
たとえば、2004年11月4日のデータを取りたいというときは
where to_char(modify_date,'YYYY/MM/DD) = '2004/11/04';
という風にしてるのですが、これよりもっと最適な検索法?というのが
ありましたら教えて貰えますでしょうか。
to_charで一度charに変換してるから速度的にどうかなぁと思ってるのですが…。

378:nobodyさん
04/10/05 15:37:46
>>377
date型にキャストした方が速いかも。
WHERE modify_date::date='2004/11/04';

379:nobodyさん
04/10/05 15:41:36
>>378
おお!なるほど、そういうやり方があったんですね。
感謝ですm(_ _)m

380:378
04/10/05 15:43:11
>>378
あ、この方法だと、'2004/11/04'もdate型に変換するだろうから、
結局>>377とあまり違わないのかな?
俺はこの方法を用いているのだけど。



381:377
04/10/05 15:46:28
>>380
377では速度の最適を求めるような書き込みになってしまいましたが
to_charでYYYY・・・・と変換するのに抵抗を感じてしまって他のやり方が
あればと思って質問したので、十分満足しています。もっと最適なものが
あれば尚いいとは思いますが、378さんのやり方を使っていきたいと思います。

382:nobodyさん
04/10/06 11:37:12
ポストグレスキューエルそろそろ囓ってみようと思うんだけど
こんなボンクラはまずどんな本を読めばいいですか?
教えて下さい ISBNコードのみで( ´,_ゝ`)

383:nobodyさん
04/10/06 18:22:48
初めてこのDBに挑戦したら
initdb: command not found
でいきなり死亡しました。
URLリンク(www.terra-intl.com)
↑に書いてある通りにやったら
7. のinitdb でだめだったんですが、
このような経験のある人いませんか?

384:nobodyさん
04/10/06 20:34:45
>>383
せめて、使ったCygwinとPostgreSQLのバージョンくらい載せるべし。
このページと同一のバージョンが入手できた訳じゃないよね?
あるいは、PostgreSQL と Cygwin でぐぐって、新しめのページをを探すべし。



385:nobodyさん
04/10/06 21:48:18
同じバージョンしか落とせなかったんですが、古いみたいですね。
新しいので朝鮮します。

386:nobodyさん
04/10/07 12:14:27
URLリンク(discypus.jp)
今度はこのページ見てやったんですが、「Cygwin-X」なんてできないし、
デスクトップのcygwinを起動しても一瞬黒いウインドウが出るだけで
何も起こりませんでした。
昨日はできたbashもできなくなって余計ひどくなってしまいました。
環境変数は本当にシステム環境変数でいいのでしょうか?
昨日はユーザー環境変数で設定したんですが。

387:nobodyさん
04/10/07 13:55:35
>>386
Cygwinなんて使わずに8.0入れたらだめなの?

388:nobodyさん
04/10/07 14:22:42
特定のレコード(たとえばIDがaaaのレコード)がなければインサート、
あればアップデートという処理をしたいのですが、
selectであるかどうかチェック>insertかupdateに振り分ける
という方法以外に簡潔にやる方法はありますでしょうか?


389:nobodyさん
04/10/07 23:12:25
>>386
cygserver や postmaster (postgres.exe) をサービスにしないのなら、
PATH や CYGWIN や TZ はユーザ環境変数で十分。

いま、Cygwinのデフォルトパッケージ + PostgreSQL を入れて、
cygservder, CYGWIN環境変数の定義、initdbの実行までやってみたけど、
特に問題なし。(OSはWindows2000 Pro SP4。作業時間は10分で完了)

もっとも、>>387 のいうとおり、8.0 beta 入れてもいいと思うけどな。







390:386
04/10/08 01:27:12
URLリンク(allabout.co.jp)
結局ここの通りにやって成功しました。
これからの問題はJavaServletでどう扱うのかってことだけです。
なぜかPHPの解説サイトばっかなんだけれども・・・。
8.0は解説無しじゃ難しいと思ったので、辞めておきました。

391:nobodyさん
04/10/12 12:56:48 V57uzdCO
質問させて下さい

PostgreSQL(7.2.3)を使ったWebサイトを作っているのですが、最新項目の表示のため
日付(date型)でorder byしてますとえらく処理に時間がかかっています。
そういうものなのでしょうか?
日付でソートしたい場合の効率的な方法などがありましたら教えてください

392:nobodyさん
04/10/12 13:56:22
まず、vacuumdb -f dbname やってミソ。

393:nobodyさん
04/10/12 13:58:02
>>391
DATE型は内部的には4Byteの整数だから、DATE型にしてソートが遅くなると言うわけはないだろう。
一度、VACUUM FULL table;をしてみては如何だろうか。

394:nobodyさん
04/10/12 18:57:34
>>391
型の問題ではないと思うが。そのカラムにインデックスつけてる?

395:391
04/10/12 20:08:58
>>392,393,394
す、すいません
みなさんのご指摘の組み合わせでした。
indexつけたあとvacuumしてなかったせいみたい。。。
ご指摘ありがとうございました!

396:nobodyさん
04/10/25 02:34:54
.open()
でエラーがたまに出るけど、みんなどうやって処理してます?
自分は2回リトライさせてるだけなんですけど、
「普通はこうやるんだ」みたいな決まりってあるんでしょうか?

397:nobodyさん
04/10/25 04:26:44
>>396
でたことないので、出たら出ないように調べると思う

398:nobodyさん
04/10/28 02:30:23
ポストグレスキューエルを信じて裏切られることはありまつか?

399:nobodyさん
04/10/30 09:21:22
PostgreSQL ベースの某社の製品にならあるけど。

400:7.4.5
04/10/30 20:56:47
Cygwinでselect文発行したら
<8B><64><A2>みたいな文字が白くなって大量に表示された
エディタみたいな画面になっちゃったことってあります?
qキー押さないと復帰できないし、selectの結果もでないし。

あとこれは別の環境でだけど、コマンドだと文字化けしちゃう。
WEB上ではちゃんと出てるのに、コマンドで飛び出すと文字化け。
ちゃんと↓入れて日本語入力もできるのに。
set kanji-code sjis
set convert-meta off
set meta-flag on
set output-meta on
Win2000のドメインに入った状態でセットアップして
そのままだと使えなかったからローカルで使ってるのが
いけないのかなぁ。

401:nobodyさん
04/11/10 17:17:33 gbkcKDZ/
PHP4.39とPGSQL7.46で学習してます
トランザクションについて教えてください

BEGIN

SELECT テーブルAのid(SERIAL)のNEXTVALを取得

INSERT テーブルAに上で得られた値をidにいれて挿入

INSERT テーブルBに上で得られたidの値を挿入

COMMIT

以上のような流れがあったとしてテーブルAのidの唯一性は保証されてますか?
要はテーブルAにINSERTしたときのidを取得としてテーブルBにも入れたいんです。
NEXTVALを取ったあとに他のプロセスが参照してデータの整合性がなくなるのが心配です。

402:nobodyさん
04/11/10 17:52:12
シーケンスの nextval で取得される値は
トランザクションとは関係なく
唯一性が保証されるように思う

403:nobodyさん
04/11/17 16:35:31
(;´Д`)ハァハァ ポストグレスキューエルはマイエスキューエルにまだアドバンテージはあるのかい?

404:nobodyさん
04/11/24 18:16:16 fGkcMHGT
SELECTして出てきた行に1から始まる連番をつけるってことできますか?
データのランキングをだしたいんですが。

405:nobodyさん
04/11/24 19:32:44
PostgreSQL 7.4.6 の環境で質問があります。

データベースtest_db内のテーブルtbl_aのパーミッション
を以下のようになっているのですが、、、

test_db=# \dp tbl_a
Access permissions for database "test_db"
Relation | Access permissions
----------+-------------------------------------
tbl_a | {"=","postgres=arwR","nobody=arwR"}
(1 row)

パーミッション未設定のテーブルを上記の同じ設定にするには、
どのようにすれば、いいでしょうか?

test_db=# \dp tbl_b
Access permissions for database "test_db"
Relation | Access permissions
----------+-------------------------------------
tbl_b |
(1 row)



406:405
04/11/24 20:46:16
>> 405 の件は、自己解決しました。

grant select,insert,update,rule on tbl_b to nobody;
以上で実現しました。

板汚し失礼しました。


407:nobodyさん
04/11/24 20:56:44
>>403
Myに比べて多機能だしいろいろあるだろ
>>404
できる

408:404
04/11/27 22:42:48
>>407
具体的にどうやるんですか?マニュアル読み漁ってもわかりません。
サブクエリで連番つくる方法は検索して見つかったんですけど
もっと簡単にできないものかと。

409:nobodyさん
04/12/03 01:31:36 2+kl6sm2
カラム内のデータを置き換えすることはできないものでしょうか。

イメージとしましては、

update table_name set f =~ s/abcde/qwert/g;

こんな感じのようなことをやりたいのですが、説明がどうもうまく
なくて申し訳ありません。

ご教授いただければ幸いです。
宜しくお願いします。

410:nobodyさん
04/12/03 02:07:28
お主の望みは正規表現置換かや?
ならば、PL/Perl などを使ってユーザ定義関数を作れ、とのご神託である

411:nobodyさん
04/12/03 10:44:31 2+kl6sm2
>>410
SQL内でなんとかできないものでしょうか。
フィールド値の内容を丸まる変更は当然出来ますが、
likeを使用しつつもどうにかできないものかと模索中で
ございます。

412:nobodyさん
04/12/03 12:23:36
strpos() と substr() をうまく組み合わせればある程度までは行けるかもしれんが、
g オプションは難しそうだなあ。

お告げに従って PL/Perl で書くと、よくわからんが、こんな感じ?

CREATE FUNCTION chikan(text) RETURNS text AS '
my ($mojiretsu) = @_;
$mojiretsu =~ s/abcde/qwert/g;
return $mojiretsu;
' LANGUAGE plperl;

update table_name set f = chikan(f);


413:nobodyさん
04/12/14 15:59:09 2o4fy8y0
>>410>>412
ERROR: Unrecognized language specified in a CREATE FUNCTION: 'plperl'.
Recognized languages are sql, C, internal, and created procedural languages.

となったので、どうやらPL/Perlが入っていないみたいなので、入れる権限のない
私なりに何か他に方法がないか探してみました。

URLリンク(www.nanbu.com)

これでなんとか凌ぎました。
グローバルオプションこそつけられないものの、置き換えは何とかできるので
助かってます。

ご教授有難うございました。

414:nobodyさん
04/12/16 13:06:24 qpxocizM
foo というテーブルで、hoge fuga hige moe
ちう2つのレコードがあります。

で、hoge fuga higeが3つとも同じレコードについては、まとめて1レコードとみなし。
fooテーブルが何レコードあるか調べたいのですが、
どうゆうSQL文を書いたらよいのでしょうか?
select sum(*) from favorite group by hoge, fuga, hige
とやってもだめでした(そりゃそうだよね。。。)

どなたか教えていただければ幸いです。


415:414
04/12/16 13:07:38
訂正:
>foo というテーブルで、hoge fuga hige moe
>ちう2つのレコードがあります。

foo というテーブルで、hoge fuga hige moe
という2つの「フィールド」があります。

すみません

416:414
04/12/16 21:08:42
回答ないようなのでDB板逝ってきます

417:nobodyさん
05/01/19 17:22:21
ゲイツOSに対応した、postgreSQL8
キタ━━(゚∀゚)━━ッ!!

418:nobodyさん
05/01/21 13:24:22 DguRcNyC
フィールドが一個だけのテーブルが必要なんですが
こういうことって変ですか?

419:nobodyさん
05/01/21 15:11:06
>>418
それだけの情報で何をどう答えろと?
そうですか、では私はエスパーですか

420:nobodyさん
05/01/22 02:07:24
>>418
必要なのなら変ではない。
必要ないのにあるのなら変。

421:nobodyさん
05/02/01 16:43:18 HYaKzyWg
vacuum fullを実行すると2~3時間ぐらいかかり、
しかもその間、httpdに完全に接続できなくなります。
vacuum fullって、そんなもんなのでしょうか?

vacuumしないと、3日もしないうちに重くなってDB接続エラーでまくります。
3日1回httpd止めて作業となると大変なので軽減させたいのですが、
何か良い方法があれば教えてくださいm(_ _)m

構成は、こんな感じです。
Xeon2.8GHzDUAL
メモリ2GB
HDD120GB
Linux-FedoraCore2
 ・apache_1.3.33
 ・postgresql-7.4.5
 ・php-4.3.9

422:nobodyさん
05/02/01 17:35:59
>>421
VACUUM FULLを定期的にする必要なんてないっしょ。
普通cronで1日1回vacuumdb -aで十分。
8.0ならVACUUM遅延機能があるからなおよし。

423:nobodyさん
05/02/01 17:47:45
>>421
3日に1回って、そんなにすごい頻度で delete / update してるDBなのか

424:nobodyさん
05/02/01 18:13:44
おいらはvacuumdb -a -z派

425:nobodyさん
05/02/01 18:21:39
>>423
Apacheが絡んでるから、mod_auth_pgsql使っててなおかつログ取ってるとか
セッションストレージにPostgres使ってると思われ。
ツッコミどころはそこじゃなくてVACUUM "FULL"じゃないかな。

426:421
05/02/01 18:31:46
>>422-424
ありがとうございました。
PostGre使い出したのは最近なので、このvacuumにてこずってます。。。

1日1回vacuumdb -a を実行するとして、その間、みなさんはhttpdを落としたりしてますか?
ちょっと前、vacuumdbをアクセスが少ない時間帯に自動で実行させてそのままほっといてたら、
物凄く時間がかかった上に、DBエラーがでまくりで、とても公開できたもんじゃありませんでした。。。
(2~3時間ぐらいはアクセスできない状態が続いていていました。)

参考までに、vacuumdbにどのぐらいの時間がかかるものなのか教えてくださいm(_ _)m

427:nobodyさん
05/02/08 18:04:40
4.27) どのような暗号化オプションを利用できますか?
URLリンク(www.postgresql.org)
> サーバーを走らせるのに暗号化ファイルシステムを使うこともできます。

は何を指しているのでしょうか?cryptfs? 実績はありますか?

428:nobodyさん
05/02/18 21:22:36 RLTHZ6TX
今、phppgadminを使っているんですが、
これってテーブルの中身のデータを検索するのって
出来ないんですか?
どうも検索システムを使っても、テーブル名しか
検索していないようなんですが…

429:nobodyさん
05/02/19 06:45:44 nMzWTz6R
>>428
SQL発行じゃダメなのか?

430:nobodyさん
05/02/19 19:15:51 gwEGKWwx
>>429
たとえば、検索して、その中からいくつかをチョイスして削除とか
そういうのをグラフィカルに出来たらいいなあ、と思うのですが。
今はSQLを発行してやってます。

431:nobodyさん
05/02/20 00:15:29
Postgresをpg_hda.confで各DBにアクセス制限をかけているのですが、
phpPgAdminでどれか一つのDBへアクセスできると、他のDBにも
アクセスできるようになってしまいます。

各DBを完全に独立させるのはどのような設定を行えばよいのでしょうか。
ご教示いただけますと助かります。

432:nobodyさん
05/02/20 01:47:50
pg_hda はソケットレベルでの接続を制御するもの
DB毎にアクセスを制御したければ SQL の grant でスキーマレベルでの権限を設定する

433:nobodyさん
05/02/28 02:38:12
ちょっと聞いてみたい。
一回ページを表示するのに多いとこで何回くらいクエリ投げてる?
というか何回くらい投げてたら多いと思う?

434:nobodyさん
05/02/28 03:11:15
50回くらい投げてたら多いと思うね。

435:nobodyさん
05/02/28 21:12:21 43Vt3CIQ
select now() - (select max(date_create) from counter);
というSQLで出る18:11:08.696398という時間を、秒数(60*
60*18+60*11+8)に変換して出したいのですが、何かやり方
はございますでしょうか。

ご教授いただけますと幸いです。

436:nobodyさん
05/03/01 05:54:49
環境:MacOSX10.3.8

PostgreSQLの7.4.7(7.4.6でも同じ症状)をインストールしてinitdb --encoding=EUC-JP --no-localeで初期化しようとすると、

initializing pg_shadow... FATAL: XX000: failed to initialize lc_messages to ""
LOCATION: InitializeGUCOptions, guc.c:1867

というエラーメッセージが出てしまう。

googleでML等を調べまくってイヤという程某氏のマルチポストを眺めながら解決法を調べましたが、
全然うまくいきません。お願いします。力を貸して下さい。

(--debug付きの場合)
(前略)
DEBUG: start transaction
DEBUG: close relation (null)
DEBUG: commit transaction
(中略)
DEBUG: start transaction
DEBUG: commit transaction
DEBUG: start transaction
DEBUG: commit transaction
DEBUG: proc_exit(0)
DEBUG: shmem_exit(0)
DEBUG: exit(0)
ok
initializing pg_shadow... FATAL: XX000: failed to initialize lc_messages to ""
LOCATION: InitializeGUCOptions, guc.c:1867

initdb: failed

437:nobodyさん
05/03/04 15:47:39 S8fbJs1c
alter user postgres with password '';

でpostgresのパスワードを無しにしたのですが、こう設定した場合、
postgresユーザでのDB接続は出来なくなると考えて宜しいので
しょうか。

pg_hba.confでは

local all all md5
host all all 127.0.0.1 255.255.255.255 md5
local all all reject
host all all 127.0.0.1 255.255.255.255 reject

と設定済みです。

438:nobodyさん
05/03/10 20:07:41
pgbenchってやってます??みなさんどれくらいの値出ます??

ちなみにうち
pgbench -c 10 -t 100 bench
tps: 112 (including) , 113 (excluding) [Athlon XP-M 1700+,RAID1,RH7.3,psql7.2.4]
tps: 261 (including) , 264 (excluding) [Pentium4 2.83GHz,RAID1,RH9,psql7.3.4]

pgbench -c 10 -t 100 -S bench
tps: 1925 (including) , 2290 (excluding) [Athlon XP-M 1700+,RAID1,RH7.3,psql7.2.4]
tps: 2907 (including) , 3253 (excluding) [Pentium4 2.83GHz,RAID1,RH9,psql7.3.4]

良いのか悪いのか全くわからん。
OpteronとかXeonだったらどれくらいいくんだろう。
ってか、pgbenchの結果を晒しあってるスレあったら誘導してくれ。。。

439:nobodyさん
05/03/13 15:32:22
Windowsネイティブ対応キタ━━━(゚∀゚)━━━ !!!!!

440:nobodyさん
05/03/18 19:32:34 NKwPelPw
一年生、男性、5人
二年生、女性、3人

というクエリー結果を

    男性  女性
一年生 5人
二年生     3人

っていう風に見せたいときどうする?

やっぱPHPで加工するしかないのかな?

441:nobodyさん
05/03/18 21:00:03
case文つかえ

442:nobodyさん
05/04/22 12:41:11
>>30あたりでダンプの話題が出ていたようですが複数のDBがあるので
pg_dumpalを使ってみました。生成されたファイルをみてみると
最初の方で全てのDB分CREATE USERがしてあってそのあと全てのDB分
CREATE DATABASE "DB名"の様になっていましたが
ある一つのDBだけリストアしたい場合には
pg_dumpallから生成されたファイルは使えないのでしょうか?
@7.2.3です

443:nobodyさん
05/04/26 14:59:54
circle型のインサート構文がリファレンスに書いてないしぐぐっても出てこないので
誰か教えて下さい。
insert into table(field)values((0,0),1); とか
insert into table(field)values(GeometryFromText('Circle((0,0),1)')); とか
色々試してみたけどダメでした。

444:nobodyさん
05/04/26 16:19:41
>>443
INSERT INTO Table(field) VALUES(circle'((0,0),1)');

445:nobodyさん
05/04/26 16:27:20
>>443
おまけ。
INSERT INTO Table(field) VALUES('<(0,0),1>');
INSERT INTO Table(field) VALUES('0,0,1');
その他いろいろ... まぁバージョンによって認識してくれる書式に
多少の違いがあるかもしれん。

446:nobodyさん
05/04/26 18:18:09
pgadmin3のバグ(だと思う)報告。
適当なデータベースでテーブル(列は一つで主キーも無く名前・オーナー・テーブル空間・OIDを持つのみを設定)を作り、
データベース→使ったデータベース名→スキーマ→public→テーブル→作成したテーブル名
とたどり、テーブル名を右クリックしてプロパティを開く。
列タブに移動して唯一の列を削除して同一の名前の列(データ型は異なる)を追加する。
OKを押す→エラー発生(これは例外処理として正常だが)
ここでさきほど右クリックしたテーブル名を再び右クリックしてリフレッシュを選択。
その後再び列追加のOKを押すとpgadmin3が突然消える。
俺の環境ではこの操作でこの現象は100%再現する。

他にも細かいおかしな挙動がたくさんあったが忘れた。
(俺がpgadmin3使うの初めてなんでおかしな操作してるのかもしれない)

447:443
05/04/26 18:33:06
>>444-445
レスありがとう!助かりました。

448:nobodyさん
05/04/26 18:51:43
gistインデックスを作る際に指定するgist_geometry_opsには
比較演算子のセットを指示しろとpostGISのマニュアルに書いてあったけど、
&& << >> <^ >^ と書いたら&&の時点で怒られた。
何を書けというの?

せめて一つくらいコード例書いといてくれよ・・・>マニュアル

449:nobodyさん
05/04/26 18:53:01 x+Vlqkfm
ものすごくつまらないことを聞いてもいいですか?

今現在、postgresがオーナーになっているDBがありまして
他のユーザーをオーナーにしたい場合ってどうすればいいんでしょう?

450:nobodyさん
05/04/26 20:44:42
>>449
ALTER DATABASE database OWNER TO newowner;


451:nobodyさん
05/06/08 13:03:23
JNDIから取得したDataSourceでコネクションプーリングする方法を
教えてください。


452:nobodyさん
05/06/08 15:36:20
コネクションプーリングの実装は難しいから、自分でくまない方がいいとおもうけど。
JNDIからプーリングしてもらったコネクションを取得するようにしたほうがいいと思われ。

453:nobodyさん
05/06/08 21:49:29
普通にJNDIルックアップして取得したDataSourceって
ConnectionPool実装してないよね?

InitialContext ctx = new InitialContext();
DataSource ds = (DataSource)ctx.lookup("DataSourceName");

Connection conn = ds.getConnection();

ってな具合に普通にコネクション取ってるだけど
Jdbc3PoolingDataSourceとかでキャストすると落ちるし。

そもそもJNDIで定義してるDataSourceのクラスってどこ変更すりゃいいの?
ってか猛烈にスレ違いだなー

454:nobodyさん
05/06/08 22:33:26
普通にって、そりゃどこでどういう風にJNDIに登録してるかだろ。
コネクションプーリングしたコネクションをJNDIに登録して、それとってくればコネクションプーリングされてるだろ。

455:nobodyさん
05/06/08 23:15:34
DataSourceをJNDIに登録する時に、ドライバークラスはもちろん指定できるんですが
データソースのクラスまで指定する事ってできるんでしょうか?

指定しないで登録すると、デフォルトのjava.sql.DataSourceで登録しますよね。



456:nobodyさん
05/06/08 23:40:26
しらんよ、あんたの実装のことなんか。

457:nobodyさん
05/06/08 23:52:27
>>456
ですよね。
もうちょっと調べてみます。



458:nobodyさん
05/06/09 00:04:51
結局なにがしたいのか謎だったな。
WebならTomcatにまかせとけばいいし、気にすることないからなぁ。

459:nobodyさん
05/06/09 00:16:30
結局、JBoss使ってるんですけど、
DataSourceのJNDI定義するXMLをそのままデプロイすると
java.sql.DataSourceで登録されちゃうんでなんとかならないかなと思ってたんです。

この定義するXMLの中にDataSourceクラスを定義する
ディレクティブが無いんですよね。


460:nobodyさん
05/06/09 01:38:08
で、それはコネクションプーリングしてくれてないの?

461:nobodyさん
05/06/09 02:13:55
くれないです。

java.sql.DataSourceは、ConnectionPooling実装してないんで使い捨てですね。
してくれたら、このクラス、仕様どおりに動いて無い事になるので逆に困りますw

Factoryから自作してやろうかと思ったんですが危ないし、
その筋の人間の作ったJDBCドライバーかデータソースに完全に任せたいです。


462:nobodyさん
05/06/09 05:10:57
java.sql.DataSourceなんてないと思うのだが。
javax.sql.DataSourceはインターフェイスだからConnectionPooling実装してるとかしてないとか、関係ないと思うが。
というか、ConnectionPoolingって、インターフェイス?

463:nobodyさん
05/06/09 17:25:42
>>462
ですね。DataSourceはインターフェースです。
ConnectionPoolingっていうのは、仕組みなのでクラスでもインターフェースでもないです。

ちょっと検証できそうなものを見つけました。
URLリンク(www2b.biglobe.ne.jp)

464:nobodyさん
05/06/09 17:47:39
キッチリ解決しました。
MySQLの資料ですが、まんまいけるハズです。

URLリンク(kamakura.cool.ne.jp)


465:nobodyさん
05/06/09 22:11:26
つうか、JBossがわざわざJNDIに登録してるものが、コネクションプーリングしてないとは思えんのだが。

466:nobodyさん
05/06/16 02:31:27
質問させてください。
現在レン鯖の「speever」なる所でpostgreSQLを始めたのですがphpPgAdminが入ってたんで
tableの作成、テスト用データのinsertは上手くいってselectもできました。
ただ、webからphp経由で
$pgsql_conn = pg_connect("host=localhost port=5432 dbname=DB名 user=名前 password=パス");
とした時に$pgsql_connに何も入りません。
設定がいけないのかと思うのですがpg_hba.conf、postgresql.conf以外に何か設定ファイルがありましたら教えて下さい
いじったのはpg_hba.confがlocalだけだったので「host all all 127.0.0.1 255.255.255.255 trust」と
postgresql.confは#tcpip_socket = falseだったのをアンコメントしてfalseをtrueにしました
phpがver4.3.0
postgresがver7.3.2でした

467:nobodyさん
05/06/16 02:39:31
>>466
設定を変えたときPostgreSQLの再起動をした?
って言うか、貸鯖で設定ファイルを弄らしてくれるのかよ...

それよりもtcp/ipによる接続の必要性が無いのなら
UnixDomainSocketでいいんじゃね。
$pgsql_conn = pg_connect("dbname=DB名 user=名前 password=パス");

468:nobodyさん
05/06/16 02:42:30
>>467 こんばんわ
再起動は/etc/rc.d/initdからしました
なんかvps?とかで似非root権限があるそうです。
$pgsql_conn = pg_connect("dbname=DB名 user=名前 password=パス");
↑host=localhostでソケット通信かとおもてた、ちょっと試してきます

469:nobodyさん
05/06/16 02:50:33
>>467
だめでしたわ('A`)

if ($pgsql_conn) {
print "Successfully connected to database: " . pg_dbname($pgsql_conn) ." on " . pg_host($pgsql_conn) . "<br/>\n";
} else {
print pg_last_error($pgsql_conn);
print "ヽ(`Д´)ノ";
exit;
}
ヽ(`Д´)ノ←こんなん出力されたorz

470:nobodyさん
05/06/16 02:59:33
>>469
う~ん。とりあえず、エラー表示が一切無いのも気になる。
スクリプトの先頭で
error_reporting(E_ALL);
ってすれば何かエラーでないか?

471:nobodyさん
05/06/16 14:44:13
>>470
すいません、php.iniを眺めてたらerr_display=Offになってた。
onにしてhttpd再起動したら
Warning: pg_connect() [function.pg-connect]: Unable to connect to PostgreSQL server: FATAL: Database "test_db" does not exist in the system catalog. . in /var/www/html/dddddd/db_test.php on line 3

どうやらweb鯖とdb鯖が別になってる…?
すいませんでした、いそいで吊ってきます

472:nobodyさん
05/06/16 17:18:41
>>471
そのエラー表示だと、DBそのものはローカルで動いていると思われ。
dbnameがおかしいんじゃね。

473:nobodyさん
05/06/30 04:40:53
どもです。はじめまして。
phpPdAdminの質問なのですが、特権一覧と言うところに「102」という
ユーザーがいるんですが、これは自動的に追加される何らかのユーザー
なのでしょうか??
SQLを直で覗いてユーザー一覧を見たのですが、
このユーザーはいませんでした。
phpPgAdminからしか認識できません。
どなたか知っている人がいましたら、アドバス願います。

474:nobodyさん
05/06/30 20:13:04 cHU+f8gL
アドバス願います。

475:nobodyさん
05/07/23 07:34:11 WyqF/aD4
RDBMS背負ったWebアプリを開発必要があり、
Perl、DBI、PostgreSQLの勉強を進めています。
要件がなかなかFIXしないため暫定的にスタートしなくては
ならない状態なのですが、運用途中でテーブルの「列」を増減させる事は
可能なのでしょうか。
あるいは新たな構造のテーブルを作り、データを移す、とかの方法になりますか?


476:nobodyさん
05/07/23 08:02:53
>>475
ALTER TABLE ADD COLUMN で可。
URLリンク(www.postgresql.jp)

477:nobodyさん
05/07/23 18:38:51
>>476
どうもありがとうございます。
このドキュメント、いいですね。
7.4.7なので近いバージョンのをじっくり読んでみようと思います。

478:nobodyさん
05/07/29 13:20:03 p5If7shl
郵政公社が公開している郵便番号データをテキストに変換
13101 102 1020072 トウキョウト チヨダク イイダバシ 東京都 千代田区 飯田橋
(空白はタブ区切り)

そのテキストをテーブルに取り込む際
>COPY test FROM "13tokyo.txt";
としたところ
invalid input syntax for integer
というエラーが表示され、うまくいきません。
なにが原因なのでしょうか?

Column | Type | Modifiers
---------+--------------+-----------
pubcode | integer |
zip5 | character(5) |
zip7 | character(7) |
pref_k | text |
city_k | text |
town_k | text |
pref_j | text |
city_j | text |
town_j | text |

よろしこ

479:nobodyさん
05/10/25 18:12:46 2GYRQ0/r
PostgreSQL8.0.3 を使ってWebアプリをJavaで構築してます。
ユーザーが入力した情報がtext型に入ってて、このカラムに対してキーワード検索をしたい、という
要件が入ってます。
普通にlike文で検索すれば良いと思うのですが、実際、レコード件数が最大で億を超えることが予想されるようです。
text型ですけど、1万文字の文字数チェックを入れる予定です。
この場合,like文ですとインデックスが当然きかないのでかなりの時間がかかる処理になってしまうと思います。

一般的にこのような場合はDBに頼らず別の仕組みをつかっているんでしょうか??
良くある会員サイトで使われている検索はlike文で頑張っているんでしょうかね?

まだシステム仕様変更をするための時間があるのでアドバイスいただけるとありがたいです。


480:nobodyさん
05/10/25 18:28:23
>>479
普通は「全文検索」モジュールなんかを使うんじゃないのか?
URLリンク(www.oss.ecl.ntt.co.jp)


481:nobodyさん
05/10/25 19:38:24
pg_rast, pg_senna あたりを勧めたいところだけど
>レコード件数が最大で億を超えることが予想されるようです。
ということなら Rast や Senna ではキツいですね。
Hyper Estraier は件数が増えても性能劣化しないように作られているけど
pgestraier は PostgreSQL のカラムに対するインデックス作成ができないので使えないわけで。

8.1 で導入されるテーブル・パーティショニングを使ってカテゴリごとにテーブルを分けるとかすれば
pg_rast や pg_senna でもいけるかな?

482:479
05/10/25 21:21:40 sIrMsQ6K
ありがとうございます。全文検索ですか。はじめて扱いますがドキドキですw

>>480で紹介されているTsearch2 はオープンソースとのことですが、
先に述べたレコード数ですとパフォーマンス劣化は大丈夫でしょうか。

>>481さんの内容ですと、Hyper Estraier というのがBestという感じでしょうかね…。

ともあれ、ありがとうございました。

483:nobodyさん
05/10/25 21:46:04
>>482
ちょっと説明不足でした。
Hyper Estraier というのはオープンソースの全文検索エンジンで、PostgreSQL とは直接関係ないものです。
で、PostgreSQL から Hyper Estaier のインデックスを検索できるように作られたのが pgestraier なわけだけど
これは検索専用で、登録・更新・削除ができないのです。
というわけで Hyper Estraier をそのまま使うのは不可能。

ただし Java バインディングがあるので、INERTと同時に全文検索インデックスへの登録も行うようにして
(この際、主キー相当の項目を属性として登録するのを忘れずに)SELECT のときは pgestraier を使うような
運用方法にすればいけないこともないと思われます。

Tsearch2 のスケーラビリティについてはよく知らないですが KAKASI を MeCab に置き換えたものを
作ってる人もおられるみたいですね。(KAKASI の今のバージョンは UTF-8 が扱えないので)

自分はというと登録・更新・削除もできる Hyper Estraier の PostgreSQL バインディングが出るか、
Rast か Senna のスケーラビリティが上がるまで様子見です。

484:479
05/10/25 22:38:46 sIrMsQ6K
>>483
さらに詳しい説明、感謝致します。
詳しくはHyper Estraieを調査すればわかるとおもいますが、一つだけ。
「インデックスへの登録」という部分は、たとえばText型に入る内容を
Hyper Estraierに対して投げる、という感じでしょうか。その属性にpkyを付加すると。
であれば、Hyper Estraierが持つであろうインデックスファイルなどは結構な量になると
思われますが、正しい認識でしょうか。データ量が多くになると、RDBMSとは別に
全文検索用のサーバーを用意するという運用体型になるって感じでしょうか。
なかなか楽しい世界ですね。ありがとうございます。

485:479
05/10/26 10:41:49
>>484 の補足というか。Hyper Estraierについて簡単に調べました。
要求に十分こたえられる仕様だと思っています。
紹介してくださってありがとうございました。

486:nobodyさん
06/02/13 18:56:37
OIDについて質問です。
あるテーブルでの一意性を保証したいのですが、
単純に該当テーブルのOIDに対してUNIQUEを指定してしまえばいいということなんでしょうか...?
PostgreSQL7.4を想定しています。


URLリンク(www.postgresql.jp)
OID は 32 ビット長であり、クラスタ全体で 1 つのカウンタから割り当てられます。
巨大な、または、長期間運用しているデータベースでは、カウンタが一周する可能性があります。
従って、OID が一意であることを前提とすることは、OID を一意にすることを保証する手段を講じていない限り非現実的です。
OID を使用して行の識別を行う推奨方法は、その OID が使用される各テーブルの OID 列に一意性制約を作成することです。


宜しくお願い致しますm(_ _)m

487:nobodyさん
06/03/07 20:45:26
>>486
serialでも使えば?

488:nobodyさん
06/04/29 23:20:03
DB板での書き込みを再掲させて戴きます。レスがつかなかったもので…orz

PostgreSQLを使って、下記のような処理を作ろうと考えています。
現在「特定テーブルのCSV出力」に何を使うかで悩んでいます。
ストアドプロシージャか、PHPを使うかの二択から選んでくれと言われたのですが、
クライアントアプリがこれらをキックすることを考えるとどちらが簡単でしょうか。

----------
クライアント:Windows(.NETで開発)
サーバ:RedHat Linux + PostgreSQL

やりたいこと。
1.通信はhttpのみ。
2.クライアントはサーバにアクセスして、
 「特定テーブルのCSV出力」を命令する。<--------------(・ω・)
3.クライアントは処理の終了を待つ。
4.クライアントは出力されたCSVファイルをダウンロードする。

489:nobodyさん
06/04/29 23:29:08
>>488
.NETからストアドたたけるんだろうから、ストアドでやれば?
と思ったけど、httpのみかよ。
http通信で直接ストアドなんて呼べるのか?
結局phpでラップすることになるんではないかな。



490:nobodyさん
06/04/30 00:06:46
>>489
レスありがとうございます。
ADO.NETを使っていいものなら話は簡単なんですけどね…。
「セキュリティの観点」からダメだと言われてしまいました。

ちなみにPHPをキックすること自体は簡単にできるものでしょうか?

491:nobodyさん
06/04/30 00:21:53
>>488
なんの言語でやるのかしらんが、たとえばPHPでやるとして

*.csvファイルをPHPで処理するように関連付けて
*.csvファイルの中にcsv出力する[プログラム書いて
ヘッダーをtext出力にすればOk。

492:nobodyさん
06/04/30 04:22:25
>>490
> ちなみにPHPをキックすること自体は簡単にできるものでしょうか?

> 1.通信はhttpのみ。
なんだから、単純にphpのファイルにhttpアクセスするしかないのでは?


493:nobodyさん
06/05/08 08:53:52
>>491-492
了解しました。いかにも素人の質問に答えてくださってありがとうございます。


494:good
06/05/11 15:23:40 UxCS1jwo
PostgreSqlでdate型は、文字として認識されるようですが
仕様でしょうか?
たまに数値型で、抽出できたりするんですが、どうしてでしょう?
WK_SQL = WK_SQL & "(F1_RINYUYMD BETWEEN " & WK_DOU1 & " AND " & WK_DOU2 & ")
F1_RINYUYMD date型

495:nobodyさん
06/05/17 22:06:30 /QUzYdtQ
あるテーブルのint型の変数にNULLを代入しようとすると、
エラーではじかれてしまうのですが、
何がいけないのでしょうか?
charでは問題ありませんし、特にNULLがダメというわけでもないように思っているのですが、
そういうケースがあるんでしょうか?

496:nobodyさん
06/05/17 22:35:27
'NULL'ってやってるとか?
queryをダンプして貼ったらレスも付き易いかと。

497:nobodyさん
06/05/17 22:46:12
すみません、あまり経験も乏しいので説明が要領を得ないかもしれませんが、
insert into test(param) values('');
という感じです。(test というテーブルの param に代入)
実際には、COPYコマンドでファイルから代入しようとして蹴られます。
a,b,,,,c,,d, というようなデータ列で、','を区切り文字としています。
,, の部分がNULLとして扱われると思うんですが、
varchar(20)などでは問題ないのに、intのところでエラーが出ます。
それでコマンドラインでも試してみたところ、やはり同じエラーが出ました。

マニュアルなどでデータ型を見た限りだと、NULLでも問題なさそうに思うのですが、
何か操作上の間違いがあるのでしょうか。
あと、言い忘れていましたが、試しているのは Windows の psql です。

498:nobodyさん
06/05/18 00:46:59
>a,b,,,,c,,d, というようなデータ列で、','を区切り文字としています。

ここを
a,b,NULL, NULL, NULL,c, NULL,d,
みたいだとどうだろ(試してないけど

499:nobodyさん
06/05/18 01:27:13
>>497
COPY じゃ無くて \COPY を使っているとか?
COPYは ,, をNULLとして扱うようだけど、
\COPYは ,, を ""(空白文字列) として扱っている。

\COPY table FROM filename NULL ''
でいけるんじゃね?

> insert into test(param) values('');
''とNULLは別もんだよ。

500:497
06/05/18 02:19:43
>>499
うげ、そうだったんですか。
明日早速やってみます。

>>498
そういうのもありなんですか。
ただ、今やってるのは、他の人が用意したcsvをそのまま利用しているので、
そういうやり方だと何かしらのコンバートが必要になりますよね。

いずれにせよ、アドバイスありがとうございます。

501:nobodyさん
06/05/18 21:20:56
先週まで正常に動いていたPostgreSQL→phpのwebアプリが
突然にphpからの接続(insert処理)ができなくなりました。

ブラウザからINSERTを実行した際に
Warning: PostgreSQL query failed : no connection to the server
のエラーがクエリを吐いた回数分表示されます。

設定側pg_hba.conf、postgresql.confともに弄っていません、
またphpの方もバックアップとdiffをとりましたが変化ありませんでした。
また、バキュームしてみたら何か変わるかと思いSSHからvacuumdbを実行すると
FATAL 2: open of /var/lib/pgsql/data/pg_clog/0732 failed: そのようなファイルやディレクトリはありません
server closed the connection unexpectedly
This probably means the server terminated abnormally
before or while processing the request.
connection to server was lost
vacuumdb: vacuum xxxxxxxx failed

と言われました。
postgresの再起動もしてみましたが「postmaster ok」と通常通り立ち上がっているんですが…。

ブラウザから同じtableにselectを発行すると正常に値をとれます、selectもinsertもDBの接続処理は同じ関数つかってるのに…。
接続は以下のようにしています
function db_conect () {
global $CON;
$CON = pg_connect ("dbname=xxxx user=yyyyyyyyyyy");
}
長々すいません、バージョンは7.2.3です、アドバイスください

502:497
06/05/18 22:12:42
今日やってみたところ、期待通りの動作をしました。
とても助かりました。
どこのどなたか存じませんが、ありがとうございました。

503:nobodyさん
06/05/19 10:16:13 S+/mH4DM
8.1ってiモードの絵文字(外字領域)使えますか?
DBはEUC_JPで構築しています。


504:nobodyさん
06/07/19 22:01:12 6lmDHlcw
バイナリ本体は/usr/local/pgsqlに置いて、DBを/home/pgsql/varに置くようにコンパイルってどうすればできますか?

505:nobodyさん
06/07/19 22:17:41
>>504
initdb & PGDATA

506:504
06/07/20 23:55:57
なんだ、コンパイルのオプションと違ったんだ。
ありがと。

507:nobodyさん
06/07/22 00:36:09 TflzrAiN
URLリンク(pgfoundry.org)
ここからダウンロードしたODBCだと文字化けするんだけど、何かご存じないですか?

鯖が7.4で、EUC-JP
クライアントはAccessとCSEで確認して化けらったです。

SET CLIENT ENCODINGはためしてみました。

以前に片岡さんのほうのドライバいれてました。

バージョンアップしてみたのは、numeric型を認識してくれないのと、
ADOでトランザクションの発行がうまくいかなかったからです。(´・ω・`)

508:nobodyさん
06/07/22 00:37:57
>>507
URLリンク(www.geocities.jp)
を使いましょう

509:nobodyさん
06/07/22 07:31:10
○○日間アクセスしてないユーザを削除する、という処理をさせたいんですが
Postgresだけでこれを実現する機能があれば教えてください
(OSの方で定期的にスクリプトを実行するのが普通なんでしょうか?)

510:nobodyさん
06/07/22 17:56:12
cronかアクセスがあるごとに削除クエリ実行するしかないだろう

511:509
06/07/22 18:14:09
やっぱりそうですよね。。。ありがとうございました

512:nobodyさん
06/08/01 18:36:35
client_encodingのことで質問です。
eucで書いたperlプログラムから、DBIを使ってWindows版のPostgreSQL8.1.4のDBに接続しています。
postgresql.confのclient_encodingの指定はコメントアウトしています。接続先のDBはEUC_JPです。

別のPCのPostgreSQL8.1.4のDBから、pd_dumpで書き出したeucテキストのダンプデータを、
psqlを使用して取り込もうとしたところ、invalid byte sequence for encoding "SJIS" というエラーが
出てしまい、調べましたら、psqlのクライアントエンコーディングがSJISに設定されていることがわかりまして、
ダンプデータの中に SET CLIENT_ENCODING TO 'EUC_JP' という1文を入れたところエラーは出なく
なりました。ところが、今度は取り出したデータがSJISになってしまいました。

CGIプログラムも出力するhtmlのコードもEUCなので、すべてをEUCで統一できればと思うのですが、
どこを設定すればよいですか? どなたか教えてください。

513:nobodyさん
06/08/01 18:45:57
自己レスですorz
接続した直後に set client_encoding to 'EUC_JP' をすればいいだけでした。
お騒がせしました。


514:nobodyさん
06/08/02 12:41:10 IBuG4Wqs
2GBくらいある巨大テーブルがあって、
けっこう複雑なクエリを、いろんな方向からかけるので、
どうしてもseqが走ってしまって、遅くなって困ってます。。

8.1のテーブルパーティショニングを試してもみたんですが、
オプティマイザがバカになって使えないし。。。

殆どがディスクI/O待ちなのですが、こういうときどういった対策があるでしょうか。
どなたか助けて下さい(´・ω・`)

515:nobodyさん
06/08/02 14:08:15
>>514
explainやったの?

516:514
06/08/02 14:47:09 IBuG4Wqs
はい。そのへんの対策はだいたい。

517:nobodyさん
06/08/02 18:06:07
>>516
なんでそれで修正できないんだ?
explainでseqになってるところにindexはるなり、テーブル分割するなり
したら基本的に全部なくせるはずだけど?


次ページ
最新レス表示
レスジャンプ
類似スレ一覧
スレッドの検索
話題のニュース
おまかせリスト
オプション
しおりを挟む
スレッドに書込
スレッドの一覧
暇つぶし2ch