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/
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