[表示 : 全て 最新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/



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

348 名前:nobodyさん mailto:sage [03/09/17 12:17 ID:???]
select hoge,hogehoge from table group by hoge,hogehoge;

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

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

350 名前:nobodyさん [03/09/24 01:47 ID:Mc741Fcx]
おもろい
www.39001.com/cgi-bin/cpc/gateway.cgi?id=dolphin

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

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

PostgreSQL 2テーブル目
pc2.2ch.net/test/read.cgi/db/1056944337/

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

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

ということで

--- 糸冬 了 ---

355 名前:tes mailto:tes [04/01/15 23:32 ID:???]
tes



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

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

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




357 名前:nobodyさん mailto:age [04/06/25 15:12 ID:???]
あげとく

358 名前:nobodyさん mailto:sage [04/06/25 16:09 ID:???]
>>356
text_column ~* 'BAR'

DBのみのネタはDB板へ
ttp://pc5.2ch.net/db/


359 名前:356 mailto:sage [04/06/25 16:33 ID:???]
>>358
THX

~が^になっていた orz

360 名前:nobodyさん mailto:sage [04/07/01 16:49 ID:???]
■   PostgreSQLのことならここで聞け   ■
pc5.2ch.net/test/read.cgi/db/1056960249/

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

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

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

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

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

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

363 名前:nobodyさん [04/08/26 20:45 ID:QkQTY22p]

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

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


364 名前:nobodyさん [04/08/26 21:22 ID:vvcjm84y]
管理人が拳銃発砲!!!
bbs2.orange-e.net/?id=binbin

365 名前:nobodyさん [04/09/03 11:18 ID: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さん mailto:sage [04/09/03 12:21 ID:???]
>>365
Auth_PG_connection_reuse がonだとコネクションプーリングするみたいですよ。
デフォルトはoffのようだが。

367 名前:nobodyさん [04/09/03 13:48 ID: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 mailto:sage [04/09/03 19:40 ID:???]
>>367
ざっとソースを眺めてみた限りにおいて、2.0.1では切断をしていなさそうだ。
postgresqlの設定を変更して接続許可数を増やすか、
2.0.2b1にUpするしかないんじゃないか。

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

370 名前:nobodyさん mailto:sage [04/09/04 17:32 ID:???]
>>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 ID: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さん mailto:sage [04/09/09 19:21 ID:???]
>>371
質問の意図を取り間違っているかもしれないが。

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

以後、DBのみの話ならDB板へ
■   PostgreSQLのことならここで聞け   ■
pc5.2ch.net/test/read.cgi/db/1091523132/
PostgreSQL & pgsql-jp ML 3テーブル目
pc5.2ch.net/test/read.cgi/db/1079771059/

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

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

375 名前:nobodyさん mailto:sage [04/09/30 07:13:18 ID:???]
>>374
psql -f filename



376 名前:374 mailto:sage [04/09/30 07:38:51 ID:???]
>>375
レスありがとうございます。
早速ググりましたが
psql -f filename db名で
jpug.postgresql.jp/document/pg721doc/reference/app-psql.html
にありました。
ありがとうございました!

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

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

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

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



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

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

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

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



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



386 名前:nobodyさん mailto:sage [04/10/07 12:14:27 ID:???]
discypus.jp/pukiwiki/pukiwiki.php?Cygwin%2F%A5%A4%A5%F3%A5%B9%A5%C8%A1%BC%A5%EB#content_1_15
今度はこのページ見てやったんですが、「Cygwin-X」なんてできないし、
デスクトップのcygwinを起動しても一瞬黒いウインドウが出るだけで
何も起こりませんでした。
昨日はできたbashもできなくなって余計ひどくなってしまいました。
環境変数は本当にシステム環境変数でいいのでしょうか?
昨日はユーザー環境変数で設定したんですが。

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

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


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

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

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







390 名前:386 mailto:sage [04/10/08 01:27:12 ID:???]
allabout.co.jp/career/database/closeup/CU20040813A/
結局ここの通りにやって成功しました。
これからの問題はJavaServletでどう扱うのかってことだけです。
なぜかPHPの解説サイトばっかなんだけれども・・・。
8.0は解説無しじゃ難しいと思ったので、辞めておきました。

391 名前:nobodyさん [04/10/12 12:56:48 ID:V57uzdCO]
質問させて下さい

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

392 名前:nobodyさん mailto:sage [04/10/12 13:56:22 ID:???]
まず、vacuumdb -f dbname やってミソ。

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

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

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



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

397 名前:nobodyさん mailto:sage [04/10/25 04:26:44 ID:???]
>>396
でたことないので、出たら出ないように調べると思う

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

399 名前:nobodyさん mailto:sage [04/10/30 09:21:22 ID:???]
PostgreSQL ベースの某社の製品にならあるけど。

400 名前:7.4.5 mailto:sage [04/10/30 20:56:47 ID:???]
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 ID: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さん mailto:sage [04/11/10 17:52:12 ID:???]
シーケンスの nextval で取得される値は
トランザクションとは関係なく
唯一性が保証されるように思う

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

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

405 名前:nobodyさん mailto:sage [04/11/24 19:32:44 ID:???]
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 mailto:sage [04/11/24 20:46:16 ID:???]
>> 405 の件は、自己解決しました。

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

板汚し失礼しました。


407 名前:nobodyさん mailto:sage [04/11/24 20:56:44 ID:???]
>>403
Myに比べて多機能だしいろいろあるだろ
>>404
できる

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

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

イメージとしましては、

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

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

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

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

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

412 名前:nobodyさん mailto:sage [04/12/03 12:23:36 ID:???]
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 ID:2o4fy8y0]
>>410>>412
ERROR: Unrecognized language specified in a CREATE FUNCTION: 'plperl'.
Recognized languages are sql, C, internal, and created procedural languages.

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

www.nanbu.com/~nanbu/keizi_show1_2.php?category1key=&keizikey=1041937855000000006&PHPSESSID=8087763c1060187e12476afe32e0a60d

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

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

414 名前:nobodyさん [04/12/16 13:06:24 ID: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 mailto:sage [04/12/16 13:07:38 ID:???]
訂正:
>foo というテーブルで、hoge fuga hige moe
>ちう2つのレコードがあります。

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

すみません



416 名前:414 mailto:sage [04/12/16 21:08:42 ID:???]
回答ないようなのでDB板逝ってきます

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

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

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

420 名前:nobodyさん mailto:sage [05/01/22 02:07:24 ID:???]
>>418
必要なのなら変ではない。
必要ないのにあるのなら変。

421 名前:nobodyさん [05/02/01 16:43:18 ID: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さん mailto:sage [05/02/01 17:35:59 ID:???]
>>421
VACUUM FULLを定期的にする必要なんてないっしょ。
普通cronで1日1回vacuumdb -aで十分。
8.0ならVACUUM遅延機能があるからなおよし。

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

424 名前:nobodyさん mailto:sage [05/02/01 18:13:44 ID:???]
おいらはvacuumdb -a -z派

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



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

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

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

427 名前:nobodyさん mailto:sage [05/02/08 18:04:40 ID:???]
4.27) どのような暗号化オプションを利用できますか?
ttp://www.postgresql.org/files/documentation/faqs/FAQ_japanese.html#4.27
> サーバーを走らせるのに暗号化ファイルシステムを使うこともできます。

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

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

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

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

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

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

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

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

434 名前:nobodyさん mailto:sage [05/02/28 03:11:15 ID:???]
50回くらい投げてたら多いと思うね。

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

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



436 名前:nobodyさん mailto:sage [05/03/01 05:54:49 ID:???]
環境: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 ID: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さん mailto:sage [05/03/10 20:07:41 ID:???]
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さん mailto:sage [05/03/13 15:32:22 ID:???]
Windowsネイティブ対応キタ━━━━━━(゚∀゚)━━━━━━ !!!!!

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

というクエリー結果を

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

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

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

441 名前:nobodyさん mailto:sage [05/03/18 21:00:03 ID:???]
case文つかえ

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

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

444 名前:nobodyさん mailto:sage [2005/04/26(火) 16:19:41 ID:???]
>>443
INSERT INTO Table(field) VALUES(circle'((0,0),1)');

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



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

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

447 名前:443 mailto:sage [2005/04/26(火) 18:33:06 ID:???]
>>444-445
レスありがとう!助かりました。

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

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

449 名前:nobodyさん [2005/04/26(火) 18:53:01 ID:x+Vlqkfm]
ものすごくつまらないことを聞いてもいいですか?

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

450 名前:nobodyさん mailto:sage [2005/04/26(火) 20:44:42 ID:???]
>>449
ALTER DATABASE database OWNER TO newowner;


451 名前:nobodyさん mailto:sage [2005/06/08(水) 13:03:23 ID:???]
JNDIから取得したDataSourceでコネクションプーリングする方法を
教えてください。


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

453 名前:nobodyさん mailto:sage [2005/06/08(水) 21:49:29 ID:???]
普通にJNDIルックアップして取得したDataSourceって
ConnectionPool実装してないよね?

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

Connection conn = ds.getConnection();

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

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

454 名前:nobodyさん mailto:sage [2005/06/08(水) 22:33:26 ID:???]
普通にって、そりゃどこでどういう風にJNDIに登録してるかだろ。
コネクションプーリングしたコネクションをJNDIに登録して、それとってくればコネクションプーリングされてるだろ。

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

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





456 名前:nobodyさん mailto:sage [2005/06/08(水) 23:40:26 ID:???]
しらんよ、あんたの実装のことなんか。

457 名前:nobodyさん mailto:sage [2005/06/08(水) 23:52:27 ID:???]
>>456
ですよね。
もうちょっと調べてみます。



458 名前:nobodyさん mailto:sage [2005/06/09(木) 00:04:51 ID:???]
結局なにがしたいのか謎だったな。
WebならTomcatにまかせとけばいいし、気にすることないからなぁ。

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

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


460 名前:nobodyさん mailto:sage [2005/06/09(木) 01:38:08 ID:???]
で、それはコネクションプーリングしてくれてないの?

461 名前:nobodyさん mailto:sage [2005/06/09(木) 02:13:55 ID:???]
くれないです。

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

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


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

463 名前:nobodyさん mailto:sage [2005/06/09(木) 17:25:42 ID:???]
>>462
ですね。DataSourceはインターフェースです。
ConnectionPoolingっていうのは、仕組みなのでクラスでもインターフェースでもないです。

ちょっと検証できそうなものを見つけました。
ttp://www2b.biglobe.ne.jp/~caco/pgpool/

464 名前:nobodyさん mailto:sage [2005/06/09(木) 17:47:39 ID:???]
キッチリ解決しました。
MySQLの資料ですが、まんまいけるハズです。

ttp://kamakura.cool.ne.jp/oppama/swjd/jndidatasource.html


465 名前:nobodyさん mailto:sage [2005/06/09(木) 22:11:26 ID:???]
つうか、JBossがわざわざJNDIに登録してるものが、コネクションプーリングしてないとは思えんのだが。



466 名前:nobodyさん mailto:age [2005/06/16(木) 02:31:27 ID:???]
質問させてください。
現在レン鯖の「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さん mailto:sage [2005/06/16(木) 02:39:31 ID:???]
>>466
設定を変えたときPostgreSQLの再起動をした?
って言うか、貸鯖で設定ファイルを弄らしてくれるのかよ...

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

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

469 名前:nobodyさん mailto:sage [2005/06/16(木) 02:50:33 ID:???]
>>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さん mailto:sage [2005/06/16(木) 02:59:33 ID:???]
>>469
う〜ん。とりあえず、エラー表示が一切無いのも気になる。
スクリプトの先頭で
error_reporting(E_ALL);
ってすれば何かエラーでないか?

471 名前:nobodyさん mailto:sage [2005/06/16(木) 14:44:13 ID:???]
>>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さん mailto:sage [2005/06/16(木) 17:18:41 ID:???]
>>471
そのエラー表示だと、DBそのものはローカルで動いていると思われ。
dbnameがおかしいんじゃね。

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

474 名前:nobodyさん [2005/06/30(木) 20:13:04 ID:cHU+f8gL]
アドバス願います。

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




476 名前:nobodyさん mailto:sage [2005/07/23(土) 08:02:53 ID:???]
>>475
ALTER TABLE ADD COLUMN で可。
www.postgresql.jp/document/pg803doc/html/sql-altertable.html

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

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

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

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


480 名前:nobodyさん mailto:sage [2005/10/25(火) 18:28:23 ID:???]
>>479
普通は「全文検索」モジュールなんかを使うんじゃないのか?
つ ttps://www.oss.ecl.ntt.co.jp/tsearch2j/index.html


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

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

482 名前:479 [2005/10/25(火) 21:21:40 ID:sIrMsQ6K]
ありがとうございます。全文検索ですか。はじめて扱いますがドキドキですw

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

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

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

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

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



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


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


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

487 名前:nobodyさん mailto:sage [2006/03/07(火) 20:45:26 ID:???]
>>486
serialでも使えば?

488 名前:nobodyさん mailto:sage [2006/04/29(土) 23:20:03 ID:???]
DB板での書き込みを再掲させて戴きます。レスがつかなかったもので…orz

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

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

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

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



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

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

491 名前:nobodyさん mailto:sage [2006/04/30(日) 00:21:53 ID:???]
>>488
なんの言語でやるのかしらんが、たとえばPHPでやるとして

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

492 名前:nobodyさん mailto:sage [2006/04/30(日) 04:22:25 ID:???]
>>490
> ちなみにPHPをキックすること自体は簡単にできるものでしょうか?

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


493 名前:nobodyさん mailto:sage [2006/05/08(月) 08:53:52 ID:???]
>>491-492
了解しました。いかにも素人の質問に答えてくださってありがとうございます。


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

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



496 名前:nobodyさん mailto:sage [2006/05/17(水) 22:35:27 ID:???]
'NULL'ってやってるとか?
queryをダンプして貼ったらレスも付き易いかと。

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

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

498 名前:nobodyさん mailto:sage [2006/05/18(木) 00:46:59 ID:???]
>a,b,,,,c,,d, というようなデータ列で、','を区切り文字としています。

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

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

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

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

500 名前:497 mailto:sage [2006/05/18(木) 02:19:43 ID:???]
>>499
うげ、そうだったんですか。
明日早速やってみます。

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

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

501 名前:nobodyさん mailto:age [2006/05/18(木) 21:20:56 ID:???]
先週まで正常に動いていた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 mailto:sage [2006/05/18(木) 22:12:42 ID:???]
今日やってみたところ、期待通りの動作をしました。
とても助かりました。
どこのどなたか存じませんが、ありがとうございました。

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


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

505 名前:nobodyさん mailto:sage [2006/07/19(水) 22:17:41 ID:???]
>>504
initdb & PGDATA



506 名前:504 mailto:sage [2006/07/20(木) 23:55:57 ID:???]
なんだ、コンパイルのオプションと違ったんだ。
ありがと。

507 名前:nobodyさん [2006/07/22(土) 00:36:09 ID:TflzrAiN]
pgfoundry.org/frs/?group_id=1000125&release_id=546
ここからダウンロードしたODBCだと文字化けするんだけど、何かご存じないですか?

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

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

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

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

508 名前:nobodyさん mailto:sage [2006/07/22(土) 00:37:57 ID:???]
>>507
www.geocities.jp/inocchichichi/psqlodbc/indexj.html
を使いましょう

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

510 名前:nobodyさん mailto:sage [2006/07/22(土) 17:56:12 ID:???]
cronかアクセスがあるごとに削除クエリ実行するしかないだろう

511 名前:509 mailto:sage [2006/07/22(土) 18:14:09 ID:???]
やっぱりそうですよね。。。ありがとうございました

512 名前:nobodyさん mailto:sage [2006/08/01(火) 18:36:35 ID:???]
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さん mailto:sage [2006/08/01(火) 18:45:57 ID:???]
自己レスですorz
接続した直後に set client_encoding to 'EUC_JP' をすればいいだけでした。
お騒がせしました。


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

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

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

515 名前:nobodyさん mailto:sage [2006/08/02(水) 14:08:15 ID:???]
>>514
explainやったの?



516 名前:514 [2006/08/02(水) 14:47:09 ID:IBuG4Wqs]
はい。そのへんの対策はだいたい。

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

518 名前:514 [2006/08/04(金) 12:12:04 ID:dYxM1faY]
>>517
集計関数が多いことが、大きな理由だと思います。
様々な角度で切り込まないといけないので、
中間テーブルを作るとなると膨大な量になってしまって。。。

519 名前:nobodyさん mailto:sage [2006/08/04(金) 12:24:10 ID:???]
>>518
で、結局君は何を求めてここに書いているわけ?
どんなテーブル構造になってるかも分からない、seq になる SQL も分からない。
それで、何をどうアドバイスしろ、と。
一言で言うと、「知らんがな」

520 名前:nobodyさん mailto:age [2006/08/22(火) 09:04:21 ID:???]
以下を実行したいのですが, centosに最初に入っているPostgreSQLの
データベースクラスタがあるために、うまくinitdbできません。
(template0と1がSQL_ASCII固定のまま)

initdb --encoding=UNICODE --no-locale

どうすればデータベースクラスタを完全に削除できるのでしょうか?

UNICODEについては, createdb -E UNICODEでもできるのですが,
やはりinitdbで設定したいです.
PostgreSQLを終了させて, ./dataを削除したりしましたが,
キャッシュ?されているらしく完全削除ができない状況です....

521 名前:nobodyさん mailto:sage [2006/08/22(火) 14:03:02 ID:???]
make install

522 名前:nobodyさん mailto:age [2006/10/21(土) 02:59:30 ID:???]
こんばんわ
www.postgresql.jp/document/pg74doc/html/sql-altertable.html
にあるALTER TABLEのSET DEFAULTについてなんですが、psqlから
ALTER TABLE xxxxx ALTER res_insert SET DEFAULT timestamp;
を発行した所
ERROR: column "timestamp" does not exist
とカラム名res_insertを指定いるつもりが
timestampというカラム名を指定するクエリになってしまっているようなんですが
この状態で何か抜けてますでしょうか?


----------------
SELECT version();
version
----------------------------------------------------------------------------------------------------
PostgreSQL 7.4.13 on i686-pc-linux-gnu, compiled by GCC gcc (GCC) 3.4.6 20060404 (Red Hat 3.4.6-3)
(1 row)

523 名前:nobodyさん mailto:sage [2006/10/21(土) 03:53:49 ID:???]
current_timestamp のことではなくて?

524 名前:nobodyさん mailto:age [2006/10/21(土) 03:59:12 ID:???]
>>523

タイプミスしないように¥dで表示されるTypeの項目から拾ってきちゃってた…
せめて"そんなデフォルトは指定できません"的なエラー吐いてくれれば…
ありがとうございました

525 名前:nobodyさん mailto:age [2006/10/23(月) 04:52:02 ID:???]
先輩が書いたコードを読んでたら
SELECT * from xxtablexx where xxcomunxx 〜 '^[ま-も]' ;
というqueryが書いてあったんですが、〜 '^[ま-も]'の【〜】の意味が分かりません、マニュアル等に載ってますでしょうか?



526 名前:nobodyさん mailto:sage [2006/10/23(月) 09:04:41 ID:???]
>>525
POSIX正規表現なんじゃないの?


527 名前:nobodyさん mailto:sage [2006/10/23(月) 18:03:17 ID:???]
hogeテーブルに各種データとtimestamp型でInsertされた日付が格納されているんだけど
日付=todayのように日付でみるんじゃなく、「何時間以内」という様な指定でデータを取得することは可能ですか?

@7.4です

528 名前:nobodyさん mailto:sage [2006/10/23(月) 22:26:23 ID:???]
>527
intervalでマニュアルを検索しる。

529 名前:nobodyさん [2006/10/25(水) 09:54:38 ID:X5/anJFE]
select * from (select * from aaa order by bbb limit 1) as ccc;
↑これは動くのですが

delete from aaa order by bbb limit 1;
delete from (select * from aaa order by bbb limit 1) as ccc;
↑これらは動きません
構文エラーがでてしまいます。
(syntax error at or near "(" at character 13)
一体何がダメなのか、どなたか教えて頂けませんか?宜しくお願いします。
やりたいことは、bbbで昇順した上位1件を削除です。
(環境:windowsXP、postgres8.1.4)

530 名前:nobodyさん mailto:sage [2006/10/25(水) 12:03:50 ID:???]
>>529
根本的にSQLが間違ってる、って思わない訳?


531 名前:nobodyさん [2006/10/26(木) 00:18:23 ID:PySunuHV]
やはりそうですか。。
答えが見当たらなかった為、
今はselectで取得したキーを使って、
変数に格納してから、deleteを発行しなおしてます。
動作が遅くなりそうな気もしますが。。。

532 名前:nobodyさん mailto:sage [2006/10/26(木) 00:38:43 ID:???]
>>531
つか、普通はサブクエリを利用してDELETEするにしても、
ちゃんと削除対象のテーブルをFROMに指定するもんじゃないのか?

>>529の例で言えば、
delete from aaa where pk_on_aaa = (select pk_on_aaa from aaa order by bbb limit 1);
とかさ。


533 名前:nobodyさん [2006/10/26(木) 03:54:14 ID:PySunuHV]
>>532
ありがとうございます!解決しました。
副問い合わせの使い方が間違っていたのですね。
selectでは動くので、deleteではできないのかと思ってしまってました
結構googleでも検索したんですけど、見つかりませんでした(泣)
はまると、何にも進んでないのに2〜3日経っちゃいますねw
サブクエリで探して、以下のサイトを参考にしました。
もっと良いサイトもあるのでしょうけど、見つかりません^^;
www.istudy.ne.jp/ilnews/vol286/sql.asp
個人的には以下のサイトで見つけたいのですが。。
osb.sra.co.jp/PostgreSQL/Manual/PostgreSQL-8.1-ja/

534 名前:nobodyさん mailto:sage [2006/10/26(木) 16:41:56 ID:???]
>>533
なんかそれ以前の問題。
汎用的なSQL入門本でも買って読んだら。
2〜3日ありゃ十分読めるし、基礎だけでも
身に付けたほうが後々楽。

535 名前:nobodyさん mailto:sage [2006/10/27(金) 09:56:45 ID:???]
>>533
自分も「それ以前の問題」だと思う。
君が見付けたいサイトでは
osb.sra.co.jp/PostgreSQL/Manual/PostgreSQL-8.1-ja/sql-delete.html
をよく読めば良い。



536 名前:nobodyさん [2006/10/27(金) 13:03:00 ID:C3DTFplx]
>>534
>>535
ほんとありがとうございます^^
SQL入門書を買ってみることにしましたw
前にPHPの本を買ったんですが、
どうやらUNIXの本だったようで、間違ってました><
今回からはネットで調べて買おうと思ってます。
今は、以下に狙いを定めてたりしますw
www.amazon.co.jp/exec/obidos/ASIN/4798109576

537 名前:nobodyさん [2006/10/28(土) 00:20:10 ID:IIQMBUcS]
Postgres の列制約で、後から unique を定義することは出来ますか?

538 名前:nobodyさん mailto:sage [2006/10/28(土) 01:30:04 ID:???]
>>537
できる

539 名前:nobodyさん mailto:sage [2006/10/28(土) 10:55:59 ID:???]
>>538
バージョンは8.1なんですけど、持ってるの古い本で
その中では出来ないとか書いてあって、ネットで調べても出来ないって
あったんですけど

なんかそのあたりを書いてあるページを教えていただけないでしょうか

540 名前:nobodyさん mailto:sage [2006/10/29(日) 12:06:54 ID:???]
>>539
osb.sra.co.jp/PostgreSQL/Manual/PostgreSQL-8.1-ja/ddl-alter.html#AEN2253
の5.5.3. 制約の追加に
もろに
ALTER TABLE products ADD CONSTRAINT some_name UNIQUE (product_no);
って〜のがあるんだが、
オマイはどこで
「列制約で、後から unique を定義することは出来ない」
って見たんだ?

マニュアルを先に読むクセつけな。

541 名前:nobodyさん [2006/10/29(日) 22:53:31 ID:N1q0Xlu3]
ヒントだけでもお願いできたら嬉しいのですが、
id | day | number
----+---------------------+--------
1 | 2006-09-01 10:10:00 | 30
2 | 2006-09-15 10:10:00 | 30
の様なテーブルが有ってday+number(日)を足した結果が2006-10、つまり今月になるものだけを抽出指定のですがどうすればいいでしょうか。

よろしくお願い致します。。

542 名前:nobodyさん mailto:sage [2006/10/30(月) 00:43:48 ID:???]
じゃ、ヒントだけ

template1=# SELECT '2006-09-01 10:10:00'::TIMESTAMP + '30 days'::INTERVAL;
      ?column?
---------------------
 2006-10-01 10:10:00
(1 row)


543 名前:539 mailto:sage [2006/11/03(金) 00:27:31 ID:???]
>>540
ありがとうございました
おっしゃるとおりです、以後気をつけまする
助かりました

544 名前:nobodyさん mailto:age [2006/11/03(金) 16:57:01 ID:???]
541に便乗なんですが
insert | status
----------------------------+--------
2006-10-25 22:02:56.825435 | 2
2006-11-03 01:09:08.135099 | 1
なtableで
insertが当日のものだけとりたくて
SELECT insert,status from sns_message where insert < LOCALTIMESTAMP + '1 days'
SELECT insert,status from sns_message where insert < current_timestamp + '1 days'
等やってみたけれど、今日のレコードじゃなくてもSELECTできちゃうんですが…。
日付の大小見るときに不等号記号は有効ですよね?

545 名前:nobodyさん mailto:sage [2006/11/03(金) 19:25:10 ID:???]
>>544
WHERE句で
TO_CHAR(insert,'yyyy/mm/dd') = TO_CHAR(current_timestamp,'yyyy/mm/dd')
すれば今日のデータだけ取れるだろ。




546 名前:544 mailto:sage [2006/11/03(金) 23:36:51 ID:???]
>>545

ごめんなさい、insertされてからX日以上たったレコードのstatusに操作を加えたいのです。
上記コードはその過程で「insert後一日以上たったレコード」をSELECTしています

547 名前:nobodyさん mailto:sage [2006/11/04(土) 00:00:46 ID:???]
SELECT insert,status from sns_message where insert < current_timestamp + '1 day'
とか
SELECT insert,status from sns_message where insert < (select current_timestamp + '1 day')
とかは試してみた?




548 名前:544 mailto:sage [2006/11/04(土) 00:25:07 ID:???]
>>547

試しましたが何日前のレコードでもSELECTされてしまいました。
SQLは日付なんかも結構柔軟に扱えそうなんですがスキル不足で…。
とりあえずはこのまま全件とってきてスクリプト側(PHP使ってます)で判定するようにしてみます

ありがとうございました

549 名前:nobodyさん mailto:sage [2006/11/04(土) 00:39:28 ID:???]
つーか、列名に insert はないだろ。
結局「今日」のデータがとりたいのか「X日以上経った」データをとりたいのかも分からん。

550 名前:544 mailto:sage [2006/11/04(土) 00:50:26 ID:???]
>>549
最初、予約語だからダメだろうと思ったんですが試しにCREATE TABLEで使ってみたら通ったのでそのままでした。
最終的にとりたいのは「X日以上経った」データですが、いきなりだと難しいそうなので
「今日中に」INSERTされたデータをSELECTしようとしてみたりしました。

551 名前:nobodyさん mailto:sage [2006/11/04(土) 00:54:56 ID:???]
「テーブル作成 & テストデータ数個 INSERT」の SQL 書いてくれれば
試してみても良いけど

552 名前:544 mailto:sage [2006/11/04(土) 01:30:06 ID:???]
>>551
ありがとうございます、こんな感じです
--------------------
CREATE TABLE sns_message (
message_id int,
m_to int,
m_from int,
insert timestamp,
status smallint
)

INSERT INTO sns_message VALUES (1,111,555,'2006-11-4',1);
INSERT INTO sns_message VALUES (1,111,555,'2006-11-3',1);
INSERT INTO sns_message VALUES (2,111,444,'2006-09-11',1);
INSERT INTO sns_message VALUES (3,111,333,'2006-10-11',1);
---------------------
これで作成、やりたい事は
「insertされて3日たったてるレコードはstatusを9に」することです
Cronで一日一回実行するPHPで使う予定ですが"insertされて3日たったてるレコード"のSQLで詰まってます。

553 名前:544 mailto:sage [2006/11/04(土) 01:32:15 ID:???]
>>552
あうあー、2個目のINSERT文、IDが被っちまいました…
正しくは
----------
INSERT INTO sns_message VALUES (1,111,555,'2006-11-4',1);
INSERT INTO sns_message VALUES (2,111,555,'2006-11-3',1);
INSERT INTO sns_message VALUES (3,111,444,'2006-09-11',1);
INSERT INTO sns_message VALUES (4,111,333,'2006-10-11',1);
---------------------

です。

554 名前:nobodyさん mailto:sage [2006/11/04(土) 01:45:34 ID:???]
>>552
「3日たったてる」の箇所が曖昧だが、さっき(11/04)試したら

test=# select * from sns_message;
 message_id | m_to | m_from |       insert        | status
------------+------+--------+---------------------+--------
          1 |  111 |    555 | 2006-11-04 00:00:00 |      1
          2 |  111 |    555 | 2006-11-03 00:00:00 |      1
          3 |  111 |    444 | 2006-09-11 00:00:00 |      1
          4 |  111 |    333 | 2006-11-07 00:00:00 |      1
          5 |  111 |    333 | 2006-11-08 00:00:00 |      1
(5 rows)

test=# select * from sns_message where insert > current_timestamp + '3 day';
 message_id | m_to | m_from |       insert        | status
------------+------+--------+---------------------+--------
          5 |  111 |    333 | 2006-11-08 00:00:00 |      1
(1 row)

となっていますが、何か問題あり?

555 名前:nobodyさん mailto:sage [2006/11/04(土) 01:57:44 ID:???]
あ、ごめん。「3日たったてる」が曖昧だったのでよく考えていなかった。

test=# select * from sns_message where insert > current_timestamp - '3 day';
ですな。あと、元が current_timestamp になってたから、そのままにしてたけど
何時に実行するか分からないから
test=# select * from sns_message where insert > current_date - '3 day'::interval;
の方が良いと思う。あとは適当に = を付けたり、日数を調整するなりして。



556 名前:544 mailto:sage [2006/11/04(土) 02:05:03 ID:???]
>>555
ありがとうございます
test=# select * from sns_message where insert > current_date - '3 day'::interval;
でいけました!
intervalにキャストしない状態だとcurrent_date +は通るんですがcurrent_date -は通らないんですね。
ERROR: invalid input syntax for type timestamp with time zone: "3 day"
だと怒られました。謎なんで調べてきます
本当にありがとう!

557 名前:nobodyさん mailto:sage [2006/12/01(金) 21:07:28 ID:???]
>>503
超遅レスだけど8.1.3に下のページのパッチを改造したものをあててなんとかしたことはある
ml.postgresql.jp/pipermail/pgsql-jp/2003-May/013553.html


558 名前:nobodyさん [2006/12/03(日) 22:00:50 ID:rK5ovALt]
timestamp 型のデータがあるテーブルで年月のみを取り出したい場合どうすればいいでしょうか。。


time
---------------------
2006-12-03 21:25:12
2006-12-02 21:42:28
2006-11-03 21:25:12
2006-11-02 21:42:28
結果
2006-12
2006-11

それとも新たに年月の見入れる列を作った方がいいでしょうか・・・。
よろしくお願い致します。

559 名前:nobodyさん mailto:sage [2006/12/04(月) 04:13:30 ID:???]
>>558
date_trunc もしくは to_char で調べると幸せになれるかもね。

560 名前:nobodyさん mailto:sage [2006/12/08(金) 05:21:11 ID:???]
8.2のウォームスタンバイって待機系にはリードオンリーでアクセスできる?
MySQLのレプリケーションみたいに


561 名前:nobodyさん mailto:sage [2006/12/10(日) 22:52:41 ID:???]
apache2.0.x, tomcat5.0.x, j2sdk1.4.02 の環境で、PostgreSQL 8.1.x-8.2.x をJDBC3を介して接続してるんですが
コネクションプールが途切れた直後の数回のみ、以下のようなエラーが出て困ってます。
org.postgresql.util.PSQLException: FATAL: terminating connection due to administrator command
どなたか、回避する策をご存知ないでしょうか?板違いだったらすみません。

562 名前:nobodyさん mailto:sage [2006/12/13(水) 15:30:30 ID:???]
oracleからPostgreSQLにデータ移行しようと思って
・perlDBIでOracleに接続、データをselectしCSVファイル出力
・CSVファイルから読み込み、PostgreSQLにperlDBIでInsert
っていうことをしようとしているんだが、
DBD::Pg::st execute failed: ERROR: prepared statement "dbdpg_1" does not exist
ERROR: portal "" does not exist
ERROR: portal "" does not exist
っていうエラーが出てうまくいかない。
文字コードがらみだと思うんだが…。
環境はOracleがWindows、PostgreSQLはCentOS(UTF8)、perlはCentOSの上で動かしています。
いまならinitdbも可能なのでunicodeからEUCに変えることもできる。

元はといえば、
「縺vとか、「M」がperlでSJISからEUC変換すると文字化けするから困っているんだけど。



563 名前:562 mailto:sage [2006/12/13(水) 18:32:06 ID:???]
わるぃ、自己解決しちまった。
テーブルがいまいちうまく作成されていなかった。
(列無しテーブルになっていた)

いや、でも、文字コードのあたりは鬼門だねぇ。

564 名前:nobodyさん mailto:sage [2006/12/13(水) 19:49:55 ID:???]
>>562
文字コード云々で
ごまかさなくても良いよwww


565 名前:nobodyさん [2006/12/16(土) 20:21:37 ID:qU5F6hFh]
質問です。
ODBC接続ができなくて困っています。
odbcドライバーを入れて、サーバーのIP,データーベース名、ユーザー名と
パスワードを入れても、確認テストの段階でエラーが出ます。
(... the target actively refused it)
サーバーのポートは開いているようです。
何か思い当たる理由があったら教えてください。





566 名前:nobodyさん mailto:sage [2006/12/22(金) 11:46:09 ID:???]
8.2.0や8.1.5をインストールしているにも関わらず、
インストールされたバージョンを確認すると7.3(PG_VERSIONファイルと
psqlの起動画面のバージョン表示より)のようです。
普通に考えて、マシンスペックやOS環境の影響だとは思いますが、
インストール時のログを見てもアナウンスはありませんでした。
原因を確認する方法はありますでしょうか?
ちなみに、OSですがRed Hat Linux release 9 (Shrike)
Kernel 2.4.20-8 on an i686となっています。
そもそもRed hatは現状8.1までのようですが、8.1.5でもダメなので。
ご教授お願いします。


567 名前:nobodyさん mailto:sage [2006/12/23(土) 15:55:43 ID:???]
>>565
>サーバーのポートは開いているようです
ちゃんと確かめれ
わからなけりゃ netstat -nlp|grep postmaster の結果貼れ

>>566
rpmでインストールしたのかtarballでインストールしたのかくらい書け
tarballならインストールされる場所が異なってるだけだと思われるが

568 名前:nobodyさん mailto:sage [2006/12/24(日) 01:03:37 ID:???]
>>567
お世話になります。
ソース提供の物をガイダンス(マニュアル)に従いgmakeしました。
インストールディレクトリはデフォルトで、各環境変数やpathも確認しました。

元々入っている旧の物が動いている可能性があるって事ですね。
もう少し調べてみます(週明けになってしまいますが)。
ありがとうございました。

569 名前:568です mailto:sage [2006/12/24(日) 01:07:34 ID:???]
追伸
書き込み直後ですが、
PG_VERSIONファイルがあるディレクトリ(と言うよりdataディレクトリ全部)
を前もって消して、インストール後に新たに出来たのを確認して
その中のPG_VERSIONが7.3になるという事を思い出しました。
やはり7.3で作られてしまうとしか思えないです。。。

570 名前:nobodyさん mailto:sage [2006/12/28(木) 01:14:05 ID:???]
>>560
できないはず
heartbeatと8.2・2台で信頼性高いHA作りたいなあ

571 名前:nobodyさん [2007/01/14(日) 18:53:27 ID:???]
質問です。
LIKE演算子で全文検索したいのですが、LIKE演算子を全コラムに適用するには

SELECT * FROM テーブル名 WHERE コラム1 LIKE '%キーワード%' OR コラム2 LIKE '%キーワード%' OR コラム3 LIKE '%キーワード%';

みたいに地道に全コラムを書き連ねないといけないのでしょうか?
全コラムをワイルドカードを使って簡単に書く事はできませんか?

よろしくお願いします。

572 名前:nobodyさん mailto:sage [2007/01/14(日) 19:02:34 ID:???]
>>571
簡単に書くことは出来ません。
それ以前に、そんなSQLが実用的なのか考え直した方がいい。

573 名前:nobodyさん mailto:sage [2007/01/14(日) 19:07:49 ID:???]
>>572
ありがとうございました。
精進します。

574 名前:nobodyさん mailto:sage [2007/01/14(日) 23:50:14 ID:???]
ポスグレ対応の全文検索アプリ使えばいいんじゃネーノ

575 名前:nobodyさん mailto:sage [2007/02/05(月) 09:46:30 ID:???]
PGPOOLネタだが良い?

PGPOOLでレプリカしてるんですがPgAdminIIIでテーブル作るとOIDが微妙に1〜2ずれたテーブルが作成されてしまいます。
そのたびにDB1−>DB2にrsyncしてとかやっているんですが、根本的な原因がわかればと…。
そういうことってないですか?



576 名前:nobodyさん mailto:sage [2007/02/05(月) 11:10:14 ID:???]
>>575
そもそもpgpoolってOIDが同一になるって保証してたっけ?

577 名前:nobodyさん mailto:age [2007/03/13(火) 19:51:29 ID:???]
こんばんは、かなり下がってるのでageます。

count(*)でレコード数も5800件くらいなのですが、処理が重いです。
単純にレコードの件数が知りたいだけなのですが…
www.postgresql.jp/document/pg746doc/html/functions-aggregate.html

【PostgreSQLの集約関数の性能上の特徴に驚くかもしれません。 具体的には

SELECT min(col) FROM sometable;
という問い合わせは、PostgreSQLではテーブル全体に対する逐次スキャンを使用します。】
とありますが、もっと軽い代替え手段などはありますでしょうか?

以下EXPLAIN ANALYZEです
---------------------------------------------------
userA=# EXPLAIN ANALYZE select count(*) from xxxxxxxxxx;
NOTICE: QUERY PLAN:

Aggregate (cost=31500.40..31500.40 rows=1 width=0) (actual time=6452.49..6452.50 rows=1 loops=1)
-> Seq Scan on xxxxxxxxxx (cost=0.00..31485.92 rows=5792 width=0) (actual time=6414.07..6444.49 rows=5792 loops=1)
Total runtime: 6452.58 msec

EXPLAIN

578 名前:nobodyさん mailto:sage [2007/03/13(火) 20:40:25 ID:???]
>>577
COUNT(*)じゃなくて
COUNT(COLUMN_NAME)とかにすれば
少しマシになるかもしれんよ。
対象カラムはPKになってるのが良いと思う。


579 名前:nobodyさん mailto:sage [2007/03/13(火) 21:47:22 ID:???]
>>578
一部でそれが有用なRDBMSがあるようだがPostgreSQLでは効果ないよ。

>>577
そのSQLでは逐次スキャンは仕方ない。が、5800件程度のレコードなら
ちょっと遅すぎるな。VACUUM FULL;やって無効領域を飛ばせばどうだろうか。
1行がやたら滅多らでかい(巨大なtextやbyteカラムがある)場合は、外へ追い出すとか
するしかない。

580 名前:577 mailto:sage [2007/03/14(水) 10:42:41 ID:???]
レスありがとうございます
>>578
何故か余計にコストが上がりました
EXPLAIN ANALYZE select count(id) from xxxxxxxxxx;
Aggregate (cost=31500.40..31500.40 rows=1 width=4) (actual time=10446.63..10446.63 rows=1 loops=1)
-> Seq Scan on xxxxxxxxxx (cost=0.00..31485.92 rows=5792 width=4) (actual time=10409.76..10439.48 rows=5792 loops=1)
Total runtime: 10446.90 msec
(カラムidは明示的にPKEY指定はしていませんがindexは貼ってあります。)
-----------------------------------
変化なし、なら納得ですがコスト高になるのは不思議です…

>>579
VACUUM FULL;後↓
EXPLAIN ANALYZE select count(*) from xxxxxxxxxx;
Aggregate (cost=211.40..211.40 rows=1 width=0) (actual time=67.11..67.11 rows=1 loops=1)
-> Seq Scan on xxxxxxxxxx (cost=0.00..196.92 rows=5792 width=0) (actual time=16.11..61.43 rows=5792 loops=1)
Total runtime: 67.20 msec

EXPLAIN ANALYZE select count(id) from xxxxxxxxxx;
Aggregate (cost=211.40..211.40 rows=1 width=4) (actual time=21.54..21.54 rows=1 loops=1)
-> Seq Scan on xxxxxxxxxx (cost=0.00..196.92 rows=5792 width=4) (actual time=0.05..15.98 rows=5792 loops=1)
Total runtime: 21.65 msec
-----------------------------------
劇的に変わりました。
1週間に一度ほどの間隔で、レコードが全てが入れ替わるので
CronでVACUUMを走らせていましたがVACUUM FULLすると
見違える程高速になりました。

SQL文のテクニックも必要ですがDB自体のメンテも大事、という事でしょうか。

581 名前:nobodyさん mailto:sage [2007/03/14(水) 11:44:38 ID:???]
>>580
コスト増になるのは単にCBOがタコなだけだろうな。

> 1週間に一度ほどの間隔で、レコードが全てが入れ替わる

じゃ、きちんとメンテしないとだめだろうなぁ。
無駄なブロックまで走査しちゃうから。

582 名前:nobodyさん mailto:sage [2007/03/14(水) 12:48:12 ID:???]
count(*)は単純に行数が変えるが、
count(id)はidがNULLだったらカウントしないからね。
比較する分コスト増になっているのかも。

583 名前:nobodyさん mailto:sage [2007/03/14(水) 12:49:10 ID:???]
×行数が変える
○行数が返る
orz

584 名前:nobodyさん mailto:sage [2007/03/14(水) 12:54:16 ID:???]
って、よく見りゃ算出コストは変わってないやん。
ANALYZEで実行時間が変わるのはキャッシュが
からんでんではねぇか。

585 名前:577 mailto:sage [2007/03/14(水) 14:33:11 ID:???]
>>584
>キャッシュが からんでんではねぇか。
やはりpsqlから実行する時でもキャッシュは関係するんですかね?

一般に公開しているページでリクエストがある都度count(*)すると重そうなので
データを上げた際にcount(*)をしてテキストファイルにでも
総件数を出力しておいた方がいいかな、と思っております



586 名前:nobodyさん [2007/03/16(金) 22:21:41 ID:F/7LbTL8]
質問させてください。

7.4.16へ、7.3.15のDBを移行しようとしています。
DBの文字コードはEUC-JPで、携帯電話などの尋常じゃないコードの文字が多く含まれて居ます。

EUCのチェックが古いバージョンに比べ厳しくなったとのことで、流し込んでも
すぐエラーで止まってしまいます。
レコード数がとても多く、手動での修正は厳しいのですが
文字コードのチェックを甘くするオプションなどは無いでしょうか?

どうぞ宜しくお願いします。

587 名前:nobodyさん [2007/04/01(日) 22:55:03 ID:ywkCVNqC]
ずっと悩んでいます。どうかお教えください。
WEBサーバを構築中なのですが、
クライアントからmycrosoftのweb application stressで
HTTP80への負荷テストを行ったところ、
初期状態と設定変更後のレスポンスがほとんど変わりません。
現在、このような設定にしています。
-- 関連すると思われる変更点を抜粋 --
◎postgresql.conf
shared_buffers = 64000(512MB)
wal_buffers = 32
checkpoint_segments = 16
effective_cache_size = 32000
max_connection = 128
work_mem = 4096
temp_buffers = 16000
◎sysctl.conf
kernel.shmall = 2097152 <-- 基準値
kernel.shmmax = 1073741824(1GB)
◎httpd.conf
StartServers 8 <-- 基準値
MinSpareServers 5 <-- 基準値
MaxSpareServers 30
MaxRequestsPerChild 4000 <-- 基準値
MaxClients 256(pre),150(worker) <-- 基準値
KeepAliveTimeout = 10
↓続きます。

588 名前:nobodyさん [2007/04/01(日) 22:56:45 ID:ywkCVNqC]
上の続きです。
【環境】
サーバ:Vine4.1、Postgresql8.1.5、PHP5.2.1、Pen4 3Gh、メモリdual2G、HDD 100G
クライアント:Pen4 1.8Gh、メモリ1G、ルータ:BBR-4HG
【テスト結果】(内容:1テーブル30カラム程度反映のupdate処理1回)
初期(同時接続数:Requests per Second)
5 : 16.90
10: 17.15
20: 18.11
30: 18.25
設定後(〃)
5 : 17.75
10: 17.35
20: 17.45
30: 17.05
【ab -n 1000 -c 25 http://〜の結果(サーバ内)】
初期状態(Requests per second:25.90)
設定後(Requests per second:35.81)

また、ipcs -l -m を実行したときのshared memoryが0になっているのも
なにか影響しているのかと思っていますが、よくわかっていません。
どなたかおかしな点など気づかれたら、なんでも構いませんので、
どうかご教示宜しくお願い致します。

589 名前:nobodyさん mailto:sage [2007/04/03(火) 23:42:49 ID:???]
質問です。

PostgreSQL 8.1でマニュアル参考に、AutoVacuumを設定したつもりなのですが
動作しているかどうかが確認できません。
何を見れば分かるんでしょうかね?

あと、pgpoolで複製かけた状態で、AutoVacuumしても問題ないのかしら?

590 名前:nobodyさん [2007/04/13(金) 10:28:00 ID:qKjbWP1o]
Linuxのコマンドラインで、
cat /usr/tmp/w1.csv
とするとちゃんとファイルが見れるんですが,postgresのテーブルに

copy table1 from '/usr/tmp/w1.csv' delimiters ','

として取り込もうとすると、

ERROR: could not open file "/usr/tmp/w1.csv" for reading: そのようなファイルやディレクトリはありません

と出てしまいます。。所有者をpostgresにしてみたり、パーミッションも777にしてみたり
色々やってみたのですが、よくわかりませんでした。
Linuxでのファイル名はどういう風に指定すれば良いのでしょうか。
Windowsでは、普通に'c:/hoge/hoge.csv'で出来たんですが。
よろしくお願いいたします。

591 名前:590 [2007/04/13(金) 10:38:13 ID:qKjbWP1o]
あ、見落としてました。Postgresは、実際には別サーバー経由だったかも。。
すみませんでした。


592 名前:nobodyさん [2007/05/07(月) 17:13:46 ID:i8IH1bx5]
質問です。

crypt()で暗号化した文字列を複合化することってできないんでしょうか?

593 名前:nobodyさん mailto:sage [2007/05/07(月) 17:53:29 ID:???]
>>592
cryptは非可逆だったような気がしないでもない。
後、複合化じゃなく復号化、じゃないかとも思う。

594 名前:nobodyさん [2007/05/24(木) 21:16:34 ID:c925mgeL]
postgresql-8.XでWindows用のlibpq.dllを作成しました。
SSLで接続しようと sslmode=require とパラメータに指定しても、エラーになります。
sslmode value "require" invalid when SSL support is not compiled in

postgresql-8.Xをコンパイルするときにopensslなどをリンクしなければならないのでしょうか?

595 名前:nobodyさん mailto:sage [2007/05/25(金) 21:53:04 ID:???]
>>594

デフォルトではリンクされなかったと思う
ググるとPosgtres7系だけど同じようなのが出てくるよ



596 名前:nobodyさん [2007/05/27(日) 01:24:36 ID:xID/GaI9]
どこに書こうか迷いましたがここで質問しちゃいます。

くだらないことなのですが
皆さん都道府県を入れるカラムって何という名前にしてます?
todouhuken
to_dou_hu_ken
とか気持ち悪い感じするし
ヤフー辞書で英語調べたら
(the administrative divisions of Japan:) the prefectures plus Tokyo, Hokkaido, Osaka, and Kyoto
Prefectureが県という意味らしいのでそれにしようかと思ったけど、あんまり馴染みがない英語だから
他の人が見たとき解りづらい気もしないでもない。

他に思いついたのは
state
っていうのもどうかと思うし。

皆さんどんな感じにしてますか?

597 名前:nobodyさん mailto:sage [2007/05/27(日) 12:24:50 ID:???]
>>596
うちではprefになってる。都道府県のHPのドメインも
www.pref.〜
とかなってるし。

598 名前:nobodyさん mailto:sage [2007/05/27(日) 17:38:47 ID:???]
prefectureとかprefとか、stateは意味違う

599 名前:nobodyさん [2007/05/29(火) 07:59:24 ID:7xq0Zk/P]
>>597
>>598
レスありがとうございます。
厳密に言うとprefectureっていうのも意味違う気がするけど(都道府が入るから)
まあ、そんな時間かけてなやむようなところでもないしw

prefectureにしました。
ありがとうございました

600 名前:nobodyさん [2007/05/29(火) 20:02:58 ID:DKx8qJwX]
postgreで日本語(ひらがな)をソートするのに
--no-locale
をつけてinitdbするのはわかったのですが、
それでも濁点のついた文字のときおかしな挙動をするのですが
回避する方法はないのでしょうか?

たとえば

かかあ
かかい
かかう

はちゃんと並ぶのですが

かかい
かかう
がかあ

と並んでしまいます。濁点は濁点のない文字の後に並ぶみたいです。

どうすればちゃんとソートできるようになるのでしょうか?
お願いいたします
文字コードはUTF-8でバージョンは8.1.8です。

601 名前:nobodyさん mailto:sage [2007/05/29(火) 21:14:55 ID:???]
>>600
あんたの「ちゃんと」と定義する並びの文字コードを利用してください。

602 名前:nobodyさん mailto:sage [2007/05/29(火) 23:45:24 ID:???]
>>600
小学校で習わなかったか?

603 名前:nobodyさん mailto:sage [2007/05/30(水) 08:52:35 ID:???]
>>600
ちゃんとソートできてるよ。
それが嫌なら別のソート順確保用カラムでも追加するんだね。


604 名前:nobodyさん [2007/05/30(水) 10:41:44 ID:8UkqO0LS]
>>601
>>602
まじですか?
これが正しい日本語の並び順なの?
それは納得できん!

>>603
今までそうだったのですが、ふりがなを濁点を入れないで入力します。

というか、たとえ学問的に国語がそうだとしても、現実にはちがわない?
がかあ
かかい
かかう
が自然だと思う。

うちの会社でも、クライアントにも、取引会社でも、みんなこの並び順はおかしいとなったので、
濁点なしで入力してたんですけど。

605 名前:nobodyさん mailto:sage [2007/05/30(水) 10:49:04 ID:???]
>>604
文字コード的には正しいだろ。



606 名前:nobodyさん mailto:sage [2007/05/30(水) 12:15:16 ID:???]
>>604
お前さん(と周囲)の考えが不自然だと思ったほうが良い
どうしても嫌なら入力時に内部的に置き換えるしかなかろう

607 名前:604 [2007/05/30(水) 22:24:52 ID:amo3UjDj]
>>605
確かに文字コード的には正しい。正しいと言うよりも、コード化するのに
そうするより仕方なかった感じかな。

>>602>>606(たぶん同一人物)は絶対おかしい。
というか日本人じゃないでしょ。

やっぱ日本語って英語と比べて、デジタル化というかパソコンには向かないよね。
上の都道府県の例でもそう。言語というより文化も含めて合理的じゃないんだよね。
まあ、そこが良いところでもあるんだけど。

608 名前:nobodyさん mailto:sage [2007/05/31(木) 00:44:23 ID:???]
なんか頭の固い御仁だな
今後苦労しそうだ

609 名前:nobodyさん mailto:sage [2007/05/31(木) 09:09:45 ID:???]
> 現実にはちがわない? 

そのあたりは揺らぎがあるからなぁ。
↓の例のどちらが正しいかは、厳密に規定されていないはず。

例:
濁音・半濁音は清音と同一視し、同一視した際に同じ語になる場合は、清音→濁音→半濁音の順とする。 
濁音・半濁音は、清音と別の文字として扱う。順序は、清音→濁音→半濁音の順とする。


610 名前:nobodyさん mailto:sage [2007/05/31(木) 18:47:08 ID:???]
バージョン 7.4.13です
下記のようなテーブルがあり、name1に姓、name2に名が入っているのですが
htmlのテキストフォームから名前を入力してもらい、その値を元に問い合わせをするのに
「カラムの結合」というのは可能でしょうか?

Column |Type
----------------
name1 |text ←"姓"
name2 |text ←"名"

できるとしたらこんな形になると思うのですが…
SELECT * from テーブル where name1 結合演算子 name2 = '入力された値';
または何か代替え手段を教えて頂けるとありがたいです。

611 名前:nobodyさん mailto:sage [2007/06/04(月) 11:16:02 ID:???]
>>610
文字列の結合は、|| を使う。
おそらくこれでいけるとは思うが、7.4は試してない。

612 名前:nobodyさん mailto:sage [2007/06/04(月) 11:19:09 ID:???]
>>604
>がかあ
>かかい
>かかう
>が自然だと思う。

では、「がかあ」と「かかあ」はどうなる?
かかあ
がかあ
が自然、とか言うなよ?

613 名前:nobodyさん mailto:sage [2007/06/04(月) 11:22:27 ID:???]
つーか、何日も間が開いてるんだな。
まあ↓ものんびりしてるけど、よかったらこっちへ。
【Windows】 PostgreSQL8 Part.1 【対応】
pc11.2ch.net/test/read.cgi/db/1102247223/

614 名前:nobodyさん mailto:sage [2007/06/04(月) 11:26:40 ID:???]
>>612
>>609の上の例

615 名前:nobodyさん [2007/06/05(火) 21:44:04 ID:2VYXdggd]
データの追加が出来ません。
OSはCentOS4.5です。

test=> insert into test values(1,'あいうえお');
ERROR: invalid byte sequence for encoding "EUC_JP": 0x94b0

となってしまいます。解決策をどうか教えて下さい。



616 名前:nobodyさん mailto:sage [2007/06/06(水) 18:11:32 ID:???]
それだけじゃわからん。0x94b0の出所が不明だな。
とりあえず、ターミナルの文字コードはどーなってんの。
SET client_encording TO SJIS; とか試してみて。

617 名前:nobodyさん [2007/06/12(火) 21:15:35 ID:8ZZji6XO]
>>501 と同じ症状になっちまった…。
Warning: PostgreSQL query failed: FATAL 2:
open of /var/lib/pgsql/data/pg_clog/0746 failed:
そのようなファイルやディレクトリはありません
server closed the connection unexpectedly
This probably means the server terminated abnormally
before or while processing the request. in

バージョンまで同じ7.3.2
っていうか>>501さんは復帰できたの?
ググった所postmaster止めてpg_resetxlog汁ってMLにあったけど
ml.postgresql.jp/pipermail/pgsql-jp/2004-December/018144.html
原因って何なんですかね?

618 名前:617 mailto:sage [2007/06/13(水) 00:22:06 ID:???]
>>617 に追記
vacuumdbしてみたけど似た様なエラー
FATAL 2: open of /var/lib/pgsql/data/pg_clog/0746 failed: そのようなファイルやディレクトリはありません
server closed the connection unexpectedly
This probably means the server terminated abnormally
before or while processing the request.
connection to server was lost

ついでにpsqlからSELECT、UPDATE、INSERTしてみたら通った…。なんで?
PHPからpc_execしてるからそっちの問題なんだろか?
とりあえずダンプとってDB消して作り直してきます

619 名前:617 mailto:sage [2007/06/13(水) 02:50:47 ID:???]
さらに追記
pg_dumpは不可、エラーは同じ様なもの
ただし、エラー文中に既存のテーブル名が出て来たので壊れた?テーブルの見当がついた
そのテーブルに絞ってpg_dump -t をするとやはり失敗、
それ以外のtableに対して-t付きで実行したら成功した。
相変わらずSELECTは可能はだったので該当tableから
全文SELECT→PHPで整形(shellを扱えないと不便…。sedとか?)
→同一構成のダミーtableにリストアできるかテスト→該当tableをdrop→リストア
で復活できた…。
ただし何で壊れた、かの原因がまったく不明…。
MLでも原因までは書いてなさそう。
スレ汚ごめん

620 名前:nobodyさん [2007/06/17(日) 00:27:42 ID:Yzi7QEQY]
頭を悩ましているのでお願いします。

営業時間を入力しておいて、今営業中か検索できるようにしたいのですが、
open_timeとclose_timeという型がTIMEのカラムを作って、検索したときの時間が
その間にあるか、例えば
SELECT open_time < localtime AND localtime < close_time
で検索できそうだと思っていたのですが
よく考えたら、深夜24:00以降やってるお店が、うまく扱えないじゃないですか。

で、TIMEをやめてFLOATにして、保存するときに、例えば
10:30〜3:00 → 10.5〜27
にして、大小で検索も考えたのですが
検索するときに現在の時間が例えば5時なら、どう検索すればよいのか・・・
この方法もなんかうまくいかなそうです。

また24時間営業の店はどのように扱うのかとか・・・

このようなシステムを作ったことある方いらっしゃいましたら、どのように実装したか教えて頂けませんでしょうか?

621 名前:nobodyさん mailto:sage [2007/06/17(日) 00:58:26 ID:???]
>>620
開店時間(open_time::time)と営業時間(sales_hours::interval)で
WHERE (localtime - open_time) < sales_hours
でどうかな。開店後何時間経ってるかで比較する。

622 名前:620 [2007/06/18(月) 01:48:25 ID:3Ht3k2HG]
>>621
レスありがとうございます。

それだと、0:00を過ぎたときマイナスの値が帰ってきてしまうので
WHEREがtrueになってしまうと思うのですが。

timeだと日にちが変わったことが解らないからなのかな?

例えば、CRONを毎日0:00に起動して、営業時間を入れたカラムを見に行って
数日分(あんまりじっくり考えてないけど、その日と翌日分で良いのかな?)
の日付入りのテーブルを自動生成して、そこに検索かけるとか・・・

今が営業しているか、って意外と大変ですね。
開店時間が何時より早いお店とか、閉店時間が何時より遅いお店なら簡単に実装できそう。

それでいいかな・・・

なんか簡単な方法あったら引き続き情報お願いします。

623 名前:nobodyさん mailto:sage [2007/06/18(月) 03:02:36 ID:???]
>>622
ああスマン、open_timeをinterval型にキャストするの抜けてた。
WHERE ( localtime - open_time::interval ) < sales_hours;

開店時刻をinterval型に変換するのは反則のような気もするが、
これで、開店後の経過時間が出ます。(負の値にはなりません)

624 名前:nobodyさん mailto:sage [2007/06/18(月) 03:50:30 ID:???]
店舗ID,開店時間,閉店時間
1, 07:00, 23:59
1, 00:00, 03:00
(朝7時から翌朝3時までの店の場合)

みたいに一つの店舗でも営業時間を二行にわけてやればいいじゃね?

625 名前:622 mailto:sage [2007/06/19(火) 08:04:50 ID:???]
>>623
>>624
超遅レスですが
レスありがとうございます

>>623
確かに、そうすると負になりませんね。
なぜそうなるのか原理というか理屈が良くわかりませんが^^;
勉強になりました。
それならいけそうです。ありがとうございます。

>>624
なるほど、それでどちらかに入っていればいいと。
それもわりと簡単。

いろりろアイデアがあるモンですな。
ありがとうございました。
よく考えて、ベンチもとって、どちらかの方法でやらせて頂きたいと思います。



626 名前:nobodyさん mailto:sage [2007/06/19(火) 11:33:30 ID:???]
正規化するといいよ
24時以降は24足すのさ
そして範囲チェックは BETWEEN でやると見やすい

627 名前:nobodyさん mailto:sage [2007/06/19(火) 18:36:18 ID:???]
でたな正規化厨!

628 名前:nobodyさん mailto:sage [2007/06/19(火) 19:02:58 ID:???]
テーブルの正規化と意味が違うのに脊髄反射するやつw

629 名前:nobodyさん mailto:sage [2007/06/20(水) 02:18:52 ID:???]
でたな性器化中!

630 名前:nobodyさん [2007/06/23(土) 18:35:19 ID:T/euHpQb]
不可解なことでなやんどります。

複数のデータベースを作成していて、一方でVACUUMを実行したのですが、
どういうわけか、VACUUMをかけたほうだけではなく、かけてないほうで著しくパフォーマスが劣化します。

データベースA <= VACUUM実行
データベースB <= 運用中

で、遅くなっている様子が、IO負荷ではなくCPUをいつも以上に使用しているように見えます。
VACUUMの実行を中断すると通常の状態に戻るので、VACUUMと何らかの関連があると
思うのですが、VACUUMの実行によってVACUUMしていないデータベースの実行プランが
影響受けるなんてことあるんでしょうか?
誰かヒントくださいまし...

ちなみに8.1.5でございます。


631 名前:nobodyさん mailto:sage [2007/06/25(月) 18:32:04 ID:???]
同じサーバで同じpostmasterでDBが違うだけなの?
だったら片方で負荷がかかれば足引っ張られると思うが

632 名前:630 mailto:sage [2007/06/25(月) 19:07:01 ID:???]
そうなんだけど、IOで引っ張ってるんじゃなくてまるで実行プランが変わったように突然CPU使用率が上がるんだよ。
で、VACUUMをとめても実行プランが変わるまで同じ調子でCPUがんがん使ったまま…。
ANALYZEがかかると収まる。そんな感じ。

633 名前:nobodyさん mailto:sage [2007/07/25(水) 21:58:43 ID:???]
ムーバブルタイプというブログ作成ツールをインストールする際にポスグレを使っております。
インストールは無事に終わったのですが、
データベースのアップグレードをする際に
ERROR: parser: parse error at or near "0"
というエラー文言が出てきてしまいます。
通常は"0"の部分に原因となるヒントが出ているものなのですが、
0とだけ出ていても何が原因なのかが全く把握できません。
この0っていうのはどういったケースで発生するものなのでしょうか??

634 名前:nobodyさん mailto:sage [2007/07/26(木) 01:11:19 ID:???]
>>633
"0" 付近で構文解析エラー
ってころだろ。
"0"に特別な意味はなくて、SQL文中に"0"が出現したところあたりが怪しいってことだ。
勝手に想像すると、"SELECT * FROM ${table}0 ;" 見たいなSQLで
変数$tableが空だった為に正しいテーブル名が渡せなかったとか。

635 名前:nobodyさん mailto:sage [2007/07/26(木) 10:24:17 ID:???]
デバッグ出力時に、sqlも吐いとくとわかりやすい。
DB側のログに出すことも可能ではあるが



636 名前:nobodyさん mailto:sage [2007/07/26(木) 11:34:31 ID:???]
>>634-635
ありがとうございます。
参考になります。
これからソースとにらめっこ&デバッグして原因を探ってみます!

637 名前:nobodyさん mailto:sage [2007/07/26(木) 13:13:51 ID:???]
DBを一旦削除したあともう一回作ったら何故かうまく行きました。。
特に何もしてないんのだけど。。
作成にミスるって事もあるのかなぁ。

638 名前:nobodyさん mailto:sage [2007/09/22(土) 21:58:23 ID:???]
Perlで辞書検索CGIを書きましたが、DBI/DBD::Pgのあまりの遅さに辟易して、Pg使ってます。
各モジュールのパフォーマンスに関する記述ってあまりないようなんですが、皆さんはどちらを使っているのでしょうか。


ちなみに、作成したCGIはSELECT文を1回実行するもので、Dprofでプロファイリングしてみると
CGI全体でDBI/DBD::Pgで800ms、Pgで600msかかっていて、いずれも::INITで時間がかかっていました。

639 名前:nobodyさん mailto:sage [2007/10/09(火) 20:34:44 ID:???]
1台のPostgreSQLサーバーにデータベースをたくさん作っていたのですが、
これを1つのデータベースにまとめる方法はありませんか?COPYではできませんよね?
なお、テーブル名に重複はありません。


640 名前:nobodyさん mailto:sage [2007/10/23(火) 17:46:23 ID:???]
COPYでできると思うけど。
まあ、
pg_dump DBNAME1 | psql DBNAME2
とか繰り返せばいいんじゃない?
って久しぶりに見たからえらい遅レスになっちまった

641 名前:nobodyさん mailto:age [2007/12/20(木) 15:45:11 ID:???]
あるテーブルからSELECTする際に「別のテーブルに含まれていない」という条件を「Not IN」とかで
指定できたと思うんですが、この「Not IN」って名前なんて言うでしたっけ?
構文とかが良くわからないからGoogleろうと思ったけどnotとinって一般的過ぎて検索ワードにならないです
サブクエリ(副問い合わせ)だったかと思ったけど違ったし…。
www.postgresql.jp/document/pg721doc/reference/sql-select.html
にはNot IN自体載ってなかった…。

bash-2.05$ psql -V
psql (PostgreSQL) 7.1.3

642 名前:nobodyさん mailto:sage [2007/12/20(木) 16:53:36 ID:???]
>>641
IN述語でググれ。

よく「句」と間違えている人がいるようだが、
INやEXISTSは述語な。

643 名前:nobodyさん mailto:sage [2007/12/20(木) 17:16:36 ID:???]
>>642
ありがとうございます
ただ、「IN 述語」だと9万件以上引っ掛るのに
「IN 述語 postgre」だと30件ちょい…。

とりあえず↓がおもしろそうだから読んでみます!(・∀・)
www.geocities.jp/mickindex/database/idx_database.html

644 名前:641 mailto:sage [2007/12/20(木) 17:30:18 ID:???]
>>642
わかったー
SELECT カラム from テーブル where カラム IN (SELECT カラム from テーブル2);
で生けました。

PostgreのマニュアルってPHPのそれよか充実してないですよね…。
どっかいいサイトあったら教えてください

645 名前:641 mailto:sage [2007/12/20(木) 17:33:19 ID:???]
連投ごめんなさい
>>2にあった
PostgreSQL7.1マニュアル全文検索
osb.sra.co.jp/PostgreSQL/Manual/cgi-bin/namazu.cgi
これ、500エラー吐いてるけどタマタマですかね?
メンテされないのであればテンプレから外した方がいいのかな、と思いました。
1スレで4年以上もつからしょうがないけどw



646 名前:nobodyさん mailto:sage [2007/12/20(木) 17:47:31 ID:???]
>>645
みんなDB板 pc11.2ch.net/db/ に行ってるんで、
このスレは死に体。

647 名前:nobodyさん mailto:sage [2007/12/20(木) 17:51:35 ID:???]
>>643
せめて 「IN述語 PostgreSQL」でググれよ。

>>644
それだと 相関クエリをつかったEXISTSの方がいい。
特に7.1.xならなおさらINはなるべく回避してEXISTSを使うべき。

648 名前:nobodyさん [2008/01/14(月) 16:29:28 ID:VAusV2xL]
>>304にもあるけど、
postgresってrollback使えないんですか?

# select count(*) from *****
count
-------
11419
(1 row)

# Insert into ***** ( ***,***,***) values(2,1,'14-May-07');
INSERT 0 1

# rollback;
WARNING: there is no transaction in progress
ROLLBACK

# select count(*) from ors_win_lose_manage;
count
-------
11420
(1 row)

こうなってしまうのはなぜでしょう?





649 名前:nobodyさん mailto:sage [2008/01/14(月) 16:33:02 ID:???]
>>648
begin;

650 名前:648 mailto:sage [2008/01/14(月) 16:41:15 ID:???]
>>649
おぉ。。。ありがとです。






[ 新着レスの取得/表示 (agate) ] / [ 携帯版 ]

前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