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/
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が同一になるって保証してたっけ?