PostgreSQL 2テーブル目
- 1 :nobodyさん:03/03/11 02:34 ID:9JR4latc
- PostgreSQLについて語って2万テーブルをめざしましょう。
関連アプリケーション特有の話題は、以下のスレッドへ。
pgsql-mlのヲチもここで。
前スレ
[PostgreSQL]
http://pc2.2ch.net/test/read.cgi/php/989375812/
☆関連スレッド
[PHP + PostgreSQL]
http://pc2.2ch.net/test/read.cgi/php/983128806/
[PerlでPostgreSQL]
http://pc2.2ch.net/test/read.cgi/php/999249463/
[MySQL vs PostgreSQL]
http://pc2.2ch.net/test/read.cgi/php/989341364/
- 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さん:2006/07/19(水) 22:17:41 ID:???
- >>504
initdb & PGDATA
- 506 :504:2006/07/20(木) 23:55:57 ID:???
- なんだ、コンパイルのオプションと違ったんだ。
ありがと。
- 507 :nobodyさん:2006/07/22(土) 00:36:09 ID:TflzrAiN
- http://pgfoundry.org/frs/?group_id=1000125&release_id=546
ここからダウンロードしたODBCだと文字化けするんだけど、何かご存じないですか?
鯖が7.4で、EUC-JP
クライアントはAccessとCSEで確認して化けらったです。
SET CLIENT ENCODINGはためしてみました。
以前に片岡さんのほうのドライバいれてました。
バージョンアップしてみたのは、numeric型を認識してくれないのと、
ADOでトランザクションの発行がうまくいかなかったからです。(´・ω・`)
- 508 :nobodyさん:2006/07/22(土) 00:37:57 ID:???
- >>507
http://www.geocities.jp/inocchichichi/psqlodbc/indexj.html
を使いましょう
- 509 :nobodyさん:2006/07/22(土) 07:31:10 ID:???
- ○○日間アクセスしてないユーザを削除する、という処理をさせたいんですが
Postgresだけでこれを実現する機能があれば教えてください
(OSの方で定期的にスクリプトを実行するのが普通なんでしょうか?)
- 510 :nobodyさん:2006/07/22(土) 17:56:12 ID:???
- cronかアクセスがあるごとに削除クエリ実行するしかないだろう
- 511 :509:2006/07/22(土) 18:14:09 ID:???
- やっぱりそうですよね。。。ありがとうございました
- 512 :nobodyさん: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さん: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さん:2006/08/02(水) 14:08:15 ID:???
- >>514
explainやったの?
- 516 :514:2006/08/02(水) 14:47:09 ID:IBuG4Wqs
- はい。そのへんの対策はだいたい。
- 517 :nobodyさん:2006/08/02(水) 18:06:07 ID:???
- >>516
なんでそれで修正できないんだ?
explainでseqになってるところにindexはるなり、テーブル分割するなり
したら基本的に全部なくせるはずだけど?
- 518 :514:2006/08/04(金) 12:12:04 ID:dYxM1faY
- >>517
集計関数が多いことが、大きな理由だと思います。
様々な角度で切り込まないといけないので、
中間テーブルを作るとなると膨大な量になってしまって。。。
- 519 :nobodyさん:2006/08/04(金) 12:24:10 ID:???
- >>518
で、結局君は何を求めてここに書いているわけ?
どんなテーブル構造になってるかも分からない、seq になる SQL も分からない。
それで、何をどうアドバイスしろ、と。
一言で言うと、「知らんがな」
- 520 :nobodyさん: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さん:2006/08/22(火) 14:03:02 ID:???
- make install
- 522 :nobodyさん:2006/10/21(土) 02:59:30 ID:???
- こんばんわ
http://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さん:2006/10/21(土) 03:53:49 ID:???
- current_timestamp のことではなくて?
- 524 :nobodyさん:2006/10/21(土) 03:59:12 ID:???
- >>523
タイプミスしないように¥dで表示されるTypeの項目から拾ってきちゃってた…
せめて"そんなデフォルトは指定できません"的なエラー吐いてくれれば…
ありがとうございました
- 525 :nobodyさん:2006/10/23(月) 04:52:02 ID:???
- 先輩が書いたコードを読んでたら
SELECT * from xxtablexx where xxcomunxx 〜 '^[ま-も]' ;
というqueryが書いてあったんですが、〜 '^[ま-も]'の【〜】の意味が分かりません、マニュアル等に載ってますでしょうか?
- 526 :nobodyさん:2006/10/23(月) 09:04:41 ID:???
- >>525
POSIX正規表現なんじゃないの?
- 527 :nobodyさん:2006/10/23(月) 18:03:17 ID:???
- hogeテーブルに各種データとtimestamp型でInsertされた日付が格納されているんだけど
日付=todayのように日付でみるんじゃなく、「何時間以内」という様な指定でデータを取得することは可能ですか?
@7.4です
- 528 :nobodyさん: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さん:2006/10/25(水) 12:03:50 ID:???
- >>529
根本的にSQLが間違ってる、って思わない訳?
- 531 :nobodyさん:2006/10/26(木) 00:18:23 ID:PySunuHV
- やはりそうですか。。
答えが見当たらなかった為、
今はselectで取得したキーを使って、
変数に格納してから、deleteを発行しなおしてます。
動作が遅くなりそうな気もしますが。。。
- 532 :nobodyさん: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
サブクエリで探して、以下のサイトを参考にしました。
もっと良いサイトもあるのでしょうけど、見つかりません^^;
http://www.istudy.ne.jp/ilnews/vol286/sql.asp
個人的には以下のサイトで見つけたいのですが。。
http://osb.sra.co.jp/PostgreSQL/Manual/PostgreSQL-8.1-ja/
- 534 :nobodyさん:2006/10/26(木) 16:41:56 ID:???
- >>533
なんかそれ以前の問題。
汎用的なSQL入門本でも買って読んだら。
2〜3日ありゃ十分読めるし、基礎だけでも
身に付けたほうが後々楽。
- 535 :nobodyさん:2006/10/27(金) 09:56:45 ID:???
- >>533
自分も「それ以前の問題」だと思う。
君が見付けたいサイトでは
http://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
http://www.amazon.co.jp/exec/obidos/ASIN/4798109576
- 537 :nobodyさん:2006/10/28(土) 00:20:10 ID:IIQMBUcS
- Postgres の列制約で、後から unique を定義することは出来ますか?
- 538 :nobodyさん:2006/10/28(土) 01:30:04 ID:???
- >>537
できる
- 539 :nobodyさん:2006/10/28(土) 10:55:59 ID:???
- >>538
バージョンは8.1なんですけど、持ってるの古い本で
その中では出来ないとか書いてあって、ネットで調べても出来ないって
あったんですけど
なんかそのあたりを書いてあるページを教えていただけないでしょうか
- 540 :nobodyさん:2006/10/29(日) 12:06:54 ID:???
- >>539
http://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さん: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:2006/11/03(金) 00:27:31 ID:???
- >>540
ありがとうございました
おっしゃるとおりです、以後気をつけまする
助かりました
- 544 :nobodyさん: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さん:2006/11/03(金) 19:25:10 ID:???
- >>544
WHERE句で
TO_CHAR(insert,'yyyy/mm/dd') = TO_CHAR(current_timestamp,'yyyy/mm/dd')
すれば今日のデータだけ取れるだろ。
- 546 :544:2006/11/03(金) 23:36:51 ID:???
- >>545
ごめんなさい、insertされてからX日以上たったレコードのstatusに操作を加えたいのです。
上記コードはその過程で「insert後一日以上たったレコード」をSELECTしています
- 547 :nobodyさん: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:2006/11/04(土) 00:25:07 ID:???
- >>547
試しましたが何日前のレコードでもSELECTされてしまいました。
SQLは日付なんかも結構柔軟に扱えそうなんですがスキル不足で…。
とりあえずはこのまま全件とってきてスクリプト側(PHP使ってます)で判定するようにしてみます
ありがとうございました
- 549 :nobodyさん:2006/11/04(土) 00:39:28 ID:???
- つーか、列名に insert はないだろ。
結局「今日」のデータがとりたいのか「X日以上経った」データをとりたいのかも分からん。
- 550 :544:2006/11/04(土) 00:50:26 ID:???
- >>549
最初、予約語だからダメだろうと思ったんですが試しにCREATE TABLEで使ってみたら通ったのでそのままでした。
最終的にとりたいのは「X日以上経った」データですが、いきなりだと難しいそうなので
「今日中に」INSERTされたデータをSELECTしようとしてみたりしました。
- 551 :nobodyさん:2006/11/04(土) 00:54:56 ID:???
- 「テーブル作成 & テストデータ数個 INSERT」の SQL 書いてくれれば
試してみても良いけど
- 552 :544: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: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さん: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さん: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: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さん:2006/12/01(金) 21:07:28 ID:???
- >>503
超遅レスだけど8.1.3に下のページのパッチを改造したものをあててなんとかしたことはある
http://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さん:2006/12/04(月) 04:13:30 ID:???
- >>558
date_trunc もしくは to_char で調べると幸せになれるかもね。
- 560 :nobodyさん:2006/12/08(金) 05:21:11 ID:???
- 8.2のウォームスタンバイって待機系にはリードオンリーでアクセスできる?
MySQLのレプリケーションみたいに
- 561 :nobodyさん: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さん: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:2006/12/13(水) 18:32:06 ID:???
- わるぃ、自己解決しちまった。
テーブルがいまいちうまく作成されていなかった。
(列無しテーブルになっていた)
いや、でも、文字コードのあたりは鬼門だねぇ。
- 564 :nobodyさん: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さん: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さん:2006/12/23(土) 15:55:43 ID:???
- >>565
>サーバーのポートは開いているようです
ちゃんと確かめれ
わからなけりゃ netstat -nlp|grep postmaster の結果貼れ
>>566
rpmでインストールしたのかtarballでインストールしたのかくらい書け
tarballならインストールされる場所が異なってるだけだと思われるが
- 568 :nobodyさん:2006/12/24(日) 01:03:37 ID:???
- >>567
お世話になります。
ソース提供の物をガイダンス(マニュアル)に従いgmakeしました。
インストールディレクトリはデフォルトで、各環境変数やpathも確認しました。
元々入っている旧の物が動いている可能性があるって事ですね。
もう少し調べてみます(週明けになってしまいますが)。
ありがとうございました。
- 569 :568です:2006/12/24(日) 01:07:34 ID:???
- 追伸
書き込み直後ですが、
PG_VERSIONファイルがあるディレクトリ(と言うよりdataディレクトリ全部)
を前もって消して、インストール後に新たに出来たのを確認して
その中のPG_VERSIONが7.3になるという事を思い出しました。
やはり7.3で作られてしまうとしか思えないです。。。
- 570 :nobodyさん: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さん:2007/01/14(日) 19:02:34 ID:???
- >>571
簡単に書くことは出来ません。
それ以前に、そんなSQLが実用的なのか考え直した方がいい。
- 573 :nobodyさん:2007/01/14(日) 19:07:49 ID:???
- >>572
ありがとうございました。
精進します。
- 574 :nobodyさん:2007/01/14(日) 23:50:14 ID:???
- ポスグレ対応の全文検索アプリ使えばいいんじゃネーノ
- 575 :nobodyさん:2007/02/05(月) 09:46:30 ID:???
- PGPOOLネタだが良い?
PGPOOLでレプリカしてるんですがPgAdminIIIでテーブル作るとOIDが微妙に1〜2ずれたテーブルが作成されてしまいます。
そのたびにDB1−>DB2にrsyncしてとかやっているんですが、根本的な原因がわかればと…。
そういうことってないですか?
- 576 :nobodyさん:2007/02/05(月) 11:10:14 ID:???
- >>575
そもそもpgpoolってOIDが同一になるって保証してたっけ?
- 577 :nobodyさん:2007/03/13(火) 19:51:29 ID:???
- こんばんは、かなり下がってるのでageます。
count(*)でレコード数も5800件くらいなのですが、処理が重いです。
単純にレコードの件数が知りたいだけなのですが…
http://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さん:2007/03/13(火) 20:40:25 ID:???
- >>577
COUNT(*)じゃなくて
COUNT(COLUMN_NAME)とかにすれば
少しマシになるかもしれんよ。
対象カラムはPKになってるのが良いと思う。
- 579 :nobodyさん:2007/03/13(火) 21:47:22 ID:???
- >>578
一部でそれが有用なRDBMSがあるようだがPostgreSQLでは効果ないよ。
>>577
そのSQLでは逐次スキャンは仕方ない。が、5800件程度のレコードなら
ちょっと遅すぎるな。VACUUM FULL;やって無効領域を飛ばせばどうだろうか。
1行がやたら滅多らでかい(巨大なtextやbyteカラムがある)場合は、外へ追い出すとか
するしかない。
- 580 :577: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さん:2007/03/14(水) 11:44:38 ID:???
- >>580
コスト増になるのは単にCBOがタコなだけだろうな。
> 1週間に一度ほどの間隔で、レコードが全てが入れ替わる
じゃ、きちんとメンテしないとだめだろうなぁ。
無駄なブロックまで走査しちゃうから。
- 582 :nobodyさん:2007/03/14(水) 12:48:12 ID:???
- count(*)は単純に行数が変えるが、
count(id)はidがNULLだったらカウントしないからね。
比較する分コスト増になっているのかも。
- 583 :nobodyさん:2007/03/14(水) 12:49:10 ID:???
- ×行数が変える
○行数が返る
orz
- 584 :nobodyさん:2007/03/14(水) 12:54:16 ID:???
- って、よく見りゃ算出コストは変わってないやん。
ANALYZEで実行時間が変わるのはキャッシュが
からんでんではねぇか。
- 585 :577: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さん: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さん: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さん: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さん:2007/05/27(日) 12:24:50 ID:???
- >>596
うちではprefになってる。都道府県のHPのドメインも
www.pref.〜
とかなってるし。
- 598 :nobodyさん: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さん:2007/05/29(火) 21:14:55 ID:???
- >>600
あんたの「ちゃんと」と定義する並びの文字コードを利用してください。
- 602 :nobodyさん:2007/05/29(火) 23:45:24 ID:???
- >>600
小学校で習わなかったか?
- 603 :nobodyさん:2007/05/30(水) 08:52:35 ID:???
- >>600
ちゃんとソートできてるよ。
それが嫌なら別のソート順確保用カラムでも追加するんだね。
195 KB
[ 2ちゃんねる 3億PV/日をささえる レンタルサーバー \877/2TB/100Mbps]
取りに行ったけどなかった。次は一時間後に取りに行くです。新着レスの表示
掲示板に戻る
全部
前100
次100
最新50
read.cgi ver 05.0.7.8 2008/09/25 アクチョン仮面 ★
FOX ★ DSO(Dynamic Shared Object)