PostgreSQL 2テーブル目
1 :nobodyさん :03/03/11 02:34 ID:9JR4latc.net 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/
2 :1C :03/03/11 02:40 ID:???.net 関連。 日本PostgreSQLユーザー会 http://www.postgresql.jp/ PostgreSQL7.1マニュアル全文検索 http://osb.sra.co.jp/PostgreSQL/Manual/cgi-bin/namazu.cgi
3 :nobodyさん :03/03/11 13:56 ID:???.net 前スレ963で「遅い」と書いた者です。 あのあとvacuum analyze とかやってたら 1.7秒くらいになりました。 以前はあったindex scanが逆に全くなくなってしまったのが不思議です。 explainで見るとHash Join、Hash Condばかり、ほとんどHashです。 また、order byの有る無しで時間が全く違っています。 無しにすると1秒縮まるのでソートに1秒かかってるようです。 並べ替えないわけにもいかないし・・・
4 :nobodyさん :03/03/11 18:56 ID:mhiQ8bxf.net 並び替えたい順のindexを作っておく。 必要な列は全部指定しておく。 列の指定順序に要注意。 JOINしてる場合も、各テーブルに つけておく。 これで改善されないか?
5 :nobodyさん :03/03/11 23:59 ID:???.net mod_perl なんですけど、finish しないとどうなるんでしょうか? メモリが開放されない?
6 :あぼーん :あぼーん.net あぼーん
7 :nobodyさん :03/03/15 00:37 ID:qfIx2KLL.net オフィシャルサイト http://www.postgresql.com/ 日本 PostgreSQL ユーザー会 http://www.postgresql.jp/ PostgreSQL7.2.3日本語ドキュメント http://www.postgresql.jp/document/pg721doc/ PostgreSQLメーリングリスト(pgsql-jp) http://www.postgresql.jp/PostgreSQL/pgsql-jp.html 改訂第3版 PC UNIXユーザのためのPostgreSQL完全攻略ガイド (シーラカンス本) http://www.gihyo.co.jp/books/syoseki.php/4-7741-1226-7 石井達夫氏の PostgreSQL information page http://www.sra.co.jp/people/t-ishii/PostgreSQL/ CSE - Common SQL Environment の つみき Web http://www.hi-ho.ne.jp/tsumiki/
8 :nobodyさん :03/03/15 13:37 ID:YPCssbUz.net >全スレ998 サンクス PHPとPostgreSQLの事で質問したものです。 PHPの方のmultipart文字コード変換ルーチンがバグってました、 ところでPHPの便利な検索サイトで"PHPマニュアル全文検索" というのを重宝してるんですが http://apollo.u-gakugei.ac.jp/man/php/namazu.cgi?query=php-mode&submit=Search%21&whence=0&max=50&result=normal&sort=score PostgreSQLでこんなサイト知らない? マニュアルは見るのですが探すのに時間かかるんで "PHPマニュアル全文検索"だと文字を打ち込んでボタン一発でマニュアルの中を検索してくれるんでとってもいいのだ。
9 :前スレ998 :03/03/15 16:09 ID:V2aA/g1w.net >>8 PostgreSQL7.1マニュアル全文検索 http://osb.sra.co.jp/PostgreSQL/Manual/cgi-bin/namazu.cgi 7.2.3 の検索をしたければ、自分で Namazu の検索を構築してね。 Namazu はそんなに難しくない。
10 :前スレ998 :03/03/15 16:11 ID:???.net ていうか >>2 にリンク張ってあるじゃん。 >>8 はちゃんとテンプレ読め。そして私も読め。
11 :nobodyさん :03/03/15 17:22 ID:YPCssbUz.net サンクス >9 >10 すまんですたい やっぱPostgreSQLにもおなじもんがあったんですね
12 :nobodyさん :03/03/15 23:37 ID:???.net http://search.net-newbie.com/cgi-bin/namazu.cgi ここにいくと、php も PostgreSQL7.2.3 も検索できます。
13 :nobodyさん :03/03/15 23:51 ID:???.net PHP+PostgreSQLケンサク (・∀・)イイ
14 :nobodyさん :03/03/16 01:10 ID:MfieTvGJ.net 長くてごめんね、もう1つ教えて CREATE TABLE t_encounter ( encounter_nu int4 primary key, encounter_na varchar(80), sex varchar(6), phone int, mail_add varchar(50), hometown varchar(6) ); という、encounterという名前のDBを作成しました PHPでDBに書き込むと Warning: pg_query() query failed: ERROR: parser: parse error at or near "0" in と、エラーがでます原因を考えると $sql = sprintf("INSERT INTO t_encounter". "VALUES(%d, '%s', '%s', '%d', '%s', '%s );", $encounter_nu, $_SESSION["post"]["encounter_na"], $_SESSION["post"]["sex"], $_SESSION["post"]["phone"], $_SESSION["post"]["mail_add"], $_SESSION["post"]["hometown"]); $res = pg_query($conn, $sql);$encounter_nu, ここのとこの変数の定義のやり方まずいのかな? "VALUES(%d, '%s', '%s', '%d', '%s', '%s );", よろしくね
15 :nobodyさん :03/03/16 01:17 ID:???.net で、$sqlは結局どうなっとるの?
16 :nobodyさん :03/03/16 01:41 ID:???.net とりあえずphoneがint型なのにクォートされている。 エラーとはちょっと違うけどな。 なんにせよ、echo $sql で確認汁
17 :nobodyさん :03/03/16 02:09 ID:MfieTvGJ.net どうもです $res = pg_query($conn, $sql);$encounter_nu, のあとに echo $sql を入れると Parse error: parse error, unexpected T_IF, expecting ',' or ';' in /home/hoge/public_html/transmission.php on line 105 となちゃうんだよね、ifの使い方がおかしいのだろうか?
18 :nobodyさん :03/03/16 02:14 ID:???.net 両方同時に学ぼうとしないで、まずはPHPの学習に専念すれば? 問題の切り分けが全然できてないじゃん。
19 :nobodyさん :03/03/16 02:18 ID:???.net >>17 そのpg_query()文の後ろにある、$encounter_nu, ってなによ。
20 :nobodyさん :03/03/16 02:19 ID:MfieTvGJ.net >18 らじゃ
21 :nobodyさん :03/03/16 02:34 ID:MfieTvGJ.net よろしく >19さん $encounter_nuはファイルを同時にアクセスして動作がおかしくならないように シーケンシャルでpostgreSQLが番号をふらないように、 テーブルロックをPHPの方でかけて pg_fetch_result()でテーブルから参照してDBのテーブル番号をインクリメント したものです $max_no = pg_fetch_result($res, 0, "max"); if (intval($max_no) == 0) { $next_no = 1; } else { $next_no = $max_no + 1; } pg_free_result($res);
22 :nobodyさん :03/03/16 02:38 ID:???.net SQLやPHPの前に日本語勉強せろ。
23 :乗りかかった舟 :03/03/16 03:07 ID:???.net >>21 >>22 に禿同なんだが、 >>17 の $res = pg_query($conn, $sql);$encounter_nu, って構文がおかしいだろ! その後ろにecho $sql;なんて入れてるからエラーが出るんだYO
24 :nobodyさん :03/03/17 01:36 ID:???.net ちょっとすいません、テーブルのしつもんです CREATE TABLE t_hoge ( numberint, namevarchar(80), sexvarchar(6), phoneint, mailvarchar(50), ); CREATE TABLE t_hoge ( numberint, namevarchar, sexvarchar, phoneint, mailvarchar, ); こうして変数のサイズを明示しなかった時に intとvarの変数の大きさをPostgreSQLはどれくらいの確保してるの?
25 :nobodyさん :03/03/17 01:38 ID:???.net TABキーが使えんのか....
26 :nobodyさん :03/03/17 02:26 ID:???.net マニュアルのデータ型の説明のところに載ってるよ。 intはintegerと同じ varcharは長さ制限無しらしい。
27 :nobodyさん :03/03/17 02:29 ID:???.net >26 ありがとさん
28 :nobodyさん :03/03/18 01:14 ID:???.net 4/1まで不在 キタキタキタ━━━(∀゚=゚∀゚=゚∀)━━━!!!!!!!
29 :nobodyさん :03/03/18 01:16 ID:iRf6zAa0.net サゲタ━━━━━━ヽ(゚Д゚)ノ━━━━━━ !!!!!
30 :nobodyさん :03/03/19 18:10 ID:8OO+f4X+.net みなさまはpgの自動バックアップってどうやってやてます? CRONでシェルスクリプトとか起動させてやってるんでしょうか? 漏れはシェルスクリプトとか分からないもんで、適当なperl 書いてそいつをユーザpostgresのCRONで起動してやってみた んだけどうまくいかないんす。 そのスクリプトは簡単に書くと下記の感じなんですけど (backup.cgi) #!/usr/bin/perl `pg_dump データベース名 > /usr/local/pgsql/backup/backup.out`; 普通にコンソールから./backup.cgiと直接起動させると出来るんだけど CRONからの起動だと0バイトのファイルが出来るのみ・・・?
31 :nobodyさん :03/03/19 18:23 ID:???.net su -c "pg_dump 〜" postgres をcronに仕込んだ気がする。
32 :あぼーん :あぼーん.net あぼーん
33 :nobodyさん :03/03/19 18:33 ID:???.net * Postgres: Postgres バックアップスクリプト #/bin/sh # PostgreSQL database backup script # Version 1.0 # Sep. 10, 2002 # sonic <sonic@example.com> # Dump to DATABASE_NAME_YYMMDD.pgdmp. # Output log. # Setting TARGET_DB='my_datebase your_database' # List target database name. DIR=/home/postgres LOG=${DIR}/pgdump.log BACKUPDIR=${DIR}/dbbackup # Main routine echo "pg_dump start." `date` >> ${LOG} date=`date +%Y%m%d` for db_name in ${TARGET_DB} do DUMP_FILE_PATH=${BACKUPDIR}/${db_name}_${date}.pgdmp /usr/local/pgsql/bin/pg_dump ${db_name} -b -o -Fc > ${DUMP_FILE_PATH} 2>>${LOG} echo "Database ${db_name} backup complete." `date` >> ${LOG} done echo "pg_dump complete." `date` >> ${LOG}
34 :33 :03/03/19 18:37 ID:zYXO3E0g.net 私は >>33 のスクリプトを、postgres スーパーユーザの cron で実行してる。 0 6 * * * nice -19 /home/postgres/pgd.sh みんなはどうしてる?
35 :nobodyさん :03/03/19 20:08 ID:8OO+f4X+.net >>33 なるほどぉ、漏れの場合は出来れば3日分のバックアップログを 取っておいて、4日前のバックアップは削除するみたいな機能を 付けたいのです。そうなるとPerlが使えると楽なんだけどなぁ。 ああ、なんで出来ないんだ?? シェルスクリプトでも出来るんだろうけど。。。。
36 :nobodyさん :03/03/19 20:15 ID:???.net >>35 logrotate使えば?
37 :nobodyさん :03/03/19 20:27 ID:8OO+f4X+.net >>36 サンクスでし。 logrotateとはこんなモンなんでしね。勉強すます。 ttp://www16.u-page.so-net.ne.jp/xb4/katsumi/os/linux/root/logrotate.html
38 :nobodyさん :03/03/19 23:52 ID:???.net >>30 なんで .cgi なのかワカランが。 その手のコンソールから OK で cron からダメってのはたいてい環境変数。 cron 実行時は .bash_profile とかは読まないから。 crontab の中で環境変数設定できるから、man 5 crontab せい。
39 :nobodyさん :03/03/21 22:44 ID:???.net 他人へのもののたずねかたを知らないのはらたつ。 「2ちゃんだから」って理由での態度ならなおさら。 そういう人は何やらせてもダメそう。 せっかく>>33 のスクリプト見せてもらってるのに それに4日前のバックアップを削除する機能すら付け加えられない無能くん。 せいぜいlogrotateくらいはまともにつかえるようにがんがってね。ハート
40 :あぼーん :あぼーん.net あぼーん
41 :nobodyさん :03/03/22 00:09 ID:???.net >>39 職場か戦場でいやなことでもありましたか? 空爆されたとか。
42 :nobodyさん :03/03/22 00:34 ID:???.net boardというテーブルから2chという文字列を検索しようと こうしたのだが、 Warning: pg_query() query failed: ERROR: Bad boolean external representation '2ch' となるんだけどどこがおかしのかわかりましぇーん 省略しすぎたけど一応PHPってことでたのんまふ。 $id = "2ch" ; $sql = "SELECT *FROM board WHERE '$id'" ; $result = pg_query(sql) ; 教えてくらはい。
43 :nobodyさん :03/03/22 00:38 ID:???.net print $sql; とすると SELECT * FROM board WHERE '2ch' になるのだが、 これは希望通りのSQL?
44 :nobodyさん :03/03/22 00:51 ID:???.net まちがえてました$が抜けてました^^; $result = pg_query($sql) ; 続きがあって if ($result) { print ("2chは見つかりました。"); if (!$result) { print ("2chはみつかりました。); というわけで、テーブルの中に"2ch"という文字が あるか無いかをしりたいんですけど。
45 :nobodyさん :03/03/22 00:52 ID:???.net すまそ print ("2chはみつかりました。"); です
46 :nobodyさん :03/03/22 00:55 ID:???.net >>41 あとMLで他人の署名まで全文引用するのもキライです。 いやなことありまくりです。そっとしといてください。 >>42 まともなsql文すら書けない人は行ってよし。
47 :nobodyさん :03/03/22 01:01 ID:???.net まともなsql文が書けたらし質問しない罠
48 :nobodyさん :03/03/22 01:08 ID:???.net >>47 何気に問題箇所は「sql文」だと>>46 は切り分けてるからなあ
49 :nobodyさん :03/03/22 01:23 ID:lQb2nQAC.net >>42 はboardというテーブルの 何て列に入ってるのかということに 実は気付いていないという罠(w
50 :nobodyさん :03/03/22 01:37 ID:???.net 結局みんななんだかんだ言って暗に教えてあげてるからやさすぃねw
51 :nobodyさん :03/03/23 00:43 ID:???.net column1 主キー(関係ないと思いますが一応) column2 数字 column3.4.5.... とあって、 同じ column2 のものがそれぞれいくつあるか、を出す為に select column2 , count(*) from table group by column2 と書いたのですが、 結果として 数字,個数 は出るんですが、エラーとして ERROR: Attribute table.oid must be GROUPed or used in an aggregate function と記録されてしまいます。 結果が出てるのにエラー文が出るというのが気持ち悪いんですが 何が間違ってるんでしょうか。
52 :nobodyさん :03/03/23 02:15 ID:T5828xOT.net >>51 バージョンはどうなってる?
53 :51 :03/03/23 02:27 ID:???.net >>52 7.3.2です。
54 :名無しさん@Emacs :03/03/23 03:47 ID:???.net 7.2.3だと出ないなぁ。
55 :nobodyさん :03/03/23 19:17 ID:???.net >>51 それって odbc 経由で Windows からつないでる? psql からやっても同じエラーでるの?
56 :nobodyさん :03/03/24 15:05 ID:Z0MnyWwn.net PL/PGSQL で Perl の join 関数みたいなストアドを作りたいんだけど、 なんかもっとスマートな方法無いでしょうか? 結果レコードのカラム名を変数で指定できると嬉しいんだけど、 Postgres 7.2.1 では変数展開してくれませんでした。 -- SQL の結果レコードに指定した文字列を挟んで連結して返す -- 引数1: 実行する SQL 文 -- 引数2: 挟み込む文字列 DROP FUNCTION join_str(TEXT, TEXT); CREATE FUNCTION join_str(TEXT, TEXT) RETURNS TEXT AS ' declare delimiter alias for $1; sql alias for $2; str text; rec record; is_first bool; begin is_first = true; str := ''''; FOR rec IN EXECUTE sql LOOP IF is_first THEN str := rec.serialnum; -- カラム名を指定 is_first := false; ELSE str := str || delimiter || rec.serialnum; -- カラム名を指定 END IF; END LOOP; return str; end; ' LANGUAGE 'plpgsql';
57 :nobodyさん :03/03/25 10:48 ID:???.net >>56 集約関数つかってみた。でもデリミタ指定できなくなっちゃった。 create function join_str_sfunc(TEXT, TEXT) returns TEXT as ' select case when $1 = '''' then $2 when $2 = '''' then $1 else $1 || '' '' || $2 end ' language 'sql'; create aggregate join_str ( basetype = text , sfunc = join_str_sfunc , stype = text , initcond = '' ); select join_str(field_name) from table_name;
58 :nobodyさん :03/03/25 17:13 ID:???.net >>57 replace関数。単細胞杉? CREATE TABLE 好物 (名前 VARCHAR(10) NOT NULL, 番号 INT NOT NULL, 好物 VARCHAR(50) NOT NULL, PRIMARY KEY (名前,番号)); insert into 好物(名前,番号,好物)values('おれ', 3, '皮'); insert into 好物(名前,番号,好物)values('おれ', 2, 'レバー'); insert into 好物(名前,番号,好物)values('おれ', 1, 'ビール'); insert into 好物(名前,番号,好物)values('他人', 3, '手羽先'); insert into 好物(名前,番号,好物)values('他人', 2, 'つくね'); insert into 好物(名前,番号,好物)values('他人', 1, '日本酒'); select 名前,replace(join_str(好物),' ','@') as 好物 from 好物 group by 名前; 名前| 好物 ----+---------------------- おれ|ビール@レバー@皮 他人|日本酒@つくね@手羽先 ところで join_str の結合順序ってコントロールできるんですか?
59 :57 :03/03/25 17:46 ID:???.net 結合順序コントロールするにはサブクエリにするしかないかも。 select 名前 ,replace(join_str(好物),' ','@') as 好物 from (select * from 好物 order by 好物) as k group by 名前; 既に全然スマートじゃないという罠。
60 :nobodyさん :03/03/25 22:02 ID:???.net >>59 すごいでつね。正規化したのはいいけれど、動的配列を繋げて一行で取り出すのって一苦労。 集約関数は奥が深い深い。勉強になります。 うちはまだ、好物1,好物2, ...., 好物25 をくっつけてますよ。
61 :56 :03/03/26 11:32 ID:???.net >>57-59 なるほどー。すごく勉強になりました。ありがとう。 ちなみに、7.2.1 では replace() が使えませんでした。 7.3.2 では使えました。 同じマシンに異なるバージョンの Postgres をインストールするのって、 簡単にできるんですねえ。
62 :nobodyさん :03/03/27 17:09 ID:???.net > 火災と申します プロジェクトに「火がついた」か。
63 :nobodyさん :03/03/27 17:12 ID:???.net >>62 はやっ! (w
64 :nobodyさん :03/03/28 01:24 ID:???.net 7.2.2で日付計算をやっています。 test=# select CURRENT_DATE - '2001-12-01'::DATE > '2 month'::INTERVAL; ?column? ---------- f (1 row) となるのが・・・なんでだろ〜(´Д`;) DATE型じゃなくてTIMESTAMP型にすると ちゃんとtrueで帰ってくるのですが……
65 :nobodyさん :03/03/28 01:38 ID:???.net >>64 # SELECT (CURRENT_DATE - '2001-12-01'::DATE); ?column? ---------- 482 どうも返り値がinteger型のようだ。
66 :64 :03/03/28 13:45 ID:???.net >>65 integer型のようですね(´Д`;) 結局 # select CURRENT_DATE - '2 month'::INTERVAL >= '2001-12-01'::DATE; ?column? ---------- t (1 row) としたら動きました。うーむ謎〜。 #よくわかってないだけかも。
67 :nobodyさん :03/03/28 17:21 ID:???.net データの作成って、みなさんはどんな方法を採ってます? MicrosoftのAccess で入力フォームを作って、それをテキストにexport、 文字コード等を適当なものに変換、最後にcopy コマンドでpostgres に 持ってくる、という煩雑なことをしているのですが、もうちょっとなんとか ならないのかな??と悩んでまして。。。
68 :nobodyさん :03/03/28 19:11 ID:???.net >>66 DATE型 - TIMESTAMP型 = INTERVAL型 で DATE型 - DATE型 = INTEGER型 なんだよな。 仕様なのかバグなのかMLで聞いてみれば。 いc氏あたりが答えてくれるかも。
69 :nobodyさん :03/03/29 02:18 ID:???.net >>67 なんか省略してないか。 とりあえずAccess使うならODBCでPostgreSQKに接続すればいいだけだが。
70 :nobodyさん :03/03/30 15:36 ID:/7/BL2Cw.net [pgsql-jp: 29501] DELETEコマンドの使い方について。 釣り日和でつ。 , ,/ヽ ,/ ヽ ∧_∧ ,/ ヽ ( ´∀`),/ ヽ ( つつ@ ヽ __ | | | ヽ |――| (__)_) ヽ  ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄| ヽ /⌒\/⌒\/⌒\/⌒\|彡~゚ ゜~ ~。゜ ~ ~ ~ ~~ ~ ~~ ~ ~~ ~~ ~~ ⌒\/⌒\/⌒\/⌒\/⌒\彡 〜 〜〜 〜〜 〜〜 〜 〜
71 :nobodyさん :03/03/30 15:50 ID:dniM4gxK.net PostgreSQLをWindowsでcygwinを介さないで使うことはできませんか?
72 :nobodyさん :03/03/30 16:41 ID:???.net >>71 PowerGres (PostgreSQL on Windows) 〜オープンソースデータベースのスタンダード "PostgreSQL" を Windows で〜 http://osb.sra.co.jp/PowerGres/introduction.php
73 :71 :03/03/30 17:29 ID:???.net >>72 へぇ〜できるんですね。ありがとうございます。 欲を言えば、PostgreSQLの開発元がなんとかして欲しいものです。
74 :nobodyさん :03/03/30 17:48 ID:???.net >>72 有償なのはいいとしても、ソース公開じゃないから、単なる 「Windowsで動作するPostgreSQL互換RDBMS」にしか 過ぎなくなっちゃったんだよね。 石井さんはPostgreSQLがオープンソースであるメリットを 熱く語っていたけど...。
75 :nobodyさん :03/03/30 18:27 ID:???.net >>74 商売としてはしかたないと思うんだけど、SRAはPostgreSQLがWindowsで動く道を閉ざしてしまった気がする。
76 :nobodyさん :03/03/30 23:07 ID:???.net >>74 BSD ライセンスのオープンソースだからこそ、 こういった派生品でのビジネスもできる。 そして、オープンソースは、関わる人間の多さが成功の要。 たとえ派生品でも、ベースとなる製品についての知識を有する人が 一人でも増えるのは喜ばしいことだよ。 増えたうちの一人がほんの少しでも本家にコミットしてくれるなら、 最終的に本家の利益にもつながる。 >>75 メールの本文はほとんど読まずに、Subject しか読んでないから全然詳しくないんだけど、 本家の postgres-hackers ML では MS Windows 版の話とか出てるよね。 7.4 でネイティブサポートするとか書いてあったような。
77 :nobodyさん :03/03/30 23:24 ID:???.net >>76 ttp://hp.vector.co.jp/authors/VA023283/PostgreSQL.html ttp://hp.vector.co.jp/authors/VA023283/PowerGres.html 本家はプロセスモデルでPowerGresはスレッドモデルってことでいいかな。
78 :nobodyさん :03/03/31 07:13 ID:???.net >>76 SRAはPowerGresを本家にフィードバックするんだろうかね?
79 :nobodyさん :03/03/31 13:53 ID:???.net 現場は、フィードバックすると言っているがね。 ただ、(WindowsのスレッドモデルをUNIXに持ってくることに) どの程度意味があるかは分からん。 S○Aも、UNIXでいくならUNIX一本でもっと機能拡張とかすればいいのに。 中途半端にUNIXもWindowsも手を染めてどうすんだか。
80 :質問です。 :03/04/01 17:16 ID:0gCa7Sb2.net ポスグレって Windows版 ってないのですか?
81 :nobodyさん :03/04/01 17:19 ID:???.net , ,/ヽ ,/ ヽ ∧_∧ ,/ ヽ ( ´∀`),/ ヽ ( つつ@ ヽ __ | | | ヽ |――| (__)_) ヽ  ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄| ヽ /⌒\/⌒\/⌒\/⌒\|彡~゚ ゜~ ~。゜ ~ ~ ~ ~~ ~ ~~ ~ ~~ ~~ ~~ ⌒\/⌒\/⌒\/⌒\/⌒\彡 〜 〜〜 〜〜 〜〜 〜 〜
82 :nobodyさん :03/04/02 01:19 ID:???.net [pgsql-jp: 29545] 削除依頼 祭りか徹底無視か?
83 :nobodyさん :03/04/02 01:37 ID:???.net あら、意外とすんなり収束したね。
84 :nobodyさん :03/04/02 17:32 ID:???.net >>83 時間が時間だけに。 オマケはついたが。
85 :nobodyさん :03/04/04 06:06 ID:PaLgsWqP.net PostgreSQL7.3.2のDB(文字コードはEUC_JP)に、psqlから set client_encoding to 'SJIS'; を実行すると、 Conversion between SJIS and EUC_JP is not supported. となってしまいます。 PostgreSQLのlib/にはそれらしき(?)、euc_jp_and_sjis.so があります。 一体何が原因なんでしょうか?
86 :nobodyさん :03/04/05 00:01 ID:???.net うーんなんでだろ。 select * from pg_convertion (だったかな) とかはヨサゲ?
87 :nobodyさん :03/04/05 05:05 ID:???.net insert や delete に Left join を使うとエラーがでるのですが、 ポスグレではselect文だけにしか使えないのでしょうか? だとしたら2つのテーブルを比較して足りないモノだけを 1方のテーブルに追加していく、なんてことはできないのでしょうか? やれるとしたらどんな手段があるか、参考になるサイトがあれば教えてください。
88 :nobodyさん :03/04/06 17:10 ID:iXfPNuQP.net 既存のディスクが一杯になってきたので、ディスクを追加して、 今後は「今までのディスク+追加したディスク」を使いたいのだが可能なの? やっぱり、一つのデータベースが複数のディスクにまたがるのは無理なのかなぁ
89 :nobodyさん :03/04/06 18:13 ID:???.net >>87 普通にできましたが。 バージョンは? どんなsqlでエラーになったの? どんなエラーが出たの? オレは釣られたの?
90 :nobodyさん :03/04/06 22:20 ID:???.net >>89 メール欄
91 :nobodyさん :03/04/07 00:49 ID:???.net cygwinでPostgreSQL動かしてJavaのJDBC+ODBCでアクセス してみたら、読み込みはうまくいったけど書き込みは 文字化けしてテーブルに書き込まれてしまった。 文字コード調べてみたらSJIS->EUC-JPのような変換が 行われ、そのEUC-JPのコードをSJISで見たときの文字化け のままテーブルに書かれてしまった感じ。 解決策があったら教えてください。
92 :91 :03/04/08 00:41 ID:???.net 自己解決。 jdbc:postgresql:test?charSet=SJIS デコードの指定を付けたらすべてうまくいきました。
93 :nobodyさん :03/04/09 03:20 ID:Ub7v47GH.net ところで、PowerGres、どうよ? PostgreSQLでできること、全部できる?
94 :あぼーん :あぼーん.net あぼーん
95 :nobodyさん :03/04/09 06:30 ID:???.net >93 誰も買ってない悪寒。だから言ったのに・・・。
96 :nobodyさん :03/04/09 19:01 ID:xm6OICY+.net >93 Ver7.4のWindowsネイティブ対応っぷり次第だな。 それまで待てれば待ったほうがいい。
97 :nobodyさん :03/04/10 11:21 ID:???.net ひょっとしてPostgreSQLのパターンマッチングって同じ文字の連続(aaa、あああ など)って検出できない?
98 :nobodyさん :03/04/10 11:50 ID:???.net >>97 はぁ? おまえができないだけでしょ。
99 :nobodyさん :03/04/10 12:29 ID:???.net w)
100 :nobodyさん :03/04/10 15:51 ID:???.net >>98 うそだ! select * from table where string ~ '(.)\1\1'; とかできなかったぞ!できるというなら例を見せてみれ!
101 :nobodyさん :03/04/10 18:42 ID:Gvrywi5t.net 特定のフィールドを指定してセレクトするのではなく、 逆に、「あるフィールド以外すべてセレクト」というふうなクエリーはかけないのでしょうか?
102 :nobodyさん :03/04/10 20:08 ID:???.net >>100 where string ~ 'a{3}';
103 :102 :03/04/10 20:27 ID:???.net ん? 勘違いしてた。
104 :nobodyさん :03/04/10 22:07 ID:???.net >>103 だよね。できないよね?
105 :nobodyさん :03/04/10 22:22 ID:???.net >>101 WHERE foo <> 'ある条件';
106 :nobodyさん :03/04/11 01:37 ID:???.net >>101 105は間違い。 SELECT ~hogehoge WHERE ... チルダをつければいい
107 :nobodyさん :03/04/11 01:46 ID:nN51pMH3.net >106 そっか!ありがと。試してみます。
108 :nobodyさん :03/04/12 16:38 ID:???.net >>106 おいおい(w
109 :nobodyさん :03/04/12 19:46 ID:UOkuI+UD.net 気づくの遅すぎ(藁
110 :nobodyさん :03/04/13 15:52 ID:???.net >>107 騙されるな SELECT ^hogehoge だぞ
111 :nobodyさん :03/04/13 20:29 ID:???.net >>107 昔は SELECT !hogehoge と書いたもんだ
112 :nobodyさん :03/04/15 14:02 ID:???.net >>111 あんたかなりのベテランだな 一部のDBでは SELECT `hogehoge だったころもあるね
113 :nobodyさん :03/04/16 13:29 ID:sI0EuNRH.net つーか SELECTしたい列名なんて明示的に書くのが王道だろ それとも テーブル設計をコロコロ変えやがるのかと小一時間...
114 :山崎渉 :03/04/17 12:01 ID:???.net (^^)
115 :33 :03/04/17 13:09 ID:???.net >>35 n 日前のバックアップファイルを削除する、という機能が欲しくなったので付けてみた。 find と xargs コマンドが必要。 find ${BACKUPDIR} -type f -daystart -mtime +${EXPIRE_DAY} |xargs /bin/rm -f 全文は長いので >>116 に張ります。必要ないって? そんなこと言わないで・・・。
116 :33 :03/04/17 13:09 ID:???.net #/bin/sh # PostgreSQL database backup script # Dump to DATABASE_NAME_YYMMDD.pgdmp. # Delete expired files. # Output log. # Setting TARGET_DB='firstinfo tka' # List target database name. DIR=/home/postgres LOG=${DIR}/pgdump.log BACKUPDIR=${DIR}/dbbackup EXPIRE_DAY=90 # Main routine echo "pg_dump start." `date` >> ${LOG} date=`date +%Y%m%d` for db_name in ${TARGET_DB} do DUMP_FILE_PATH=${BACKUPDIR}/${db_name}_${date}.pgdmp /usr/local/pgsql/bin/pg_dump ${db_name} -b -o -Fc > ${DUMP_FILE_PATH} 2>>${LOG} echo "Database ${db_name} backup complete." `date` >> ${LOG} done echo "pg_dump complete." `date` >> ${LOG} echo "Delete obosolete pgdmp files start." `date` >> ${LOG} find ${BACKUPDIR} -type f -daystart -mtime +${EXPIRE_DAY} |xargs /bin/rm -f echo "Delete obosolete pgdmp files complete." `date` >> ${LOG}
117 :山崎渉 :03/04/20 06:27 ID:???.net ∧_∧ ( ^^ )< ぬるぽ(^^)
118 :nobodyさん :03/04/23 02:29 ID:b3QZu4Pm.net PostgreSQL のデータベースを UTF8 で作ったとき、日本語の入ったカラムに ORDER BY かけると JIS 漢字順ではなくなるのかな?
119 :nobodyさん :03/04/23 23:03 ID:???.net linさんのコメントにどんな意図があるかは知らないけど サイトのJavaScriptでしばらく楽しんでしまった。。。
120 :あぼーん :あぼーん.net あぼーん
121 :nobodyさん :03/04/24 19:29 ID:Q1w3nY2w.net 質問です。 複数のカラムを対象に、selectしたいのですが、どう書けばよろしいでしょうか? mysqlだとFull Text Searchとあると思うのですが、Postgresでできますでしょうか?
122 :nobodyさん :03/04/25 11:28 ID:???.net 管理ツールDbVisualizerってどうよ? http://www.minq.se/products/dbvis/index.html Javaアプリだけど、個人的には好感触。
123 :nobodyさん :03/04/25 12:18 ID:???.net >>122 psqlで十分。 エディタもviでいい。 巡回ダウソもwgetでいい。 なんてなぁ、新しいのを覚えられないだけ。 CSE入れてみたけど起動してみて、 さ ぁ ど う し た も の か と 小 一 時 間 ...
124 :nobodyさん :03/04/27 05:21 ID:???.net >>121 意味わかんね。 select * from table ってやれば複数のカラム対象にselectできてるし。
125 :nobodyさん :03/04/27 12:54 ID:???.net >>121 Full Text Searchって全文検索? NamazとかKakasiでも使うかしかないんでないの? 全文検索な時点でDBが面倒見ないといけない機能でもないような気がする。 単純に複数カラムにを検索条件に掛けたいなら地道にSQL書きなはれ。 SELECT A.id FROM A,B WHERE A.id = B.id AND A.firstname = "あああ" AND B.adress = "あああ" みたいな。 こんなSQL使う時点で、設計ミスか余計な機能な気もするけど。
126 :nobodyさん :03/04/27 21:48 ID:RGglVdIs.net psqlからのcopyコマンドで"\N"という文字列がテーブルに入れれない・・・(WITH NULL AS指定はなしで ) "\b"、"\n"、"\."は "\\b"、"\\n"、"\\."に変換すれば入るのに・・・ "\N"は"\\N"に変換してもだめ・・・ "\N"という文字列はだめなんでしょうか?
127 :nobodyさん :03/04/27 21:51 ID:ClMbC1OP.net >>121 第一正規化、って知っていますか?
128 :121 :03/04/27 21:52 ID:u/4ug4s4.net >> 124 失礼しました。whereで複数カラムを指定するという意味です。 >> 125 全文検索というと、確かにNamazuとかそういう方向いっちゃいますね。 単純に複数カラムを検索条件にかけたいだけです。 where andでつなぐと遅くなるので、(レコード数が230万件あるので) mysqlのFull Text Searchつかったらと先方にいわれ、いまさら乗り換える のはややこしいので、Postgresでもそういう機能がないかと探しておりま した。 設計ミスか余計な機能ではとありますが、検索対象の列が5つあって、 最初はそれぞれにかければいいという仕様でしたが、5つのどれかに ヒットするようにしなさいと仕様が変更されたのです。 他に方法あるでしょうか? って自分で考えろという感じですが、 いろいろと調べてはいるのですが、思いつきません。。
129 :nobodyさん :03/04/27 22:21 ID:???.net >>128 ふつうにorすればいいのでは。。。
130 :121 :03/04/27 22:41 ID:u/4ug4s4.net > 129 すいません、where andではなく、where or で、遅くなるという意味です。
131 :nobodyさん :03/04/27 23:03 ID:???.net >>128 >設計ミスか余計な機能ではとありますが、検索対象の列が5つあって、 >最初はそれぞれにかければいいという仕様でしたが、5つのどれかに >ヒットするようにしなさいと仕様が変更されたのです。 そんなの、仕様変更されるのが当たり前だな。 仕様変更に対応できるようにしてなかった設計ミス。 ところで、230万件×5の全文検索ってMySQLなら速くできるのかな?
132 :nobodyさん :03/04/27 23:07 ID:???.net >>130 検索対象のカラムにindexは張ってあるの?
133 :122 :03/04/27 23:32 ID:???.net >>123 psqlで充分ってか。ある意味うらやますぃ。 個人的には使っていこうと考えているけど、確かにpsqlで充分かもね。
134 :nobodyさん :03/04/28 01:11 ID:???.net >>132 index張ってあっても、like '%語句%'で検索するなら意味ないと思われ。
135 :132 :03/04/28 02:16 ID:???.net >>134 あー、likeで%から始まる奴は駄目だね。 ホントに全文検索っぽくやってるとしたら、like '%語句%'ってやってる 可能性は高いか。 121にもうちょっと情報を出してホスィところだなぁ。
136 :nobodyさん :03/04/28 11:27 ID:???.net where coalesce(列1,'') || coalesce(列2,'') || coalesce(列3,'') like '%検索ワード%'explain してみたら、costは同じだけどrowsは or より少ないよ
137 :121 :03/04/28 13:42 ID:carn+S7w.net >> 134,135 ご指摘の通り、like '%語句%'とやっております。 実は今からでもテーブルの設計は変更可能なのですが、 どのように変更したらよろしいでしょうか。 今はID,NAME,AA,BB,CC,DD,EEというカラム構成で、 AA,BB,CC,DD,EEの中で、どれかに検索キーワードがあればヒットする というようにしたいです。 >> 136 こちらありがとうございます。 coalesceってこういう時に使うのですね。習ってはいたのですが、 いつ使うんだろと思っていました。勉強になります。
138 :nobodyさん :03/04/28 15:37 ID:???.net >>121 >>127
139 :nobodyさん :03/04/29 11:45 ID:???.net textの部分一致は、例えば「abcdefg」という文字列があったとして、 like '%cd%' とすると遅くなるから、 abcdefg bcdefg cdefg defg efg fg g というテーブルを別に作って、like 'cd%' すると速くなるよ、と 言われたことがある。もちろん、インデックス作って。 実際自分でやってみたことはないが。
140 :121 :03/04/29 18:01 ID:JKdqeuMi.net >> 127 正規化については、こちらを読みました。 http://www.rfs.jp/sitebuilder/sql/01/06.html 今回のケースとは特に関係ないかと思うのですが、私の洞察力不足でしょうか。 >> 139 ありがとうございます。 そこまでやると複雑になるので、おとなしくMySQLに移行するかと思って しまいます。。
141 :nobodyさん :03/04/29 19:13 ID:8zWvKIjl.net http://my.vector.co.jp/servlet/System.FileDownload/download/ftp/0/281853/pack/win95/game/table/pachinko/SUTING.LZH
142 :あぼーん :あぼーん.net あぼーん
143 :しろ :03/04/30 09:50 ID:???.net >140 > 正規化については、こちらを読みました。 > http://www.rfs.jp/sitebuilder/sql/01/06.html > 今回のケースとは特に関係ないかと思うのですが、私の洞察力不足でしょうか。 今回のケースと関係あるかないかどうかは「ID,NAME,AA,BB,CC,DD,EE」では判りません。 NAME,AA,BB,CC・・・が、名前、住所、電話番号、メールアドレス・・・などだったら この部分に関しての正規化の必要はないかもしれません。 しかし、NAME,AA,BB,CC・・・が、担当者、商品名A、商品名B、商品名C・・・などだったら 必要ありますね。 とうわけで、あなたの洞察力不足かどうかは、構造がわからないので なんともいえないです。
144 :nobodyさん :03/04/30 14:44 ID:???.net 正規化汁!と言ったひとの早とちりでしょう。
145 :121 :03/04/30 22:31 ID:0656yZRu.net >> 143 NAME,AA,BB,CC・・・は、担当者、商品名A、商品名B、商品名C・・・という 構造です。特にカラムが一緒ではないので、正規化は関係ないかと思うのですが、、、 ちがいます?
146 :nobodyさん :03/04/30 22:44 ID:???.net >>145 それって、担当者「NAME」が最近扱った商品A、B、C、Dとか…? そういうパターンだったら正規化の対象だと思ふ。
147 :146 :03/04/30 23:01 ID:???.net (担当者テーブル:tantou) id,name,address,tel… (担当者id,担当者名,住所,電話番号…) (商品テーブル:item) id,name,price,registrant_id,regist_date… (商品id,商品名,価格,登録者id,登録日時…) SELECT tantou.name, tantou.address, item.regist_date FROM tantou, item WHERE tantou.id = item.registrant_id AND tantou.name = "AAA" AND item.name like "%BBB%" みたいな感じにはなんないでしょうか? NAME,AA,BB,CC・・・は、担当者、商品名A、商品名B、商品名C というカラムにならないといけない状況があまり想像つきませぬ。。
148 :146 :03/04/30 23:06 ID:???.net 最近の5件だったらこうか…。 (憶測しすぎだったらスマソ) SELECT tantou.name, tantou.address, item.regist_date FROM tantou, item WHERE tantou.id = item.registrant_id AND tantou.name = "AAA" AND item.name like "%BBB%" ORDER BY item.regist_date LIMIT 5
149 :nobodyさん :03/05/01 20:08 ID:???.net PostgreSQLってテーブル名とかフィールド名が大文字英数だと、 SQL書くときテーブル名, フィールド名をダブルクォーテーションで くくらないといけないんだな。 なんでこんな仕様になってんだ?
150 :nobodyさん :03/05/02 09:43 ID:???.net >>149 それは予約語とかぶった時の話では?
151 :nobodyさん :03/05/02 20:04 ID:???.net 2つのテーブルの両方のカラム(同じなまえ)にデータが存在するかどうかを 確認するために以下のようにしているのですが、うまくいきません。 どこか間違っているのでしょうか? SELECT 1 FROM TBL1, TBL2 WHERE TBL1.ID!='hoge' AND TBL2.ID!='hoge'; SELECT 1 FROM TBL1, TBL2 WHERE TBL1.ID='hoge' OR TBL2.ID='hoge';
152 :nobodyさん :03/05/02 20:54 ID:ixQKgJiY.net >>151 intersect
153 :nobodyさん :03/05/02 20:57 ID:???.net >>151 上は「両方ともhogeじゃない」 下は「TBL1のIDがhogeもしくはTBL2のIDがhoge」
154 :nobodyさん :03/05/02 21:05 ID:???.net SELECT 1 FROM TBL1, TBL2 WHERE TBL1.ID = TBL2.ID AND TBL1.ID = 'hoge';
155 :402 :03/05/03 00:55 ID:???.net >>149 大文字の混ざった識別子をダブルクォートするのは PostgreSQLの仕様というよりSQL92の仕様のはずです。
156 :nobodyさん :03/05/04 18:28 ID:???.net ここで聞くのが適当かどうかわかりませんが、まったく同じSQLでWeb上からの アクセス結果とスクリプトやコマンドインタプリタからのSQL実行結果 とが違うので悩んでおります。以下がそのSQL文です。 SELECT 1 WHERE EXISTS(SELECT 1 FROM TBL1 WHERE ID='hoge') OR EXISTS(SELECT 1 FROM TBL2 WHERE ID='hoge'); Web上からの処理結果がうまく表示されません。それぞれ2つのSQLだとWeb上 でもうまく表示されるのですが・・・ 因みに mod_perl を使っていますが、きちんと use strict して変数はすべて my で 宣言しています。もちろん grant もしています。
157 :nobodyさん :03/05/05 00:34 ID:V6Q641Ow.net >>156 何か見るからに変なSQL書いてるな。 具体的に何がどう違う結果になってるのか書け。 あと全部Perlで試しているのか?それともpsqlか?
158 :nobodyさん :03/05/05 00:40 ID:???.net >>157 コンソールからはPerlで書いたスクリプトで、存在しているIDをときはきちんと 1を返します。 psql(コマンドインタプリタ)からでも同じSQLだと同じ1を返します。 ただ、Web上からPerlで書いたCGIに同じSQLを実行させた結果、0を 返します。因みにDBIとDBD−Pgを使って永続接続させています。
159 :nobodyさん :03/05/06 16:42 ID:???.net >>158 文を SELECT 1 WHERE true; みたく単純にしてみて、同じコトをやってみたら?
160 :nobodyさん :03/05/10 12:46 ID:???.net >>158 PostgreSQLに接続するユーザーの問題では? ユーザーを明示的に指定してやったらどうよ?
161 :nobodyさん :03/05/13 09:51 ID:77a0e79m.net プログラミングではなく、運用の質問なんですが、 Postgresの監視って、プロセス上がってるかどうか 程度でいいですかねぇ?
162 :nobodyさん :03/05/13 11:44 ID:???.net >>161 ・プロセスあがってるかどうか監視 ・最大プロセス超えてないかどうか監視 ・クエリーの応答時間が甚だしく増えていないかどうか監視 くらいじゃねーの? ディスク容量とかも必要かも試練が こっちは鯖の監視の範疇に入るかな
163 :nobodyさん :03/05/13 11:47 ID:sZdPhQWk.net >>161 接続できるかどうかぐらいはテストしたら?
164 :161 :03/05/13 17:15 ID:77a0e79m.net >>162 サンクスです。 >>163 シェルで一発で済ましてしまいたんですよ。 ベンダにやってもらうので そこまでやってもらうと お金の問題が出てきそうなんですよね。 mysqladmin pingみたいのがあれば と思ったんですが・・・・・・。 ありがとうでした。
165 :nobodyさん :03/05/14 05:36 ID:aknt5UHd.net 原因がまったく解明しないため、質問させていただきます。 今までどおり、 if($r->resultStatus ne PGRES_TUPLES_OK){ return 0; } このようにselectが正常にとおってるかサブルーチン内で チェックさせていたのですが、ある時からなぜか PGRES_TUPLES_OKがそのまま「PGRES_TUPLES_OK」 となってしまい、この照合も「2 ne PGRES_TUPLES_OK」 となり、照合エラーとなってしまいます。 考えられる原因があれば、どうかご教授ください。 よろしくお願いいたします。
166 :nobodyさん :03/05/14 07:26 ID:???.net >>165 この情報からだとスペルミスか、何らかの理由で定数のimportが できなかったのかというくらいしか思いつかんが。 原因はわからんが、そういうミスを事前にチェックできるよう、use strict; を 使うのが常識。あと、PGRES_TUPLES_OKは整数なので、比較は ne じゃ なくて != でよい。
167 :165 :03/05/14 21:34 ID:aknt5UHd.net 原因が判明しました。しかし、その意味がどうしてもわかりません。 if($r->resultStatus ne PGRES_TUPLES_OK){ return 0; } という処理は「db.pl」というファイルの中のサブルーチン「db_command」 内で行っていたのですが、このファイルのパッケージ名を「db(package db;)」 としました。 違うファイル「select.cgi」より「db.pl」をrequireし、サブルーチン 「db_command」を「db::db_command($sql)」と呼び出していたの ですが、この呼び出し方に問題がありました。 パッケージ管理せず、「db_command($sql)」と呼び出すと、結果が 返ってきます。strictでも何にもエラーがはかれません。 原因はわかりましたが、その意味が不明です。 勉強不足で申し訳ないです。
168 :165 :03/05/14 23:48 ID:???.net またもや自己解決。。。ようやくわかりました。 Pg::PGRES_TUPLES_OK これだけです。これで解決しました。 いろいろと失礼致しました。
169 :nobodyさん :03/05/18 19:21 ID:EvuGQeIP.net 「40万件有るデー」って、いなかのスーパーの安売りみたいですね。
170 :nobodyさん :03/05/18 20:08 ID:???.net >>169 漏れは関西弁かとおもたYO!!!
171 :nobodyさん :03/05/18 20:08 ID:???.net しょーもないカキコでageるなコラ。
172 :nobodyさん :03/05/18 21:06 ID:5+xOckh5.net PostgreSQLはなんでshift−jisのエンコーディングをサポートしてくれないの?
173 :あぼーん :あぼーん.net あぼーん
174 :あぼーん :あぼーん.net あぼーん
175 :あぼーん :あぼーん.net あぼーん
176 :あぼーん :あぼーん.net あぼーん
177 :nobodyさん :03/05/19 20:20 ID:???.net UNIX積算秒を timestamp型にUPDATE文でセットするにはどのような方法があるのでしょうか? マニュアルの date_trunc() や timestamp() 関数を見てもそれらしいのが見あたら なくてなやんでいます。
178 :nobodyさん :03/05/20 20:28 ID:tVu/NkZD.net すんまそん、 緊急の為、過去ログ見ないで聞きます 文字コードを設定する方法を教えてくだつぁい 困りはてました・・・ 環境はapache(Linux)+PostgreSQL+PHP もう日本語めひゃくひゃ・・・
179 :nobodyさん :03/05/20 22:01 ID:7LQQ/2dr.net PostgreSQL 7.3.2 付属ドキュメント http://www.postgresql.jp/document/pg732doc/
180 :nobodyさん :03/05/20 22:13 ID:???.net 緊急で 文字コードを設定する方法を教えてくだつぁい って疑問にぶち当たるシチュエーションってのが想像つかん。
181 :nobodyさん :03/05/20 22:43 ID:mI4NkyBO.net Serialを指定したテーブルからNextValの値を取得したいと 思っています。 Javaで行う場合に、 REsultSet rs = executeQuery("select nextval('zzz_id_seq')"); としているのですが、これからどのように取得すればいいのでしょうか? それとも、根本的に取得の方法が間違っていますか?
182 :nobodyさん :03/05/20 23:42 ID:???.net >>178 名前の欄に fushianasan と書けばOKです!!!
183 :山崎渉 :03/05/22 01:59 ID:???.net ━―━―━―━―━―━―━―━―━[JR山崎駅(^^)]━―━―━―━―━―━―━―━―━―
184 :nobodyさん :03/05/22 10:32 ID:JcOANcCI.net オマイら dbの容量計算の仕方教えて下さい。
185 :nobodyさん :03/05/22 14:27 ID:???.net >>184 select count(*) from hogehoge;
186 :nobodyさん :03/05/24 20:17 ID:aDXBSjIE.net ポスグレ!
187 :nobodyさん :03/05/24 23:21 ID:???.net ( ゚-゚)b
188 :nobodyさん :03/05/24 23:26 ID:???.net 略すなYO!!!
189 :nobodyさん :03/05/27 10:31 ID:oAIrGLTh.net select count(*) from hogehoge; って件数じゃん
190 :あぼーん :あぼーん.net あぼーん
191 :nobodyさん :03/05/27 13:02 ID:ehUv/K+8.net で、hogehogeってなに?
192 :あぼーん :あぼーん.net あぼーん
193 :nobodyさん :03/05/27 13:44 ID:???.net (´-`).。oO(いつもながらツッコミが遅いです・・・)
194 : :03/05/27 15:44 ID:???.net (1) create table t1 (ts timestamp); ってしますよね。で、日本時間15:37ごろに (2) insert into t1 values (now()); ってしますよね。で、 (3) select * from t1; ってやると 2003-05-27 15:37:54.748034 んな感じで値が帰ってくるかと思うのですが、 (4) これを php から epoch 形式で取得して、date() 関数に渡すと 28日の0時になってしまいます。 これは↑のうちのどこが悪いのでしょう?
195 :nobodyさん :03/05/27 17:46 ID:dZ0fIA92.net 次のようなテーブルがあるとして、思ったような 操作ができずに困っています。どなたかよい方法を ご存知の片がおられましたら、教えてください。よろしくお願いします。 下のようなテーブルがあったとします。 Id name point date 1 あ 5 5月1日 2 い 1 5月16日 3 う 22 5月5日 4 え 0 5月27日 5 お 10 5月26日 このテーブルから、例えば本日が5月27日だとすると 本日から3日以内のdateのものを優先的に取得し、 そのレコードより後ろに、それ以外のデータを pointの降順で並べたいのです。
196 :195の続き :03/05/27 17:46 ID:dZ0fIA92.net つまり上の例からSQL文で取得した結果を id name point date 4 え 0 5月27日 (3日以内のものが上にきている) 5 お 10 5月26日 (3日以内) 3 う 22 5月5日 (↓それ以外はpointの降順) 1 あ 5 5月1日 2 い 1 5月16日 という風にしたいのです。しかし、SQL文が思いつきません。 select * from ( (select * from テーブル名 where (検索条件) and dateが3日以内 ) UNION (select * from テーブル名 where (検索条件) ) ) order by date desc , point desc; のようにしても、dateの降順になるだけでした。 (検索条件)というのは今回ある条件でレコードを引っ張ってくるので その条件のことなのですが、これは非常に処理が重く なんとか1回ですませられないかとも思っています。 長文になってしまいましたが、アドバイスをよろしくおねがいします。 あつかましくてすみません・・・
197 :nobodyさん :03/05/27 18:23 ID:???.net >>196 UNIONって実践で使おうとして結局ボツにした事しかないから あんまり詳しい挙動は良くわかんないんだけど、 (select * from テーブル名 where (検索条件) and dateが3日以内 ) と (select * from テーブル名 where (検索条件) をくっつけるってことは、distinctかけるか"(検索条件)and dateが3日以上前" にしないと重複行がでるような。。 あと、"くっつけた後"のレコードに対してorder by date desc , point desc;してるんだから、 この時点で3日以内のレコードが一番上とか関係ないし。 (select * from テーブル名 where (検索条件) and dateが3日以内 ) という結果と (select * from テーブル名 where (検索条件) and dateが3日以上前 order by date desc , point desc); という結果をUNIONしないとだめっぽ。 それ以前に、単純に新しい日付順に並べるのが一番楽だろうになんでまたこんな奇怪な 仕様になってるんですか? 印刷するにしてもブラウザに表示するにしても、一言注意書きが必要になっちゃうような インターフェースは避けるべきかと。 日常的に直近3日のデータしか使わないようなら、(Webアプリなら)直近3日を表示するページを作って、 全体表示をするページへのリンクを貼るようにするとか仕様変更も検討しては?
198 :nobodyさん :03/05/27 19:33 ID:???.net 今197がいいこと言った!!!
199 :nobodyさん :03/05/28 12:30 ID:37obhOpS.net >>196 select * from (select *,1 AS tmp from テーブル名 where (検索条件) and dateが3日以内 ) union (select *,2 AS tmp from テーブル名 where (検索条件) order by tmp, date desc , point desc ってのは?
200 :あぼーん :あぼーん.net あぼーん
201 :あぼーん :あぼーん.net あぼーん
202 :nobodyさん :03/05/28 13:41 ID:???.net 単発で質問スレを立てないように。終了。
203 :195 :03/05/28 20:14 ID:8u4ScsfX.net >>197 さん 変な質問に付き合っていただき、どうもありがとうございます。 確かに、おっしゃるとおりでした。最後のソートがよくないです UNIONは和集合なので、一応重複したレコードは1つになります。 結局、 select * from ( (select * from テーブル名 where (検索条件) and dateが3日以内 )order by date desc UNION ALL (select * from テーブル名 where (検索条件) )order by point desc; ) のようにしているのが現状です。UNION ALLだと、そのままくっつけてくれて、 検索条件のところで互いに重ならないような条件をくわえています。 これ、確かに設計がわるいです・・ たとえば、検索エンジンで、新し物を表示し、アクセスうが多いものを 表示しようという嗜好なのですが・
204 :nobodyさん :03/05/29 00:24 ID:l3/TekvE.net PostgreSQL 7.3.3 Now Available for Download Posted on 2003-05-27 by press@postgresql.org The PostgreSQL Global Development Group has released PostgreSQL 7.3.3. It is highly recommended that those running earlier version of the 7.3 branch upgrade at their earliest convenience. http://www.t.ring.gr.jp/archives/misc/db/postgresql/source/v7.3.3/
205 :nobodyさん :03/05/29 17:54 ID:???.net squid で proxy 作って、WEB 見るときはそれを使うようにした。 そしたら、日本 PostgreSQL ユーザー会のページ(postgresql.jp)が見れなくなった。 他のページは見れるし、proxy 外したらユーザー会のページもOKなのに。 なんでだろう。 ・・・スレ違いだね。ごめん。
206 :あぼーん :あぼーん.net あぼーん
207 :あぼーん :あぼーん.net あぼーん
208 :nobodyさん :03/05/31 23:38 ID:NfBpY+67.net Release rush ですね >>204 postgresql 7.3.3 php 4.3.2 ...Mozilla 1.4 RC1
209 :nobodyさん :03/06/03 11:27 ID:LFu6QbCl.net こんにちは。 decimal型で、&演算子を用いて演算する方法は無いでしょうか? 1ビットごとに意味を持たせておいて、&でマスクをかけて検索している のですが、int8の64ビットだと、64種類までなので、 それては不足しています。 そこで、decimal型でやりたいのですが、int型しか&を使えない というエラーが出てしまいます。intにcastしても、その時点で int8の最大値を超えているとエラーが出てしまうので、 困っています。 よい解決方法がありましたら、ご教授ください。
210 :nobodyさん :03/06/03 14:50 ID:???.net bit型を使うわけにはいけない? もしくはバイナリをつっこむとか。 文字列で表現する方法もあるし。 そもそもdecimalのデータ格納効率はintなどと比べて悪いんじゃない?
211 :209 :03/06/03 16:24 ID:LFu6QbCl.net そうだったんですか・・・ありがとうございます。 indexをはりたかったので、decimalでしました。 いろいろやった結果、 floor ( decimalカラム / 探したい数値 ) % 2 = 1 という式でなりました。お世話になりました(^^ 格納効率も、次回から考慮してみますね
212 :あぼーん :あぼーん.net あぼーん
213 :nobodyさん :03/06/04 14:29 ID:7jLojF8m.net PostgreSQL7.3.2です。 あるDBへ接続できなくなってしまいました。 psql sample とすると、 psql: FATAL: catalog is missing 5 attribute(s) for relid 1262 と出てしまいます。pg_dumpとろうとしても、 pg_dump: [archiver (db)] connection to database "sample" failed: FATAL: catalog is missing 5 attribute(s) for relid 1262 と出てしまいます。 バックアップはとっていません。。削除するわけにもいかない事情があります。 どうにかして復旧することはできませんか。。。 (つか、意外にひ弱なPostgreSQL?)
214 :あぼーん :あぼーん.net あぼーん
215 :nobodyさん :03/06/04 14:45 ID:ulcLr4fi.net でいつWindows版は出るわけ?
216 :nobodyさん :03/06/04 18:24 ID:???.net >>215 http://osb.sra.co.jp/PowerGres/index.php
217 :nobodyさん :03/06/04 22:45 ID:???.net 7.4はWindowsでもビルドできるって?
218 :213 :03/06/05 00:19 ID:tKeK+oMF.net 213です。すんません、どなたか>>213 の解決策、ご存じの方いらっしゃいませんか…まじ困ってます(;´Д`) Google探しまくってますが有効策みあたりません。。 おながいします"_m(_'_)m_"
219 :nobodyさん :03/06/05 00:52 ID:eid+uK9F.net こんばんは。 CREATE TABLE heaven ( name text, karma int ); karmaを10下げる関数を書いたんですけど、そんなこと しなくても単純なSQL文で実行出来ますか?後学のため に教えてください。 UPDATE heaven SET kerma = kerma - 10 WHERE name = 'hoge'; みたいなことがしたいんです。。
220 :nobodyさん :03/06/05 00:53 ID:???.net >>219 やってみたら出来た。試す前に投稿した自分を許して下さい。。
221 :nobodyさん :03/06/05 02:28 ID:???.net >>213 カタログ情報が壊れているのかな なんか相当ヘンなことしなかった? >バックアップはとっていません。。 日時のダンプくらい取れYO・・・ >(つか、意外にひ弱なPostgreSQL?) 他人のせいにして・・・ もうダメぽ・・・ データファイルから本体のデータを復旧するツールってないのかな? もしなくても デキる香具師なら ソース読んで2,3日で作れそうだが
222 :213 :03/06/05 09:20 ID:8BFr2soT.net >>221 >>日時のダンプくらい取れYO・・・ そのとーりです。はい。取る前におきてしまったんでつ。もう、どうしようもないです。 >>他人のせいにして・・・ それが私の特徴です(←こら AccessとかMS-SQL Server2000じゃこんなことゼッタイ無かったのにぃ〜と嘆いています。 使い始めて9日目…やっぱ復旧ツールって無いんですね…これこそダメぽ……
223 :nobodyさん :03/06/05 11:49 ID:???.net Jet使うとしょっちゅう壊れると思うんだが。 復旧できるからまだしも、そうでなかったらどうしようもない。
224 :nobodyさん :03/06/10 15:30 ID:+sYGrsNt.net windowsからlinux上にインストールしたpostgresqlサーバに アクセスして、テーブルとかをいじれるツールってあるのでせうか? ODBCとか使って、accessからアクセスできないかななんちゃって(サムイ
225 :nobodyさん :03/06/10 16:13 ID:???.net >>224 access は知らんが、CSE はできる。
226 :nobodyさん :03/06/10 18:37 ID:???.net >>224 激しくできます。ぐぐって見てください。
227 :224 :03/06/11 01:48 ID:???.net >>225 CSE試してみました。 まだじっくりいじっていないのですが、 SQLコマンドを打ち込む補助ツールのようですね。 SQL初心者には、まだまだわからないことがいっぱいです。 もっと、GUIでテーブル操作とか、リレーションとかしてみたいです。 >>226 ありました! ttp://www.hizlab.net/app/pgwin.html こことかで解説みて、成功しましたが、 テーブルの作成やプロパティの変更、クエリの作成などは 出来ないのエスね。。。
228 :nobodyさん :03/06/11 12:40 ID:dVQT51zl.net >>227 access server を買って使ってくれ・・・
229 :postgresql勉強始めました :03/06/12 23:09 ID:aCqR/moW.net ここで、質問しても良いのでしょうか・・・? postgresqlの勉強を始めたばかりで、わからないことばかりなのですが、 いったん作成したテーブルに、新たな列を後から追加・削除することは可能でしょうか?
230 :nobodyさん :03/06/12 23:30 ID:b2p7Tjjy.net >>229 バージョンによるが、可能。 詳しくは >>179 のドキュメントに書いてあるよ。
231 :nobodyさん :03/06/12 23:30 ID:???.net ALTER TABLEを使う ttp://www.postgresql.jp/document/pg732doc/user/ddl-alter.html 基本的なことは>>2 のユーザー会のマニュアルを見るべし。 DBは突っ込んで勉強するとけっこう深い。ガンガレ
232 :231 :03/06/12 23:31 ID:???.net かぶったーよ
233 :nobodyさん :03/06/12 23:37 ID:???.net >>1 のテンプレにはマニュアルへのリンクを張った方が良いな。 前スレへのリンクはあまり利用価値が無いと思う。
234 :nobodyさん :03/06/14 02:40 ID:8UJU9HVd.net initlocationをつかって、 DBの作成する場所を変えようと思ってるんだけど、 なんかしんないけど、 エラー出るんですよ。 誰かわかりますかね。 su - postgres export PGDATA2=/var/lib/pgsql/data initlocation PGDATA2 createdb test -D 'PGDATA2' ERROR: Postmaster environment variable 'PGDATA2' not set createdb: database creation failed
235 :234 :03/06/14 04:22 ID:8UJU9HVd.net 234です。 事故解決しました。 postmasterを起動するときに、 export も同時にやるとうまくいったよ。
236 : :03/06/16 16:41 ID:???.net すいません、PHP + PostgreSQL スレにも書いたんですけど あまり人いないようなのでこちらにもお邪魔させてください。 別の外注が作ったシステムの移行を頼まれたのですが、 PostgreSQL 7.2 ⇒ 7.3 での非互換な項目 空の文字列 ('') は、整数フィールドに対する入力として 許可されなくなりました。 以前は、これは暗黙的に 0 と 解釈されていました。 に引っ掛かってしまいました。べらぼうな数のテーブルと べらぼうな数のPHPソースがあり、これを一つ一つ $SQL = "UPDATE table SET int_value = '$int_value'"; から例えば $int_value += 0; $SQL = "UPDATE table SET int_value = $int_value"; のような感じに変更するのはかなり厳しい状況です。 バージョンを下げる以外に何か対応策はないですかね? postgresql.conf とかで切り替えられたらいいんですが。。。
237 :nobodyさん :03/06/16 17:27 ID:???.net >>236 コピペ? あまりにも典型的なハマリ(ry もし実話だったら とりあえず新幹線に乗って 京都・奈良で寺巡りでもして来い 壮大な歴史の中では 自分がいかにちっぽけな存在であるか よーく分かるはずだ
238 :nobodyさん :03/06/16 23:54 ID:???.net >>236 まぁ、Postgresのバージョン間の互換性には期待するな、ということで。
239 :236 :03/06/17 16:12 ID:???.net >>237 違うよ。はまりたくてはまってるわけではないけど 頼むから register_globals を期待しないで欲しい>前の業者 >>238 漏れは期待してません。PHPに関しても然り。 その上でどうやったらこの問題を解決できるか知りたいのれす。 神はここにはいらっしゃいませんか。
240 :あぼーん :あぼーん.net あぼーん
241 :nobodyさん :03/06/17 19:28 ID:???.net >>239 整数のフィールドを持つテーブルに対して、一つ一つトリガを作るとか。 手間はかかるがコードの修正よりは単純作業だし、漏れが出にくいよ(w UPDATEやINSERTが必ず通る道で待ち伏せするわけだから。 テーブルの一覧をざっと眺めて、半日なり1日なり単純作業をすれば見切り発車はできるかと。 で、後からじっくりマターリとコードを直して行く。。。 すんごい小手先だけど、コード多い・時間無い・エラーが出るのはマズイって状況なら これぐらいしか思いつかん。 設定で一発でなんとかできりゃあ良いんだろうけど、俺は知りませぬ。 #もしシステムのユーザが一般人ではなくてオペレータとかだったら、「空白入れんなヴォケ!」 #ってマニュアル対応で逃(ry
242 :236 :03/06/17 19:32 ID:???.net なるほど、トリガですか。何とかなるかな… ちょっと盲点だったかもしれません。 ありがとうございます、助かりました。
243 :nobodyさん :03/06/18 02:42 ID:SST1kRd8.net Win2Kに cygwin で PostgreSQL7.3 をインストールして、同じ端末につみきWEBのCSEをインストールしました。 で、データベースに接続しようとしたところ FATAL 1: Database ""testdb"" does not exist in the system catalog というエラーが発生して繋がりません。 他のSQLエディタで(psqledit)設定を一緒にしたところ、うまくつながりました。 なので、データベース名を囲むダブルクオテーションが二重になってるのが原因だと思うのですが、同じところでハマって居る人いませんか? データベース名を指定しないと、ユーザ名がデータベース名になるのですが、そのときは"testdb"というように一重になり、繋がります。 どなたか解決方法を知っている人がいれば、ご教授願います。
244 :229 :03/06/18 04:02 ID:???.net >>230 >>231 遅レスすいません。 ありがとうございました。 おかげで解決いたしました。
245 :nobodyさん :03/06/22 09:55 ID:???.net >>243 なんか libqp.dll があやしそう。libpq.dll をいれなおしてみては?
246 :nobodyさん :03/06/22 09:57 ID:SKC4SEC9.net 「PostgreSQL構築・運用ガイド」期待age ttp://ml.postgresql.jp/pipermail/pgsql-jp/2003-June/005336.html
247 :nobodyさん :03/06/22 09:59 ID:???.net http://ml.postgresql.jp/pipermail/pgsql-jp/2003-June/005336.html
248 :あぼーん :あぼーん.net あぼーん
249 :nobodyさん :03/06/22 10:19 ID:???.net 本書は,PostgreSQLの導入方法はもちろん, 企業情報システムでの利用を前提にした,運用方法や信頼性, 可用性を高めるための方法,企業情報システムで広く使われている Oracleデータベースとの比較なども紹介し, 企業ユーザーにとって有用な情報をお届けします。 http://ml.postgresql.jp/pipermail/pgsql-jp/2003-June/005336.html http://bpstore.nikkeibp.co.jp/item/main/148222234340.html http://bpstore.nikkeibp.co.jp/item/image/h_4822223434.gif
250 :nobodyさん :03/06/22 10:28 ID:???.net で、これは何本って言えばいいんだ? うぐい本か?日本野鳥○会の人 解説きぼん。
251 :nobodyさん :03/06/22 10:53 ID:???.net >>250 ぽすぐれ本
252 :nobodyさん :03/06/22 11:15 ID:???.net なんで魚なんだ?>ヲレ 自己突っ込み完了しますた。 次の話題どぞ。
253 :nobodyさん :03/06/22 16:44 ID:???.net >>246 なんかまたペンギンの影があるね。 亀は使えないのかな?
254 :成功者! :03/06/22 23:57 ID:pFJThKfu.net 誰でも仕事が出来ます。 資本金0円でスタート ココを見てください! http://www.c-gmf.com/farewell/box10.htm
255 :nobodyさん :03/06/23 20:54 ID:dxcUTx3u.net Java+PostgreSQLでwebアプリを作る場合、文字コードは何にするのが一般的ですか? webページをSJIS、DB内はEUCにしようかと思ってますが、EUCにすると 全角半角どちらも1文字扱いになるらしいので、どうしようかな〜って感じです。 本番サーバはLinuxでApache+Tomcat、開発はwindowsで同じ環境作ってやってます。 winでの開発はJISが楽ですよね、やっぱり・・・
256 :あぼーん :あぼーん.net あぼーん
257 :nobodyさん :03/06/23 22:12 ID:???.net >>255 PostgreSQLはunicodeでエンコーディングしないと、全角ハイフンなどが化けます。
258 :nobodyさん :03/06/25 12:22 ID:???.net バグ出しさせてください、おながいします。
259 :nobodyさん :03/06/25 13:52 ID:???.net >>258 環境を教えてください
260 :nobodyさん :03/06/26 23:18 ID:UmxIAMQr.net >>285-259 ワラタ
261 :nobodyさん :03/06/27 20:33 ID:r28icV76.net Postgres自体でSQLの実行ログがどこかに保存される設定とかってあるのでしょうか? 自前で実装する(SQL実行時にテキストに書き出す or DBにテーブルを作成して書き込む等) しか仕方ないですよね?
262 :nobodyさん :03/06/27 22:35 ID:Fj3NiizR.net >> あるよ。 $PGDATA/postgresql.conf に log_statement = true と書き込んでからpostmasterを再起動すれば完了したクエリがログに 記録されるようになります。 ログファイルは、 $ pg_ctl -D /usr/local/pgsql/data -l pgsql.log start のように指定しる。
263 :nobodyさん :03/06/28 02:05 ID:14usrn45.net PHP+PostgreSQLで排他処理を行いたいと思うのですが、 解説本か、サイトあれば教えてください。 無ければ、簡単にご説明くださいませんか?
264 :あぼーん :あぼーん.net あぼーん
265 :nobodyさん :03/06/28 04:20 ID:???.net >>263 ロックする。以上。
266 :nobodyさん :03/06/28 05:20 ID:14usrn45.net DBのロックってできるの?
267 :nobodyさん :03/06/28 07:37 ID:???.net >>266 マニュアル読めや
268 :nobodyさん :03/06/28 09:59 ID:???.net ID:14usrn45はDB使わない方が(・∀・)イイヨイイヨー
269 :nobodyさん :03/06/29 19:33 ID:???.net PostgreSQL-7.3.2をPlamo Linux上で使ってるんですが、 同じ環境の方に聞きたいです。 libplpgsql.so postgres.h libpq.h の3ファイルって存在 してますか?4月号のSoftware Design見ながらXMLPGSQLの 導入を試みてるんですが make でこけてしまうので。。上記 の3ファイルの場所を指定しろって言われてるんだけどそも そもそんなファイルがないのです。
270 :261 :03/06/30 11:26 ID:5q6N3/KD.net >>262 当方、バージョンが少し古くて、log_statement = trueではエラーが出たので ググってみたところdebug_print_query = trueという指定でできました! ありがとうございます。
271 :あぼーん :あぼーん.net あぼーん
272 :nobodyさん :03/06/30 12:26 ID:5tKrGL8Q.net データベース板できました http://pc2.2ch.net/db/
273 :nobodyさん :03/06/30 12:40 ID:???.net http://pc2.2ch.net/test/read.cgi/db/1056944337/
274 :nobodyさん :03/06/30 12:48 ID:???.net >>272 ひでぇ有様だな(w スレ一覧みてワロタ
275 :nobodyさん :03/06/30 12:59 ID:???.net http://i.2ch.net/m30.html 明らかにデータベース板
276 :nobodyさん :03/07/01 00:31 ID:???.net >>274 ← 何気にマジレスっぽ(プ
277 :nobodyさん :03/07/01 02:20 ID:???.net ドラゴンボールヲタ?>>276
278 :nobodyさん :03/07/01 09:23 ID:oVA7Xb+Q.net >>274 =>>277 マジレス図星だったようだなw
279 :274 :03/07/01 09:40 ID:???.net >>278 新板の荒れ様を見てワロタっていう素直な感想を書いただけだから、 確かにマジレスには違いないけど。。 何を無理やり煽り文体にしてるの? 何で絡まれてるの?俺。
280 :nobodyさん :03/07/01 11:21 ID:???.net ドラゴンボール関連のスレは消されたみたい。 やっぱりデータベース板だそうだ。
281 :nobodyさん :03/07/02 01:55 ID:???.net >280 ついさっきまで確信が持てなかったヲレ。
282 :nobodyさん :03/07/02 17:01 ID:???.net >>280 http://www.ff.iij4u.or.jp/~ch2/bbsmenu.html データベースだし。
283 :nobodyさん :03/07/04 04:50 ID:???.net 激烈初心者です。 数値のデータ型で、 int2で指定したところに「0001」という数字を代入すると、 1になりますよね? これを、000の部分を残すためには、文字列型しかないですか?
284 :nobodyさん :03/07/04 09:35 ID:???.net 「0001」は文字列だから、数値型のカラムに突っ込んで 勝手に「1」になるのは仕方が無いんじゃない? 表示する時に0埋めするようにすれば? "0000"と文字列にコンバートした1とか10を右から4文字切り取って 表示するとかなら、SQLでできるし。
285 :nobodyさん :03/07/10 16:23 ID:57Eu1LHu.net PostgreSQL 7.2.3 php4.1.2 kernel 2.4.7-10 gcc 2.96 という環境で、webアプリを稼動させています。 cronで一日一回「vacuum full」を実行しています。 テーブルは約50個あり、しばらく運用していると データを保存しているハードディスク領域(/usr/local/pgsql/data/base/XXXXXXXX)が徐々に肥大していきます。 肥大化していくと、insertや、dropが比較的多めのテーブルがあるのですが、 そのテーブルのレスポンスも悪くなっていきます。 そのテーブルをdumpして、dumpファイルからの復帰をすると改善するようです。 別のマシンに同じDBを持ってきて、問題のDBをDUMPし、一旦そのDBをdropdb。 そして、createdbし、dumpからの復帰 psql -e db < dumpfile をするとハードディスク領域(/usr/local/pgsql/data/base/XXXXXXXX)は約1/3程度になりました。 定期的にdumpして、そのdumpファイルからの復帰という作業は非効率的ですので このような作業をせずに肥大化を防げる方法はありませんでしょうか。
286 :nobodyさん :03/07/10 16:51 ID:ubgylsck.net >>285 REINDEX
287 :nobodyさん :03/07/10 18:09 ID:8n4LR913.net BEGIN 処理A BEGIN 処理B COMMIT 処理C ABORT としても処理AとBはコミットしちゃいますよね?
288 :あぼーん :あぼーん.net あぼーん
289 :nobodyさん :03/07/10 19:40 ID:???.net >287 つか、nested transactionは処理できない。 使おうとしている時点で間違い。
290 :nobodyさん :03/07/10 19:40 ID:???.net >>287 BEGINからCOMMITまでがトランザクションだから、 現在のトランザクションはありませんってエラーがでるんでないの?
291 :290 :03/07/10 19:42 ID:???.net >>289 >>287 ネストさせようとしてたのか!
292 :nobodyさん :03/07/10 20:16 ID:???.net >291 どう見てもネストしてるじゃん。 ちなみに、beginした後でもう一度beginしると、 「もうトランザクション始まってんのじゃボケェ」と言われます。
293 :287 :03/07/10 22:42 ID:???.net どうもです。 できるのを前提にコードを書いていたので、 一番外側でだけクエリを発行するようなラッパー関数つくって回避しました。 (途中のアボートは例外処理) 調べてみたらトランザクションのネストができない実装の方が一般的なんですね。
294 :285 :03/07/11 15:47 ID:???.net >>286 ありがとうございます。一応reindexを毎日するように設定してしばらく様子見てみます。 ちなみにreindexとvacuum fullは順番的にはどちらを先にした方が良いのでしょうか?
295 :nobodyさん :03/07/11 17:21 ID:C9rBOC2S.net test=# vacuum; NOTICE: Some databases have not been vacuumed in over 2 billion transactions. You may have already suffered transaction-wraparound data loss. VACUUM test=# とvacuumで上のNOTICEが出た場合はどういう対処をすれば良いのでしょうか。
296 :nobodyさん :03/07/12 02:17 ID:???.net >20億トランザクション越えたのにvacuumされませんですた。 >トランザクションID使い果たして、データの喪失が発生しますた。
297 :山崎 渉 :03/07/15 11:07 ID:???.net __∧_∧_ |( ^^ )| <寝るぽ(^^) |\⌒⌒⌒\ \ |⌒⌒⌒~| 山崎渉 ~ ̄ ̄ ̄ ̄
298 :nobodyさん :03/07/23 23:29 ID:???.net
299 :nobodyさん :03/07/24 12:05 ID:TEX2oC6v.net ラージオブジェクトって、pg_dumpでバックアップできるの? 7.1からだっけ?
300 :あぼーん :あぼーん.net あぼーん
301 : :03/07/24 15:51 ID:???.net ちょっとお尋ねしますが、PostgreSQLでトーナメント表って実現できますか? チームテーブルと対戦テーブルを用意するところまではできたのですが、 全ての対戦結果を一覧表示させる方法がわかりません。 チームテーブルの内部結合の結果に対して 対戦テーブルを外部結合すればいいかと思ったのですが、 複数のテーブルに対して外部結合というのはできないもんなんでしょうか? イメージでいうとこんな感じです。 select a.name, b.name, m.score from team a, team b left outer join match m on m.home = a.id and m.visitor = b.id;
302 :nobodyさん :03/07/25 03:00 ID:IBsY8pQ4.net PHP + PostgreSQL PERL + PostgreSQL C + PostgreSQL どれが一番高速でアクセスできますか?
303 :nobodyさん :03/07/25 12:25 ID:oPyKjtod.net >>302 ミドル次第。
304 :nobodyさん :03/07/26 17:34 ID:grYAyx0u.net PostgreSQLってRollBack使えないんすか?
305 :nobodyさん :03/07/26 22:34 ID:???.net ハァ?
306 :nobodyさん :03/07/27 23:23 ID:guTNEK25.net >>304 使えよ
307 :nobodyさん :03/07/28 09:21 ID:b/HKh3mz.net 投稿者が女名だと、同じ内容の回答が続くね。
308 :nobodyさん :03/07/28 09:44 ID:b/HKh3mz.net しかも、「紹介者がいないときは自分自身になります」って条件読んでないし。
309 :nobodyさん :03/07/28 10:13 ID:???.net おいらも今度から女の名前で質問しよう。
310 :nobodyさん :03/07/28 11:55 ID:???.net >>309 人格つくりすぎて、あぼーんするハメにならんようにな。
311 :nobodyさん :03/07/28 23:51 ID:???.net 旦那になって戻ってくるから大丈夫。
312 :ももこ :03/07/29 00:11 ID:???.net >>311 もどってきてね♥
313 :nobodyさん :03/08/01 07:34 ID:fLmmiO+8.net すいません。postgresql-7.2.3で日本語環境が構築できません。 psql -lとしても、EUC_JPとか言語環境がでてきません。 List of databases Name | Owner -----------+---------- template0 | postgres ./configure --enable-mutibyte=EUC_JP と指定もしています。 createdb -E EUC_JP test2 /usr/local/pgsql/bin/createdb: /usr/local/pgsql/bin/pg_encoding: No such file or directory createdb: "EUC_JP" is not a valid encoding name ↑こんなエラーもでてます。
314 :nobodyさん :03/08/01 07:50 ID:esvzZjrA.net 祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り ニーノさんのホームページ作り2 http://ex.2ch.net/test/read.cgi/entrance/1059029010/ ニーノ ◆p9GipySMGk によってラウンジにたてられたこのスレで、 http://page.freett.com/ninogumi/ 【ニーノさんのホームページ】 というサイトが作られた。(現在もコンテンツは爆発的に増えてるよ。) さぁ、君もアイディアを出して、2CHネラーだけの最強サイトをつくろう! 祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り
315 :nobodyさん :03/08/01 07:50 ID:???.net >>313 euc-jpじゃないのかage。
316 :315 :03/08/01 07:51 ID:???.net ageてねーや。でもspamカキコがくるからageなくていいや。
317 :nobodyさん :03/08/01 22:20 ID:bI0qs527.net createdb -E EUC_JP データベース名
318 :nobodyさん :03/08/01 23:09 ID:vlQX/M9J.net http://www.vesta.dti.ne.jp/~hi-lite/fe/ero.html ここなら簡単に見れたぞ
319 :山崎 渉 :03/08/02 02:20 ID:???.net ∧_∧ ( ^^ )< ぬるぽ(^^)
320 :ぼるじょあ ◆ySd1dMH5Gk :03/08/02 04:48 ID:???.net ∧_∧ ∧_∧ ピュ.ー ( ・3・) ( ^^ ) <これからも僕たちを応援して下さいね(^^)。 =〔~∪ ̄ ̄ ̄∪ ̄ ̄〕 = ◎――――――◎ 山崎渉&ぼるじょあ
321 :nobodyさん :03/08/02 07:48 ID:???.net FAQになってる予感がするけど、列制約を変更したくなりました。 create table asでも列制約は新しく定義できないみたいだし。 あと1列だけ型も変更したい。 慎重に設計しなかった自分が悪いわけですが、なんか突破口 ないですか?手で再入力だけは避けたいです。。
322 :nobodyさん :03/08/03 08:56 ID:???.net >>321 突破口って。。。 マニュアル読めばいいだけと違うの?
323 :_ :03/08/04 16:26 ID:???.net CREATE TABLE account_table ( expire_date TIMESTAMP, name TEXT ); のようなものがあって、 SELECT * FROM account_table WHERE expire_date > now() AND name = 'foobar'; のような問い合わせを頻繁に行なっています。実際にはテーブルも問い合わせ ももっと複雑です。 ここで、上記SELECT文を、1引数('foobar' 部分)のPL/pgSQLの関数にしてしま いたいのですが、そういうことは可能でしょうか? CREATE FUNCTION get_account( TEXT ) RETURNS ??? AS 'BEGIN ???; END' LANGUAGE 'plpgsql' ; のような概観になるかなとは思うのですが、戻りの型などがわかりません。 EXECUTEを使うのでしょうか? 教えてください。 # Viewのほうが無難でしょうか? プログラム側にwhere句を書き忘れる可能性 # があるのが嫌なんですよね…
324 :nobodyさん :03/08/05 03:24 ID:???.net CREATE FUNCTION get_account( text ) RETURN SETOF RECORD AS ' [...snip...] ' LANGUAGE 'plpgsql';
325 :nobodyさん :03/08/05 13:23 ID:???.net すこしスレ違いかもしれませんが、どちらに質問していいかわからなかったので、 ここで質問させてください。 ある大きな2つのテーブルをJOINしたいのですが、そのままJOINすると 時間が掛かりそうなので、片方を一時テーブルに書き出して、それをJOINしようと 思ったのですが、一時テーブルを作った後、違うページで一時テーブルとJOINしようと するとテーブルが存在しないと言われてしまいます。 PHPから一時テーブルを作成した場合、その一時テーブルにアクセスできるのは どのタイミングまでなのでしょうか? マニュアルにはセッションの終わりまでのようなことが書いてありますが、 PHPのセッションは終了してません。 それとも、一時テーブルを作成しないでもいい方法などありませんでしょうか? よろしくお願いします。 環境は、PHP 4.2.3 PostgreSQL 7.2.3です。
326 :308 :03/08/05 13:57 ID:???.net すいません、自己解決しました。
327 :nobodyさん :03/08/05 15:59 ID:???.net >325 pconnect使わなければ、PHPからPostgreSQLへのセッションは 毎回切った張ったされますが。
328 :nobodyさん :03/08/05 16:25 ID:???.net >>325 一時テーブルをVIEWにするかサブクエリにするのが一般的だけど、 性能上の問題からその一時テーブルの結果を使いまわしたいなら 名前をつけてテーブル作成するしかないかな。 pg_pconnect使ってもApache/PHPの状態によってはDBセッションが同一にならないから、 ページを跨いだ一時テーブルの利用はできない。
329 :nobodyさん :03/08/05 18:56 ID:???.net PostgreSQL 7.2 のPL/pgSQLについて教えてください。 CREATE TABLE reg ( d TIMESTAMP ); なるテーブルがあり、d には「現在からn秒後の時刻」をINSERTするようにし ています。現在はプログラムから INSERT INTO reg VALUES ( NOW() + INTERVAL ''100 sec'' ); のようにしているのですが、これをPL/pgSQLで書きなおそうとしています。 で、 CREATE FUNCTION f( BIGINT ) RETURNS BOOL AS ' BEGIN INSERT INTO reg VALUES ( NOW() + INTERVAL ''$3 sec'' ); RETURN TRUE; END ' LANGUAGE 'plpgsql'; としてみたのですが、$3 が展開されないのか、足し算が行なわれません。 どのように書いたら望む結果になりますでしょうか? 教えてください。
330 :325 :03/08/05 21:08 ID:???.net >>327 , 328 ありがとうございました。 pconnectを使って、ページをまたいで一時テーブルを使おうとしてたので、 テーブルが残ってるのか残ってないのか、よくわからなくて混乱してました。 pg_connectを使って、なんとか同じページ内で一時テーブルを使って処理してます。 VIEWは、まだ勉強中なので試行錯誤してみます。
331 :nobodyさん :03/08/06 04:59 ID:7sg7mWSc.net 教えてください。 DISK障害でテーブル内データのほとんどが消えました。 実体の/usr/local/pgsql/data/base/内は無事のようです。 /base/DB名からなんとかリカバリできないでしょうか? postgresql6.5.3です。
332 :nobodyさん :03/08/08 10:59 ID:???.net ZDNetの誤字ひどいな。 『SRA 最新PostGreSQLをベースにした「PoerGres on Linux」「PowerGres Plus」を発表』 http://www.zdnet.co.jp/news/0308/07/nj00_srasql.html
333 :nobodyさん :03/08/18 01:33 ID:???.net age
334 :nobodyさん :03/08/25 03:03 ID:???.net perl、DBIでのトランザクションについてなんですが、 今日のレコード数を持ってきて、それを+1した値で、 新たにINSERTするというときは、 ↓みたいな感じでOKなのでしょうか? (他のユーザが登録している場合でも、値のずれが生じないですよね?) よろしくお願いします。 $dbh->{AutoCommit} = 0; $dbh->{RaiseError} = 1; eval { $val = get_value("SELECT count(*)+1 FROM a WHERE 今日のもの"); $ret = insert_value("INSERT INTO a (foo, ...) values ($val, ...)"); $dbh->commit; }; if ($@) { warn "Transaction aborted because $@"; $dbh->rollback; # undo the incomplete changes }
335 :nobodyさん :03/08/25 21:37 ID:r6wfNhzL.net 7.4の自動バキュームって使えそう? フルバキュームまで自動でやってくれるの?
336 :nobodyさん :03/08/27 12:18 ID:???.net 何を勘違いしたか今までポスタージャSQLって読んでたよ…
337 :nobodyさん :03/09/01 22:46 ID:???.net 私信に近い雑談をMLに流すな〜!
338 :nobodyさん :03/09/01 22:57 ID:???.net >>334 ズレはしないかもしれないが、カチ合う可能性はあるよ。 それを防ぐには、SERIALIZABLEにするか明示的にテーブルロックする。
339 :nobodyさん :03/09/01 23:02 ID:???.net cygwinインストール中に落ちてしまって、インストールできないのですが どうすれば。。あっここで聞くことじゃないですか。。そうですか。。
340 :nobodyさん :03/09/01 23:31 ID:???.net >335 contrib/pg_autovacuum/README.pg_autovacuum より。 vacuum fullに関しては、xid使い切りに関しては考えてるけど、 普段はvacuum止まりということかな。 Vacuum and Analyze: ------------------- pg_autovacuum performs either a vacuum analyze or just analyze depending on the quantity and type of table activity (insert, update, or delete): - If the number of (inserts + updates + deletes) > AnalyzeThreshold, then only an analyze is performed. - If the number of (deletes + updates ) > VacuumThreshold, then a vacuum analyze is performed. deleteThreshold is equal to: vacuum_base_value + (vacuum_scaling_factor * "number of tuples in the table") insertThreshold is equal to: analyze_base_value + (analyze_scaling_factor * "number of tuples in the table") The AnalyzeThreshold defaults to half of the VacuumThreshold since it represents a much less expensive operation (approx 5%-10% of vacuum), and running it more often should not substantially degrade system performance.
341 :nobodyさん :03/09/07 02:48 ID:yFWWpiPw.net PostgreSQL 7.2.1使ってるんですけど、 運用中にREINDEXとかDROP INDEX〜CREATE INDEXとかの INDEXの再生成って行って良いんですかね? 念のため運用を一時的に止めた方が良いんでしょうか?
342 :nobodyさん :03/09/07 04:52 ID:???.net やってもいいっすよ。ロックかかるけど。
343 :nobodyさん :03/09/16 10:01 ID:Wb82WrlA.net バッチグーage
344 :nobodyさん :03/09/16 10:29 ID:???.net MLヲチスレでつか?(藁
345 :nobodyさん :03/09/16 15:02 ID:Wb82WrlA.net >>344 1をみてくらさい。
346 :/ :03/09/16 22:32 ID:GYSWeRnL.net おまえら、7.4 は高速化が図られてるようですよ。 【PostgreSQLウォッチ】第1回 PostgreSQLの次期版7.4の性能を検証 http://itpro.nikkeibp.co.jp/members/SI/oss/20030911/1/
347 :nobodyさん :03/09/17 11:21 ID:An2EWdc3.net select hoge,hogehoge from table group by hoge; をしたいのですがどのようにしたら実現できますか? グループ化してないhogehogeもselectしたいのです
348 :nobodyさん :03/09/17 12:17 ID:???.net select hoge,hogehoge from table group by hoge,hogehoge;
349 :nobodyさん :03/09/23 22:55 ID:PMiaWnnI.net >>347 hoge|hogehoge aaaa|bbbb aaaa|cccc とあったら、何を出せバインダー
350 :nobodyさん :03/09/24 01:47 ID:Mc741Fcx.net おもろい http://www.39001.com/cgi-bin/cpc/gateway.cgi?id=dolphin
351 :nobodyさん :03/09/24 05:33 ID:namugEPq.net >>350 「メル友みっけ」か...
352 :nobodyさん :03/09/24 05:41 ID:???.net ここが一番上にきとる。 移転したんじゃなかったっけ? PostgreSQL 2テーブル目 http://pc2.2ch.net/test/read.cgi/db/1056944337/
353 :nobodyさん :03/09/24 05:56 ID:???.net バイナリデータの挿入の仕方がマニュアルに書いてない 気がするんですが、どうやるんでしょう。 create table images (imagname text, img bytea); このimg列に /tmp/hoge.jpg を挿入したいです。
354 :nobodyさん :03/09/24 06:17 ID:???.net >>352 しらんかった。 っていうか、ドラゴンボール板さわぎのどさくさで、気付いてなかった。 ということで --- 糸冬 了 ---
355 :tes :04/01/15 23:32 ID:???.net tes
356 :nobodyさん :04/06/25 15:10 ID:???.net 適当な文字列が入っているcolumnにたいして、 大文字小文字関係なく、検索文字をマッチさせるにはどうしたらいいの? select * from foo where text_column ^ lower('BAR') or text_column ^ upper('BAR') とかだと、「Bar」みたいのはヒットしないんだよなぁ。
357 :nobodyさん :04/06/25 15:12 ID:???.net あげとく
358 :nobodyさん :04/06/25 16:09 ID:???.net >>356 text_column ~* 'BAR' DBのみのネタはDB板へ ttp://pc5.2ch.net/db/
359 :356 :04/06/25 16:33 ID:???.net >>358 THX ~が^になっていた orz
360 :nobodyさん :04/07/01 16:49 ID:???.net ■ PostgreSQLのことならここで聞け ■ http://pc5.2ch.net/test/read.cgi/db/1056960249/
361 :nobodyさん :04/07/14 02:54 ID:IeDlw13K.net postgres7.3を使用予定ですが、REINDEXの使用方法を教えてください。 REINDEX対象のテーブル名をpg_stat_user_tablesより 取得しながら、REINDEXを全テーブルに順番にかけるシェルを作ろうと思っています。 その際、pgbashを使用し、cronで自動実行を予定しています。 もしソースコードがわかれば教えて下さい。 またみなさんはどんな方法で、行っていますか?
362 :nobodyさん :04/07/14 02:55 ID:IeDlw13K.net postgres7.3を使用予定ですが、REINDEXの使用方法を教えてください。 REINDEX対象のテーブル名をpg_stat_user_tablesより 取得しながら、REINDEXを全テーブルに順番にかけるシェルを作ろうと思っています。 その際、pgbashを使用し、cronで自動実行を予定しています。 もしソースコードがわかれば教えて下さい。 またみなさんはどんな方法で、行っていますか?
363 :nobodyさん :04/08/26 20:45 ID:QkQTY22p.net ネットワークから接続しているユーザのIPを 抜き出してログを取りたいのですが SQLコマンドで、自分はどこから接続しているかを 確認できる関数ってPostgresにはありませんか? とにかく、接続しているクライアントのIPさえ分かればOKです。 宜しくお願いします。
364 :nobodyさん :04/08/26 21:22 ID:vvcjm84y.net 管理人が拳銃発砲!!! http://bbs2.orange-e.net/?id=binbin
365 :nobodyさん :04/09/03 11:18 ID:dro8VJ79.net apache2.0.5とPostgreSQL7.4の環境でmod_auth_pgsqlを使ってBasic認証を 行なっているのですが、認証するたびにpostgresユーザーで下のようなプロセスが 溜まっていきます。 postgres: apache database 127.0.0.1 idle そして挙げ句の果てに mod_auth_pgsql database connection error reset failed FATAL: connection limit exceeded for non-superusers とメッセージが出てサーバーエラー になってしまいます。多分mod_auth_pgsqlがパスワードのデータベースへ接続した後、 切断してくれないからじゃないかと思うのですが、どこか明示的に設定しなければ ならない場所があるのでしょうか?
366 :nobodyさん :04/09/03 12:21 ID:???.net >>365 Auth_PG_connection_reuse がonだとコネクションプーリングするみたいですよ。 デフォルトはoffのようだが。
367 :nobodyさん :04/09/03 13:48 ID:dro8VJ79.net レスありがとうございます。早速 Auth_PG_connection_reuse off を設定して みました。(それ以前は、Auth_PG_connection_reuseは何も設定していません。)すると Invalid command 'Auth_PG_connection_reuse', perhaps mis-spelled or defined by a module not included in the server configuration となりサーバーエラーが返ってきました。別の原因は考えられますか? ちなみにmod_auth_pgsqlは2.0.1、ディストリは fedora core 2です。
368 :366 :04/09/03 19:40 ID:???.net >>367 ざっとソースを眺めてみた限りにおいて、2.0.1では切断をしていなさそうだ。 postgresqlの設定を変更して接続許可数を増やすか、 2.0.2b1にUpするしかないんじゃないか。
369 :nobodyさん :04/09/03 21:48 ID:???.net わざわざ調べて頂いてありがとうございます。バージョン特有の問題なのですね。 当面の間は、max_connectionsを増やして、cronで定期的に service httpd graceful を走らせてしのごうと思います。お世話になりました。
370 :nobodyさん :04/09/04 17:32 ID:???.net >>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.net 行き詰まってしまって解決できなくなってしまったので、 質問させて頂きます。 TESTというテーブルの中に、A,Bというカラムがあり、 Aでgroup byしてから、Bをdistinctしたものの カウントを取りたかったくて、下のようなSQLを組んだのですが、 Bをdistinctできてないものをgroup byした結果が、 出てきてしまいます。 私が意図したSQLはどうすれば実現できるかご教授おねがいします。 SELECT A,count(distinct(B)) FROM TEST group by A;
372 :nobodyさん :04/09/09 19:21 ID:???.net >>371 質問の意図を取り間違っているかもしれないが。 SELECT a,count(*) FROM text GROUP BY a,b; 以後、DBのみの話ならDB板へ ■ PostgreSQLのことならここで聞け ■ http://pc5.2ch.net/test/read.cgi/db/1091523132/ PostgreSQL & pgsql-jp ML 3テーブル目 http://pc5.2ch.net/test/read.cgi/db/1079771059/
373 :371 :04/09/09 22:19 ID:xemAm0Ui.net >372 意図したこととは違いましたが、そのSQL見てて、 ふと思いつき、解決できました。ありがとうございます。
374 :nobodyさん :04/09/30 06:39:58 ID:???.net データが8000件位入ったテーブルtestに さらに8000件近いレコードを追加したいのですが insert文をエクセルで8000個作ることまではできたのですが、 これをポスグレに読ませる際、一括でコピペするとパースエラーになってしまいました。 10件位づつこまめにコピペするとエラーは起きないのですが 時間がかかりすぎるのでファイルから読み込ませたいのです。 ググった所"copy"だと扱えるデータがタブ区切り形式らしいのですが insert文が書かれたファイルを読み込ます事はできるのでしょうか? PostgreSQL7.2.3です。
375 :nobodyさん :04/09/30 07:13:18 ID:???.net >>374 psql -f filename
376 :374 :04/09/30 07:38:51 ID:???.net >>375 レスありがとうございます。 早速ググりましたが psql -f filename db名で http://jpug.postgresql.jp/document/pg721doc/reference/app-psql.html にありました。 ありがとうございました!
377 :nobodyさん :04/10/05 15:22:15 ID:xTnP4bvw.net 不安なのでちょっと質問して宜しいでしょうか。 timestamp型のmodify_dateというカラムがあったときに たとえば、2004年11月4日のデータを取りたいというときは where to_char(modify_date,'YYYY/MM/DD) = '2004/11/04'; という風にしてるのですが、これよりもっと最適な検索法?というのが ありましたら教えて貰えますでしょうか。 to_charで一度charに変換してるから速度的にどうかなぁと思ってるのですが…。
378 :nobodyさん :04/10/05 15:37:46 ID:???.net >>377 date型にキャストした方が速いかも。 WHERE modify_date::date='2004/11/04';
379 :nobodyさん :04/10/05 15:41:36 ID:???.net >>378 おお!なるほど、そういうやり方があったんですね。 感謝ですm(_ _)m
380 :378 :04/10/05 15:43:11 ID:???.net >>378 あ、この方法だと、'2004/11/04'もdate型に変換するだろうから、 結局>>377 とあまり違わないのかな? 俺はこの方法を用いているのだけど。
381 :377 :04/10/05 15:46:28 ID:???.net >>380 377では速度の最適を求めるような書き込みになってしまいましたが to_charでYYYY・・・・と変換するのに抵抗を感じてしまって他のやり方が あればと思って質問したので、十分満足しています。もっと最適なものが あれば尚いいとは思いますが、378さんのやり方を使っていきたいと思います。
382 :nobodyさん :04/10/06 11:37:12 ID:???.net ポストグレスキューエルそろそろ囓ってみようと思うんだけど こんなボンクラはまずどんな本を読めばいいですか? 教えて下さい ISBNコードのみで( ´,_ゝ`)
383 :nobodyさん :04/10/06 18:22:48 ID:???.net 初めてこのDBに挑戦したら initdb: command not found でいきなり死亡しました。 http://www.terra-intl.com/unix.html ↑に書いてある通りにやったら 7. のinitdb でだめだったんですが、 このような経験のある人いませんか?
384 :nobodyさん :04/10/06 20:34:45 ID:???.net >>383 せめて、使ったCygwinとPostgreSQLのバージョンくらい載せるべし。 このページと同一のバージョンが入手できた訳じゃないよね? あるいは、PostgreSQL と Cygwin でぐぐって、新しめのページをを探すべし。
385 :nobodyさん :04/10/06 21:48:18 ID:???.net 同じバージョンしか落とせなかったんですが、古いみたいですね。 新しいので朝鮮します。
386 :nobodyさん :04/10/07 12:14:27 ID:???.net http://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さん :04/10/07 13:55:35 ID:???.net >>386 Cygwinなんて使わずに8.0入れたらだめなの?
388 :nobodyさん :04/10/07 14:22:42 ID:???.net 特定のレコード(たとえばIDがaaaのレコード)がなければインサート、 あればアップデートという処理をしたいのですが、 selectであるかどうかチェック>insertかupdateに振り分ける という方法以外に簡潔にやる方法はありますでしょうか?
389 :nobodyさん :04/10/07 23:12:25 ID:???.net >>386 cygserver や postmaster (postgres.exe) をサービスにしないのなら、 PATH や CYGWIN や TZ はユーザ環境変数で十分。 いま、Cygwinのデフォルトパッケージ + PostgreSQL を入れて、 cygservder, CYGWIN環境変数の定義、initdbの実行までやってみたけど、 特に問題なし。(OSはWindows2000 Pro SP4。作業時間は10分で完了) もっとも、>>387 のいうとおり、8.0 beta 入れてもいいと思うけどな。
390 :386 :04/10/08 01:27:12 ID:???.net http://allabout.co.jp/career/database/closeup/CU20040813A/ 結局ここの通りにやって成功しました。 これからの問題はJavaServletでどう扱うのかってことだけです。 なぜかPHPの解説サイトばっかなんだけれども・・・。 8.0は解説無しじゃ難しいと思ったので、辞めておきました。
391 :nobodyさん :04/10/12 12:56:48 ID:V57uzdCO.net 質問させて下さい PostgreSQL(7.2.3)を使ったWebサイトを作っているのですが、最新項目の表示のため 日付(date型)でorder byしてますとえらく処理に時間がかかっています。 そういうものなのでしょうか? 日付でソートしたい場合の効率的な方法などがありましたら教えてください
392 :nobodyさん :04/10/12 13:56:22 ID:???.net まず、vacuumdb -f dbname やってミソ。
393 :nobodyさん :04/10/12 13:58:02 ID:???.net >>391 DATE型は内部的には4Byteの整数だから、DATE型にしてソートが遅くなると言うわけはないだろう。 一度、VACUUM FULL table;をしてみては如何だろうか。
394 :nobodyさん :04/10/12 18:57:34 ID:???.net >>391 型の問題ではないと思うが。そのカラムにインデックスつけてる?
395 :391 :04/10/12 20:08:58 ID:???.net >>392 ,393,394 す、すいません みなさんのご指摘の組み合わせでした。 indexつけたあとvacuumしてなかったせいみたい。。。 ご指摘ありがとうございました!
396 :nobodyさん :04/10/25 02:34:54 ID:???.net .open() でエラーがたまに出るけど、みんなどうやって処理してます? 自分は2回リトライさせてるだけなんですけど、 「普通はこうやるんだ」みたいな決まりってあるんでしょうか?
397 :nobodyさん :04/10/25 04:26:44 ID:???.net >>396 でたことないので、出たら出ないように調べると思う
398 :nobodyさん :04/10/28 02:30:23 ID:???.net ポストグレスキューエルを信じて裏切られることはありまつか?
399 :nobodyさん :04/10/30 09:21:22 ID:???.net PostgreSQL ベースの某社の製品にならあるけど。
400 :7.4.5 :04/10/30 20:56:47 ID:???.net 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/.net PHP4.39とPGSQL7.46で学習してます トランザクションについて教えてください BEGIN SELECT テーブルAのid(SERIAL)のNEXTVALを取得 INSERT テーブルAに上で得られた値をidにいれて挿入 INSERT テーブルBに上で得られたidの値を挿入 COMMIT 以上のような流れがあったとしてテーブルAのidの唯一性は保証されてますか? 要はテーブルAにINSERTしたときのidを取得としてテーブルBにも入れたいんです。 NEXTVALを取ったあとに他のプロセスが参照してデータの整合性がなくなるのが心配です。
402 :nobodyさん :04/11/10 17:52:12 ID:???.net シーケンスの nextval で取得される値は トランザクションとは関係なく 唯一性が保証されるように思う
403 :nobodyさん :04/11/17 16:35:31 ID:???.net (;´Д`)ハァハァ ポストグレスキューエルはマイエスキューエルにまだアドバンテージはあるのかい?
404 :nobodyさん :04/11/24 18:16:16 ID:fGkcMHGT.net SELECTして出てきた行に1から始まる連番をつけるってことできますか? データのランキングをだしたいんですが。
405 :nobodyさん :04/11/24 19:32:44 ID:???.net PostgreSQL 7.4.6 の環境で質問があります。 データベースtest_db内のテーブルtbl_aのパーミッション を以下のようになっているのですが、、、 test_db=# \dp tbl_a Access permissions for database "test_db" Relation | Access permissions ----------+------------------------------------- tbl_a | {"=","postgres=arwR","nobody=arwR"} (1 row) パーミッション未設定のテーブルを上記の同じ設定にするには、 どのようにすれば、いいでしょうか? test_db=# \dp tbl_b Access permissions for database "test_db" Relation | Access permissions ----------+------------------------------------- tbl_b | (1 row)
406 :405 :04/11/24 20:46:16 ID:???.net >> 405 の件は、自己解決しました。 grant select,insert,update,rule on tbl_b to nobody; 以上で実現しました。 板汚し失礼しました。
407 :nobodyさん :04/11/24 20:56:44 ID:???.net >>403 Myに比べて多機能だしいろいろあるだろ >>404 できる
408 :404 :04/11/27 22:42:48 ID:???.net >>407 具体的にどうやるんですか?マニュアル読み漁ってもわかりません。 サブクエリで連番つくる方法は検索して見つかったんですけど もっと簡単にできないものかと。
409 :nobodyさん :04/12/03 01:31:36 ID:2+kl6sm2.net カラム内のデータを置き換えすることはできないものでしょうか。 イメージとしましては、 update table_name set f =~ s/abcde/qwert/g; こんな感じのようなことをやりたいのですが、説明がどうもうまく なくて申し訳ありません。 ご教授いただければ幸いです。 宜しくお願いします。
410 :nobodyさん :04/12/03 02:07:28 ID:???.net お主の望みは正規表現置換かや? ならば、PL/Perl などを使ってユーザ定義関数を作れ、とのご神託である
411 :nobodyさん :04/12/03 10:44:31 ID:2+kl6sm2.net >>410 SQL内でなんとかできないものでしょうか。 フィールド値の内容を丸まる変更は当然出来ますが、 likeを使用しつつもどうにかできないものかと模索中で ございます。
412 :nobodyさん :04/12/03 12:23:36 ID:???.net 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.net >>410 、>>412 ERROR: Unrecognized language specified in a CREATE FUNCTION: 'plperl'. Recognized languages are sql, C, internal, and created procedural languages. となったので、どうやらPL/Perlが入っていないみたいなので、入れる権限のない 私なりに何か他に方法がないか探してみました。 http://www.nanbu.com/~nanbu/keizi_show1_2.php?category1key=&keizikey=1041937855000000006&PHPSESSID=8087763c1060187e12476afe32e0a60d これでなんとか凌ぎました。 グローバルオプションこそつけられないものの、置き換えは何とかできるので 助かってます。 ご教授有難うございました。
414 :nobodyさん :04/12/16 13:06:24 ID:qpxocizM.net foo というテーブルで、hoge fuga hige moe ちう2つのレコードがあります。 で、hoge fuga higeが3つとも同じレコードについては、まとめて1レコードとみなし。 fooテーブルが何レコードあるか調べたいのですが、 どうゆうSQL文を書いたらよいのでしょうか? select sum(*) from favorite group by hoge, fuga, hige とやってもだめでした(そりゃそうだよね。。。) どなたか教えていただければ幸いです。
415 :414 :04/12/16 13:07:38 ID:???.net 訂正: >foo というテーブルで、hoge fuga hige moe >ちう2つのレコードがあります。 foo というテーブルで、hoge fuga hige moe という2つの「フィールド」があります。 すみません
416 :414 :04/12/16 21:08:42 ID:???.net 回答ないようなのでDB板逝ってきます
417 :nobodyさん :05/01/19 17:22:21 ID:???.net ゲイツOSに対応した、postgreSQL8 キタ━━━━(゚∀゚)━━━━ッ!!
418 :nobodyさん :05/01/21 13:24:22 ID:DguRcNyC.net フィールドが一個だけのテーブルが必要なんですが こういうことって変ですか?
419 :nobodyさん :05/01/21 15:11:06 ID:???.net >>418 それだけの情報で何をどう答えろと? そうですか、では私はエスパーですか
420 :nobodyさん :05/01/22 02:07:24 ID:???.net >>418 必要なのなら変ではない。 必要ないのにあるのなら変。
421 :nobodyさん :05/02/01 16:43:18 ID:HYaKzyWg.net vacuum fullを実行すると2〜3時間ぐらいかかり、 しかもその間、httpdに完全に接続できなくなります。 vacuum fullって、そんなもんなのでしょうか? vacuumしないと、3日もしないうちに重くなってDB接続エラーでまくります。 3日1回httpd止めて作業となると大変なので軽減させたいのですが、 何か良い方法があれば教えてくださいm(_ _)m 構成は、こんな感じです。 Xeon2.8GHzDUAL メモリ2GB HDD120GB Linux-FedoraCore2 ・apache_1.3.33 ・postgresql-7.4.5 ・php-4.3.9
422 :nobodyさん :05/02/01 17:35:59 ID:???.net >>421 VACUUM FULLを定期的にする必要なんてないっしょ。 普通cronで1日1回vacuumdb -aで十分。 8.0ならVACUUM遅延機能があるからなおよし。
423 :nobodyさん :05/02/01 17:47:45 ID:???.net >>421 3日に1回って、そんなにすごい頻度で delete / update してるDBなのか
424 :nobodyさん :05/02/01 18:13:44 ID:???.net おいらはvacuumdb -a -z派
425 :nobodyさん :05/02/01 18:21:39 ID:???.net >>423 Apacheが絡んでるから、mod_auth_pgsql使っててなおかつログ取ってるとか セッションストレージにPostgres使ってると思われ。 ツッコミどころはそこじゃなくてVACUUM "FULL"じゃないかな。
426 :421 :05/02/01 18:31:46 ID:???.net >>422-424 ありがとうございました。 PostGre使い出したのは最近なので、このvacuumにてこずってます。。。 1日1回vacuumdb -a を実行するとして、その間、みなさんはhttpdを落としたりしてますか? ちょっと前、vacuumdbをアクセスが少ない時間帯に自動で実行させてそのままほっといてたら、 物凄く時間がかかった上に、DBエラーがでまくりで、とても公開できたもんじゃありませんでした。。。 (2〜3時間ぐらいはアクセスできない状態が続いていていました。) 参考までに、vacuumdbにどのぐらいの時間がかかるものなのか教えてくださいm(_ _)m
427 :nobodyさん :05/02/08 18:04:40 ID:???.net 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.net 今、phppgadminを使っているんですが、 これってテーブルの中身のデータを検索するのって 出来ないんですか? どうも検索システムを使っても、テーブル名しか 検索していないようなんですが…
429 :nobodyさん :05/02/19 06:45:44 ID:nMzWTz6R.net >>428 SQL発行じゃダメなのか?
430 :nobodyさん :05/02/19 19:15:51 ID:gwEGKWwx.net >>429 たとえば、検索して、その中からいくつかをチョイスして削除とか そういうのをグラフィカルに出来たらいいなあ、と思うのですが。 今はSQLを発行してやってます。
431 :nobodyさん :05/02/20 00:15:29 ID:???.net Postgresをpg_hda.confで各DBにアクセス制限をかけているのですが、 phpPgAdminでどれか一つのDBへアクセスできると、他のDBにも アクセスできるようになってしまいます。 各DBを完全に独立させるのはどのような設定を行えばよいのでしょうか。 ご教示いただけますと助かります。
432 :nobodyさん :05/02/20 01:47:50 ID:???.net pg_hda はソケットレベルでの接続を制御するもの DB毎にアクセスを制御したければ SQL の grant でスキーマレベルでの権限を設定する
433 :nobodyさん :05/02/28 02:38:12 ID:???.net ちょっと聞いてみたい。 一回ページを表示するのに多いとこで何回くらいクエリ投げてる? というか何回くらい投げてたら多いと思う?
434 :nobodyさん :05/02/28 03:11:15 ID:???.net 50回くらい投げてたら多いと思うね。
435 :nobodyさん :05/02/28 21:12:21 ID:43Vt3CIQ.net select now() - (select max(date_create) from counter); というSQLで出る18:11:08.696398という時間を、秒数(60* 60*18+60*11+8)に変換して出したいのですが、何かやり方 はございますでしょうか。 ご教授いただけますと幸いです。
436 :nobodyさん :05/03/01 05:54:49 ID:???.net 環境: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.net alter user postgres with password ''; でpostgresのパスワードを無しにしたのですが、こう設定した場合、 postgresユーザでのDB接続は出来なくなると考えて宜しいので しょうか。 pg_hba.confでは local all all md5 host all all 127.0.0.1 255.255.255.255 md5 local all all reject host all all 127.0.0.1 255.255.255.255 reject と設定済みです。
438 :nobodyさん :05/03/10 20:07:41 ID:???.net pgbenchってやってます??みなさんどれくらいの値出ます?? ちなみにうち pgbench -c 10 -t 100 bench tps: 112 (including) , 113 (excluding) [Athlon XP-M 1700+,RAID1,RH7.3,psql7.2.4] tps: 261 (including) , 264 (excluding) [Pentium4 2.83GHz,RAID1,RH9,psql7.3.4] pgbench -c 10 -t 100 -S bench tps: 1925 (including) , 2290 (excluding) [Athlon XP-M 1700+,RAID1,RH7.3,psql7.2.4] tps: 2907 (including) , 3253 (excluding) [Pentium4 2.83GHz,RAID1,RH9,psql7.3.4] 良いのか悪いのか全くわからん。 OpteronとかXeonだったらどれくらいいくんだろう。 ってか、pgbenchの結果を晒しあってるスレあったら誘導してくれ。。。
439 :nobodyさん :05/03/13 15:32:22 ID:???.net Windowsネイティブ対応キタ━━━━━━(゚∀゚)━━━━━━ !!!!!
440 :nobodyさん :05/03/18 19:32:34 ID:NKwPelPw.net 一年生、男性、5人 二年生、女性、3人 というクエリー結果を 男性 女性 一年生 5人 二年生 3人 っていう風に見せたいときどうする? やっぱPHPで加工するしかないのかな?
441 :nobodyさん :05/03/18 21:00:03 ID:???.net case文つかえ
442 :nobodyさん :2005/04/22(金) 12:41:11 ID:???.net >>30 あたりでダンプの話題が出ていたようですが複数のDBがあるので pg_dumpalを使ってみました。生成されたファイルをみてみると 最初の方で全てのDB分CREATE USERがしてあってそのあと全てのDB分 CREATE DATABASE "DB名"の様になっていましたが ある一つのDBだけリストアしたい場合には pg_dumpallから生成されたファイルは使えないのでしょうか? @7.2.3です
443 :nobodyさん :2005/04/26(火) 14:59:54 ID:???.net circle型のインサート構文がリファレンスに書いてないしぐぐっても出てこないので 誰か教えて下さい。 insert into table(field)values((0,0),1); とか insert into table(field)values(GeometryFromText('Circle((0,0),1)')); とか 色々試してみたけどダメでした。
444 :nobodyさん :2005/04/26(火) 16:19:41 ID:???.net >>443 INSERT INTO Table(field) VALUES(circle'((0,0),1)');
445 :nobodyさん :2005/04/26(火) 16:27:20 ID:???.net >>443 おまけ。 INSERT INTO Table(field) VALUES('<(0,0),1>'); INSERT INTO Table(field) VALUES('0,0,1'); その他いろいろ... まぁバージョンによって認識してくれる書式に 多少の違いがあるかもしれん。
446 :nobodyさん :2005/04/26(火) 18:18:09 ID:???.net pgadmin3のバグ(だと思う)報告。 適当なデータベースでテーブル(列は一つで主キーも無く名前・オーナー・テーブル空間・OIDを持つのみを設定)を作り、 データベース→使ったデータベース名→スキーマ→public→テーブル→作成したテーブル名 とたどり、テーブル名を右クリックしてプロパティを開く。 列タブに移動して唯一の列を削除して同一の名前の列(データ型は異なる)を追加する。 OKを押す→エラー発生(これは例外処理として正常だが) ここでさきほど右クリックしたテーブル名を再び右クリックしてリフレッシュを選択。 その後再び列追加のOKを押すとpgadmin3が突然消える。 俺の環境ではこの操作でこの現象は100%再現する。 他にも細かいおかしな挙動がたくさんあったが忘れた。 (俺がpgadmin3使うの初めてなんでおかしな操作してるのかもしれない)
447 :443 :2005/04/26(火) 18:33:06 ID:???.net >>444-445 レスありがとう!助かりました。
448 :nobodyさん :2005/04/26(火) 18:51:43 ID:???.net gistインデックスを作る際に指定するgist_geometry_opsには 比較演算子のセットを指示しろとpostGISのマニュアルに書いてあったけど、 && << >> <^ >^ と書いたら&&の時点で怒られた。 何を書けというの? せめて一つくらいコード例書いといてくれよ・・・>マニュアル
449 :nobodyさん :2005/04/26(火) 18:53:01 ID:x+Vlqkfm.net ものすごくつまらないことを聞いてもいいですか? 今現在、postgresがオーナーになっているDBがありまして 他のユーザーをオーナーにしたい場合ってどうすればいいんでしょう?
450 :nobodyさん :2005/04/26(火) 20:44:42 ID:???.net >>449 ALTER DATABASE database OWNER TO newowner;
451 :nobodyさん :2005/06/08(水) 13:03:23 ID:???.net JNDIから取得したDataSourceでコネクションプーリングする方法を 教えてください。
452 :nobodyさん :2005/06/08(水) 15:36:20 ID:???.net コネクションプーリングの実装は難しいから、自分でくまない方がいいとおもうけど。 JNDIからプーリングしてもらったコネクションを取得するようにしたほうがいいと思われ。
453 :nobodyさん :2005/06/08(水) 21:49:29 ID:???.net 普通にJNDIルックアップして取得したDataSourceって ConnectionPool実装してないよね? InitialContext ctx = new InitialContext(); DataSource ds = (DataSource)ctx.lookup("DataSourceName"); Connection conn = ds.getConnection(); ってな具合に普通にコネクション取ってるだけど Jdbc3PoolingDataSourceとかでキャストすると落ちるし。 そもそもJNDIで定義してるDataSourceのクラスってどこ変更すりゃいいの? ってか猛烈にスレ違いだなー
454 :nobodyさん :2005/06/08(水) 22:33:26 ID:???.net 普通にって、そりゃどこでどういう風にJNDIに登録してるかだろ。 コネクションプーリングしたコネクションをJNDIに登録して、それとってくればコネクションプーリングされてるだろ。
455 :nobodyさん :2005/06/08(水) 23:15:34 ID:???.net DataSourceをJNDIに登録する時に、ドライバークラスはもちろん指定できるんですが データソースのクラスまで指定する事ってできるんでしょうか? 指定しないで登録すると、デフォルトのjava.sql.DataSourceで登録しますよね。
456 :nobodyさん :2005/06/08(水) 23:40:26 ID:???.net しらんよ、あんたの実装のことなんか。
457 :nobodyさん :2005/06/08(水) 23:52:27 ID:???.net >>456 ですよね。 もうちょっと調べてみます。
458 :nobodyさん :2005/06/09(木) 00:04:51 ID:???.net 結局なにがしたいのか謎だったな。 WebならTomcatにまかせとけばいいし、気にすることないからなぁ。
459 :nobodyさん :2005/06/09(木) 00:16:30 ID:???.net 結局、JBoss使ってるんですけど、 DataSourceのJNDI定義するXMLをそのままデプロイすると java.sql.DataSourceで登録されちゃうんでなんとかならないかなと思ってたんです。 この定義するXMLの中にDataSourceクラスを定義する ディレクティブが無いんですよね。
460 :nobodyさん :2005/06/09(木) 01:38:08 ID:???.net で、それはコネクションプーリングしてくれてないの?
461 :nobodyさん :2005/06/09(木) 02:13:55 ID:???.net くれないです。 java.sql.DataSourceは、ConnectionPooling実装してないんで使い捨てですね。 してくれたら、このクラス、仕様どおりに動いて無い事になるので逆に困りますw Factoryから自作してやろうかと思ったんですが危ないし、 その筋の人間の作ったJDBCドライバーかデータソースに完全に任せたいです。
462 :nobodyさん :2005/06/09(木) 05:10:57 ID:???.net java.sql.DataSourceなんてないと思うのだが。 javax.sql.DataSourceはインターフェイスだからConnectionPooling実装してるとかしてないとか、関係ないと思うが。 というか、ConnectionPoolingって、インターフェイス?
463 :nobodyさん :2005/06/09(木) 17:25:42 ID:???.net >>462 ですね。DataSourceはインターフェースです。 ConnectionPoolingっていうのは、仕組みなのでクラスでもインターフェースでもないです。 ちょっと検証できそうなものを見つけました。 ttp://www2b.biglobe.ne.jp/~caco/pgpool/
464 :nobodyさん :2005/06/09(木) 17:47:39 ID:???.net キッチリ解決しました。 MySQLの資料ですが、まんまいけるハズです。 ttp://kamakura.cool.ne.jp/oppama/swjd/jndidatasource.html
465 :nobodyさん :2005/06/09(木) 22:11:26 ID:???.net つうか、JBossがわざわざJNDIに登録してるものが、コネクションプーリングしてないとは思えんのだが。
466 :nobodyさん :2005/06/16(木) 02:31:27 ID:???.net 質問させてください。 現在レン鯖の「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さん :2005/06/16(木) 02:39:31 ID:???.net >>466 設定を変えたときPostgreSQLの再起動をした? って言うか、貸鯖で設定ファイルを弄らしてくれるのかよ... それよりもtcp/ipによる接続の必要性が無いのなら UnixDomainSocketでいいんじゃね。 $pgsql_conn = pg_connect("dbname=DB名 user=名前 password=パス");
468 :nobodyさん :2005/06/16(木) 02:42:30 ID:???.net >>467 こんばんわ 再起動は/etc/rc.d/initdからしました なんかvps?とかで似非root権限があるそうです。 $pgsql_conn = pg_connect("dbname=DB名 user=名前 password=パス"); ↑host=localhostでソケット通信かとおもてた、ちょっと試してきます
469 :nobodyさん :2005/06/16(木) 02:50:33 ID:???.net >>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さん :2005/06/16(木) 02:59:33 ID:???.net >>469 う〜ん。とりあえず、エラー表示が一切無いのも気になる。 スクリプトの先頭で error_reporting(E_ALL); ってすれば何かエラーでないか?
471 :nobodyさん :2005/06/16(木) 14:44:13 ID:???.net >>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さん :2005/06/16(木) 17:18:41 ID:???.net >>471 そのエラー表示だと、DBそのものはローカルで動いていると思われ。 dbnameがおかしいんじゃね。
473 :nobodyさん :2005/06/30(木) 04:40:53 ID:???.net どもです。はじめまして。 phpPdAdminの質問なのですが、特権一覧と言うところに「102」という ユーザーがいるんですが、これは自動的に追加される何らかのユーザー なのでしょうか?? SQLを直で覗いてユーザー一覧を見たのですが、 このユーザーはいませんでした。 phpPgAdminからしか認識できません。 どなたか知っている人がいましたら、アドバス願います。
474 :nobodyさん :2005/06/30(木) 20:13:04 ID:cHU+f8gL.net アドバス願います。
475 :nobodyさん :2005/07/23(土) 07:34:11 ID:WyqF/aD4.net RDBMS背負ったWebアプリを開発必要があり、 Perl、DBI、PostgreSQLの勉強を進めています。 要件がなかなかFIXしないため暫定的にスタートしなくては ならない状態なのですが、運用途中でテーブルの「列」を増減させる事は 可能なのでしょうか。 あるいは新たな構造のテーブルを作り、データを移す、とかの方法になりますか?
476 :nobodyさん :2005/07/23(土) 08:02:53 ID:???.net >>475 ALTER TABLE ADD COLUMN で可。 http://www.postgresql.jp/document/pg803doc/html/sql-altertable.html
477 :nobodyさん :2005/07/23(土) 18:38:51 ID:???.net >>476 どうもありがとうございます。 このドキュメント、いいですね。 7.4.7なので近いバージョンのをじっくり読んでみようと思います。
478 :nobodyさん :2005/07/29(金) 13:20:03 ID:p5If7shl.net 郵政公社が公開している郵便番号データをテキストに変換 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.net PostgreSQL8.0.3 を使ってWebアプリをJavaで構築してます。 ユーザーが入力した情報がtext型に入ってて、このカラムに対してキーワード検索をしたい、という 要件が入ってます。 普通にlike文で検索すれば良いと思うのですが、実際、レコード件数が最大で億を超えることが予想されるようです。 text型ですけど、1万文字の文字数チェックを入れる予定です。 この場合,like文ですとインデックスが当然きかないのでかなりの時間がかかる処理になってしまうと思います。 一般的にこのような場合はDBに頼らず別の仕組みをつかっているんでしょうか?? 良くある会員サイトで使われている検索はlike文で頑張っているんでしょうかね? まだシステム仕様変更をするための時間があるのでアドバイスいただけるとありがたいです。
480 :nobodyさん :2005/10/25(火) 18:28:23 ID:???.net >>479 普通は「全文検索」モジュールなんかを使うんじゃないのか? つ ttps://www.oss.ecl.ntt.co.jp/tsearch2j/index.html
481 :nobodyさん :2005/10/25(火) 19:38:24 ID:???.net 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.net ありがとうございます。全文検索ですか。はじめて扱いますがドキドキですw >>480 で紹介されているTsearch2 はオープンソースとのことですが、 先に述べたレコード数ですとパフォーマンス劣化は大丈夫でしょうか。 >>481 さんの内容ですと、Hyper Estraier というのがBestという感じでしょうかね…。 ともあれ、ありがとうございました。
483 :nobodyさん :2005/10/25(火) 21:46:04 ID:???.net >>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.net >>483 さらに詳しい説明、感謝致します。 詳しくはHyper Estraieを調査すればわかるとおもいますが、一つだけ。 「インデックスへの登録」という部分は、たとえばText型に入る内容を Hyper Estraierに対して投げる、という感じでしょうか。その属性にpkyを付加すると。 であれば、Hyper Estraierが持つであろうインデックスファイルなどは結構な量になると 思われますが、正しい認識でしょうか。データ量が多くになると、RDBMSとは別に 全文検索用のサーバーを用意するという運用体型になるって感じでしょうか。 なかなか楽しい世界ですね。ありがとうございます。
485 :479 :2005/10/26(水) 10:41:49 ID:???.net >>484 の補足というか。Hyper Estraierについて簡単に調べました。 要求に十分こたえられる仕様だと思っています。 紹介してくださってありがとうございました。
486 :nobodyさん :2006/02/13(月) 18:56:37 ID:???.net OIDについて質問です。 あるテーブルでの一意性を保証したいのですが、 単純に該当テーブルのOIDに対してUNIQUEを指定してしまえばいいということなんでしょうか...? PostgreSQL7.4を想定しています。 http://www.postgresql.jp/document/pg732doc/user/datatype-oid.html OID は 32 ビット長であり、クラスタ全体で 1 つのカウンタから割り当てられます。 巨大な、または、長期間運用しているデータベースでは、カウンタが一周する可能性があります。 従って、OID が一意であることを前提とすることは、OID を一意にすることを保証する手段を講じていない限り非現実的です。 OID を使用して行の識別を行う推奨方法は、その OID が使用される各テーブルの OID 列に一意性制約を作成することです。 宜しくお願い致しますm(_ _)m
487 :nobodyさん :2006/03/07(火) 20:45:26 ID:???.net >>486 serialでも使えば?
488 :nobodyさん :2006/04/29(土) 23:20:03 ID:???.net DB板での書き込みを再掲させて戴きます。レスがつかなかったもので…orz PostgreSQLを使って、下記のような処理を作ろうと考えています。 現在「特定テーブルのCSV出力」に何を使うかで悩んでいます。 ストアドプロシージャか、PHPを使うかの二択から選んでくれと言われたのですが、 クライアントアプリがこれらをキックすることを考えるとどちらが簡単でしょうか。 ---------- クライアント:Windows(.NETで開発) サーバ:RedHat Linux + PostgreSQL やりたいこと。 1.通信はhttpのみ。 2.クライアントはサーバにアクセスして、 「特定テーブルのCSV出力」を命令する。<--------------(・ω・) 3.クライアントは処理の終了を待つ。 4.クライアントは出力されたCSVファイルをダウンロードする。
489 :nobodyさん :2006/04/29(土) 23:29:08 ID:???.net >>488 .NETからストアドたたけるんだろうから、ストアドでやれば? と思ったけど、httpのみかよ。 http通信で直接ストアドなんて呼べるのか? 結局phpでラップすることになるんではないかな。
490 :nobodyさん :2006/04/30(日) 00:06:46 ID:???.net >>489 レスありがとうございます。 ADO.NETを使っていいものなら話は簡単なんですけどね…。 「セキュリティの観点」からダメだと言われてしまいました。 ちなみにPHPをキックすること自体は簡単にできるものでしょうか?
491 :nobodyさん :2006/04/30(日) 00:21:53 ID:???.net >>488 なんの言語でやるのかしらんが、たとえばPHPでやるとして *.csvファイルをPHPで処理するように関連付けて *.csvファイルの中にcsv出力する[プログラム書いて ヘッダーをtext出力にすればOk。
492 :nobodyさん :2006/04/30(日) 04:22:25 ID:???.net >>490 > ちなみにPHPをキックすること自体は簡単にできるものでしょうか? > 1.通信はhttpのみ。 なんだから、単純にphpのファイルにhttpアクセスするしかないのでは?
493 :nobodyさん :2006/05/08(月) 08:53:52 ID:???.net >>491-492 了解しました。いかにも素人の質問に答えてくださってありがとうございます。
494 :good :2006/05/11(木) 15:23:40 ID:UxCS1jwo.net 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.net あるテーブルのint型の変数にNULLを代入しようとすると、 エラーではじかれてしまうのですが、 何がいけないのでしょうか? charでは問題ありませんし、特にNULLがダメというわけでもないように思っているのですが、 そういうケースがあるんでしょうか?
496 :nobodyさん :2006/05/17(水) 22:35:27 ID:???.net 'NULL'ってやってるとか? queryをダンプして貼ったらレスも付き易いかと。
497 :nobodyさん :2006/05/17(水) 22:46:12 ID:???.net すみません、あまり経験も乏しいので説明が要領を得ないかもしれませんが、 insert into test(param) values(''); という感じです。(test というテーブルの param に代入) 実際には、COPYコマンドでファイルから代入しようとして蹴られます。 a,b,,,,c,,d, というようなデータ列で、','を区切り文字としています。 ,, の部分がNULLとして扱われると思うんですが、 varchar(20)などでは問題ないのに、intのところでエラーが出ます。 それでコマンドラインでも試してみたところ、やはり同じエラーが出ました。 マニュアルなどでデータ型を見た限りだと、NULLでも問題なさそうに思うのですが、 何か操作上の間違いがあるのでしょうか。 あと、言い忘れていましたが、試しているのは Windows の psql です。
498 :nobodyさん :2006/05/18(木) 00:46:59 ID:???.net >a,b,,,,c,,d, というようなデータ列で、','を区切り文字としています。 ここを a,b,NULL, NULL, NULL,c, NULL,d, みたいだとどうだろ(試してないけど
499 :nobodyさん :2006/05/18(木) 01:27:13 ID:???.net >>497 COPY じゃ無くて \COPY を使っているとか? COPYは ,, をNULLとして扱うようだけど、 \COPYは ,, を ""(空白文字列) として扱っている。 \COPY table FROM filename NULL '' でいけるんじゃね? > insert into test(param) values(''); ''とNULLは別もんだよ。
500 :497 :2006/05/18(木) 02:19:43 ID:???.net >>499 うげ、そうだったんですか。 明日早速やってみます。 >>498 そういうのもありなんですか。 ただ、今やってるのは、他の人が用意したcsvをそのまま利用しているので、 そういうやり方だと何かしらのコンバートが必要になりますよね。 いずれにせよ、アドバイスありがとうございます。
501 :nobodyさん :2006/05/18(木) 21:20:56 ID:???.net 先週まで正常に動いていた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 :2006/05/18(木) 22:12:42 ID:???.net 今日やってみたところ、期待通りの動作をしました。 とても助かりました。 どこのどなたか存じませんが、ありがとうございました。
503 :nobodyさん :2006/05/19(金) 10:16:13 ID:S+/mH4DM.net 8.1ってiモードの絵文字(外字領域)使えますか? DBはEUC_JPで構築しています。
504 :nobodyさん :2006/07/19(水) 22:01:12 ID:6lmDHlcw.net バイナリ本体は/usr/local/pgsqlに置いて、DBを/home/pgsql/varに置くようにコンパイルってどうすればできますか?
505 :nobodyさん :2006/07/19(水) 22:17:41 ID:???.net >>504 initdb & PGDATA
506 :504 :2006/07/20(木) 23:55:57 ID:???.net なんだ、コンパイルのオプションと違ったんだ。 ありがと。
507 :nobodyさん :2006/07/22(土) 00:36:09 ID:TflzrAiN.net 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:???.net >>507 http://www.geocities.jp/inocchichichi/psqlodbc/indexj.html を使いましょう
509 :nobodyさん :2006/07/22(土) 07:31:10 ID:???.net ○○日間アクセスしてないユーザを削除する、という処理をさせたいんですが Postgresだけでこれを実現する機能があれば教えてください (OSの方で定期的にスクリプトを実行するのが普通なんでしょうか?)
510 :nobodyさん :2006/07/22(土) 17:56:12 ID:???.net cronかアクセスがあるごとに削除クエリ実行するしかないだろう
511 :509 :2006/07/22(土) 18:14:09 ID:???.net やっぱりそうですよね。。。ありがとうございました
512 :nobodyさん :2006/08/01(火) 18:36:35 ID:???.net 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:???.net 自己レスですorz 接続した直後に set client_encoding to 'EUC_JP' をすればいいだけでした。 お騒がせしました。
514 :nobodyさん :2006/08/02(水) 12:41:10 ID:IBuG4Wqs.net 2GBくらいある巨大テーブルがあって、 けっこう複雑なクエリを、いろんな方向からかけるので、 どうしてもseqが走ってしまって、遅くなって困ってます。。 8.1のテーブルパーティショニングを試してもみたんですが、 オプティマイザがバカになって使えないし。。。 殆どがディスクI/O待ちなのですが、こういうときどういった対策があるでしょうか。 どなたか助けて下さい(´・ω・`)
515 :nobodyさん :2006/08/02(水) 14:08:15 ID:???.net >>514 explainやったの?
516 :514 :2006/08/02(水) 14:47:09 ID:IBuG4Wqs.net はい。そのへんの対策はだいたい。
517 :nobodyさん :2006/08/02(水) 18:06:07 ID:???.net >>516 なんでそれで修正できないんだ? explainでseqになってるところにindexはるなり、テーブル分割するなり したら基本的に全部なくせるはずだけど?
518 :514 :2006/08/04(金) 12:12:04 ID:dYxM1faY.net >>517 集計関数が多いことが、大きな理由だと思います。 様々な角度で切り込まないといけないので、 中間テーブルを作るとなると膨大な量になってしまって。。。
519 :nobodyさん :2006/08/04(金) 12:24:10 ID:???.net >>518 で、結局君は何を求めてここに書いているわけ? どんなテーブル構造になってるかも分からない、seq になる SQL も分からない。 それで、何をどうアドバイスしろ、と。 一言で言うと、「知らんがな」
520 :nobodyさん :2006/08/22(火) 09:04:21 ID:???.net 以下を実行したいのですが, 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:???.net make install
522 :nobodyさん :2006/10/21(土) 02:59:30 ID:???.net こんばんわ 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:???.net current_timestamp のことではなくて?
524 :nobodyさん :2006/10/21(土) 03:59:12 ID:???.net >>523 タイプミスしないように¥dで表示されるTypeの項目から拾ってきちゃってた… せめて"そんなデフォルトは指定できません"的なエラー吐いてくれれば… ありがとうございました
525 :nobodyさん :2006/10/23(月) 04:52:02 ID:???.net 先輩が書いたコードを読んでたら SELECT * from xxtablexx where xxcomunxx 〜 '^[ま-も]' ; というqueryが書いてあったんですが、〜 '^[ま-も]'の【〜】の意味が分かりません、マニュアル等に載ってますでしょうか?
526 :nobodyさん :2006/10/23(月) 09:04:41 ID:???.net >>525 POSIX正規表現なんじゃないの?
527 :nobodyさん :2006/10/23(月) 18:03:17 ID:???.net hogeテーブルに各種データとtimestamp型でInsertされた日付が格納されているんだけど 日付=todayのように日付でみるんじゃなく、「何時間以内」という様な指定でデータを取得することは可能ですか? @7.4です
528 :nobodyさん :2006/10/23(月) 22:26:23 ID:???.net >527 intervalでマニュアルを検索しる。
529 :nobodyさん :2006/10/25(水) 09:54:38 ID:X5/anJFE.net 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:???.net >>529 根本的にSQLが間違ってる、って思わない訳?
531 :nobodyさん :2006/10/26(木) 00:18:23 ID:PySunuHV.net やはりそうですか。。 答えが見当たらなかった為、 今はselectで取得したキーを使って、 変数に格納してから、deleteを発行しなおしてます。 動作が遅くなりそうな気もしますが。。。
532 :nobodyさん :2006/10/26(木) 00:38:43 ID:???.net >>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.net >>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:???.net >>533 なんかそれ以前の問題。 汎用的なSQL入門本でも買って読んだら。 2〜3日ありゃ十分読めるし、基礎だけでも 身に付けたほうが後々楽。
535 :nobodyさん :2006/10/27(金) 09:56:45 ID:???.net >>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.net >>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.net Postgres の列制約で、後から unique を定義することは出来ますか?
538 :nobodyさん :2006/10/28(土) 01:30:04 ID:???.net >>537 できる
539 :nobodyさん :2006/10/28(土) 10:55:59 ID:???.net >>538 バージョンは8.1なんですけど、持ってるの古い本で その中では出来ないとか書いてあって、ネットで調べても出来ないって あったんですけど なんかそのあたりを書いてあるページを教えていただけないでしょうか
540 :nobodyさん :2006/10/29(日) 12:06:54 ID:???.net >>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.net ヒントだけでもお願いできたら嬉しいのですが、 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:???.net じゃ、ヒントだけ 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:???.net >>540 ありがとうございました おっしゃるとおりです、以後気をつけまする 助かりました
544 :nobodyさん :2006/11/03(金) 16:57:01 ID:???.net 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:???.net >>544 WHERE句で TO_CHAR(insert,'yyyy/mm/dd') = TO_CHAR(current_timestamp,'yyyy/mm/dd') すれば今日のデータだけ取れるだろ。
546 :544 :2006/11/03(金) 23:36:51 ID:???.net >>545 ごめんなさい、insertされてからX日以上たったレコードのstatusに操作を加えたいのです。 上記コードはその過程で「insert後一日以上たったレコード」をSELECTしています
547 :nobodyさん :2006/11/04(土) 00:00:46 ID:???.net 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:???.net >>547 試しましたが何日前のレコードでもSELECTされてしまいました。 SQLは日付なんかも結構柔軟に扱えそうなんですがスキル不足で…。 とりあえずはこのまま全件とってきてスクリプト側(PHP使ってます)で判定するようにしてみます ありがとうございました
549 :nobodyさん :2006/11/04(土) 00:39:28 ID:???.net つーか、列名に insert はないだろ。 結局「今日」のデータがとりたいのか「X日以上経った」データをとりたいのかも分からん。
550 :544 :2006/11/04(土) 00:50:26 ID:???.net >>549 最初、予約語だからダメだろうと思ったんですが試しにCREATE TABLEで使ってみたら通ったのでそのままでした。 最終的にとりたいのは「X日以上経った」データですが、いきなりだと難しいそうなので 「今日中に」INSERTされたデータをSELECTしようとしてみたりしました。
551 :nobodyさん :2006/11/04(土) 00:54:56 ID:???.net 「テーブル作成 & テストデータ数個 INSERT」の SQL 書いてくれれば 試してみても良いけど
552 :544 :2006/11/04(土) 01:30:06 ID:???.net >>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:???.net >>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:???.net >>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:???.net あ、ごめん。「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:???.net >>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:???.net >>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.net 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:???.net >>558 date_trunc もしくは to_char で調べると幸せになれるかもね。
560 :nobodyさん :2006/12/08(金) 05:21:11 ID:???.net 8.2のウォームスタンバイって待機系にはリードオンリーでアクセスできる? MySQLのレプリケーションみたいに
561 :nobodyさん :2006/12/10(日) 22:52:41 ID:???.net 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:???.net 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:???.net わるぃ、自己解決しちまった。 テーブルがいまいちうまく作成されていなかった。 (列無しテーブルになっていた) いや、でも、文字コードのあたりは鬼門だねぇ。
564 :nobodyさん :2006/12/13(水) 19:49:55 ID:???.net >>562 文字コード云々で ごまかさなくても良いよwww
565 :nobodyさん :2006/12/16(土) 20:21:37 ID:qU5F6hFh.net 質問です。 ODBC接続ができなくて困っています。 odbcドライバーを入れて、サーバーのIP,データーベース名、ユーザー名と パスワードを入れても、確認テストの段階でエラーが出ます。 (... the target actively refused it) サーバーのポートは開いているようです。 何か思い当たる理由があったら教えてください。
566 :nobodyさん :2006/12/22(金) 11:46:09 ID:???.net 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:???.net >>565 >サーバーのポートは開いているようです ちゃんと確かめれ わからなけりゃ netstat -nlp|grep postmaster の結果貼れ >>566 rpmでインストールしたのかtarballでインストールしたのかくらい書け tarballならインストールされる場所が異なってるだけだと思われるが
568 :nobodyさん :2006/12/24(日) 01:03:37 ID:???.net >>567 お世話になります。 ソース提供の物をガイダンス(マニュアル)に従いgmakeしました。 インストールディレクトリはデフォルトで、各環境変数やpathも確認しました。 元々入っている旧の物が動いている可能性があるって事ですね。 もう少し調べてみます(週明けになってしまいますが)。 ありがとうございました。
569 :568です :2006/12/24(日) 01:07:34 ID:???.net 追伸 書き込み直後ですが、 PG_VERSIONファイルがあるディレクトリ(と言うよりdataディレクトリ全部) を前もって消して、インストール後に新たに出来たのを確認して その中のPG_VERSIONが7.3になるという事を思い出しました。 やはり7.3で作られてしまうとしか思えないです。。。
570 :nobodyさん :2006/12/28(木) 01:14:05 ID:???.net >>560 できないはず heartbeatと8.2・2台で信頼性高いHA作りたいなあ
571 :nobodyさん :2007/01/14(日) 18:53:27 ID:???.net 質問です。 LIKE演算子で全文検索したいのですが、LIKE演算子を全コラムに適用するには SELECT * FROM テーブル名 WHERE コラム1 LIKE '%キーワード%' OR コラム2 LIKE '%キーワード%' OR コラム3 LIKE '%キーワード%'; みたいに地道に全コラムを書き連ねないといけないのでしょうか? 全コラムをワイルドカードを使って簡単に書く事はできませんか? よろしくお願いします。
572 :nobodyさん :2007/01/14(日) 19:02:34 ID:???.net >>571 簡単に書くことは出来ません。 それ以前に、そんなSQLが実用的なのか考え直した方がいい。
573 :nobodyさん :2007/01/14(日) 19:07:49 ID:???.net >>572 ありがとうございました。 精進します。
574 :nobodyさん :2007/01/14(日) 23:50:14 ID:???.net ポスグレ対応の全文検索アプリ使えばいいんじゃネーノ
575 :nobodyさん :2007/02/05(月) 09:46:30 ID:???.net PGPOOLネタだが良い? PGPOOLでレプリカしてるんですがPgAdminIIIでテーブル作るとOIDが微妙に1〜2ずれたテーブルが作成されてしまいます。 そのたびにDB1−>DB2にrsyncしてとかやっているんですが、根本的な原因がわかればと…。 そういうことってないですか?
576 :nobodyさん :2007/02/05(月) 11:10:14 ID:???.net >>575 そもそもpgpoolってOIDが同一になるって保証してたっけ?
577 :nobodyさん :2007/03/13(火) 19:51:29 ID:???.net こんばんは、かなり下がってるので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:???.net >>577 COUNT(*)じゃなくて COUNT(COLUMN_NAME)とかにすれば 少しマシになるかもしれんよ。 対象カラムはPKになってるのが良いと思う。
579 :nobodyさん :2007/03/13(火) 21:47:22 ID:???.net >>578 一部でそれが有用なRDBMSがあるようだがPostgreSQLでは効果ないよ。 >>577 そのSQLでは逐次スキャンは仕方ない。が、5800件程度のレコードなら ちょっと遅すぎるな。VACUUM FULL;やって無効領域を飛ばせばどうだろうか。 1行がやたら滅多らでかい(巨大なtextやbyteカラムがある)場合は、外へ追い出すとか するしかない。
580 :577 :2007/03/14(水) 10:42:41 ID:???.net レスありがとうございます >>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:???.net >>580 コスト増になるのは単にCBOがタコなだけだろうな。 > 1週間に一度ほどの間隔で、レコードが全てが入れ替わる じゃ、きちんとメンテしないとだめだろうなぁ。 無駄なブロックまで走査しちゃうから。
582 :nobodyさん :2007/03/14(水) 12:48:12 ID:???.net count(*)は単純に行数が変えるが、 count(id)はidがNULLだったらカウントしないからね。 比較する分コスト増になっているのかも。
583 :nobodyさん :2007/03/14(水) 12:49:10 ID:???.net ×行数が変える ○行数が返る orz
584 :nobodyさん :2007/03/14(水) 12:54:16 ID:???.net って、よく見りゃ算出コストは変わってないやん。 ANALYZEで実行時間が変わるのはキャッシュが からんでんではねぇか。
585 :577 :2007/03/14(水) 14:33:11 ID:???.net >>584 >キャッシュが からんでんではねぇか。 やはりpsqlから実行する時でもキャッシュは関係するんですかね? 一般に公開しているページでリクエストがある都度count(*)すると重そうなので データを上げた際にcount(*)をしてテキストファイルにでも 総件数を出力しておいた方がいいかな、と思っております
586 :nobodyさん :2007/03/16(金) 22:21:41 ID:F/7LbTL8.net 質問させてください。 7.4.16へ、7.3.15のDBを移行しようとしています。 DBの文字コードはEUC-JPで、携帯電話などの尋常じゃないコードの文字が多く含まれて居ます。 EUCのチェックが古いバージョンに比べ厳しくなったとのことで、流し込んでも すぐエラーで止まってしまいます。 レコード数がとても多く、手動での修正は厳しいのですが 文字コードのチェックを甘くするオプションなどは無いでしょうか? どうぞ宜しくお願いします。
587 :nobodyさん :2007/04/01(日) 22:55:03 ID:ywkCVNqC.net ずっと悩んでいます。どうかお教えください。 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.net 上の続きです。 【環境】 サーバ: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:???.net 質問です。 PostgreSQL 8.1でマニュアル参考に、AutoVacuumを設定したつもりなのですが 動作しているかどうかが確認できません。 何を見れば分かるんでしょうかね? あと、pgpoolで複製かけた状態で、AutoVacuumしても問題ないのかしら?
590 :nobodyさん :2007/04/13(金) 10:28:00 ID:qKjbWP1o.net 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.net あ、見落としてました。Postgresは、実際には別サーバー経由だったかも。。 すみませんでした。
592 :nobodyさん :2007/05/07(月) 17:13:46 ID:i8IH1bx5.net 質問です。 crypt()で暗号化した文字列を複合化することってできないんでしょうか?
593 :nobodyさん :2007/05/07(月) 17:53:29 ID:???.net >>592 cryptは非可逆だったような気がしないでもない。 後、複合化じゃなく復号化、じゃないかとも思う。
594 :nobodyさん :2007/05/24(木) 21:16:34 ID:c925mgeL.net 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:???.net >>594 デフォルトではリンクされなかったと思う ググるとPosgtres7系だけど同じようなのが出てくるよ
596 :nobodyさん :2007/05/27(日) 01:24:36 ID:xID/GaI9.net どこに書こうか迷いましたがここで質問しちゃいます。 くだらないことなのですが 皆さん都道府県を入れるカラムって何という名前にしてます? 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:???.net >>596 うちではprefになってる。都道府県のHPのドメインも www.pref.〜 とかなってるし。
598 :nobodyさん :2007/05/27(日) 17:38:47 ID:???.net prefectureとかprefとか、stateは意味違う
599 :nobodyさん :2007/05/29(火) 07:59:24 ID:7xq0Zk/P.net >>597 >>598 レスありがとうございます。 厳密に言うとprefectureっていうのも意味違う気がするけど(都道府が入るから) まあ、そんな時間かけてなやむようなところでもないしw prefectureにしました。 ありがとうございました
600 :nobodyさん :2007/05/29(火) 20:02:58 ID:DKx8qJwX.net postgreで日本語(ひらがな)をソートするのに --no-locale をつけてinitdbするのはわかったのですが、 それでも濁点のついた文字のときおかしな挙動をするのですが 回避する方法はないのでしょうか? たとえば かかあ かかい かかう はちゃんと並ぶのですが かかい かかう がかあ と並んでしまいます。濁点は濁点のない文字の後に並ぶみたいです。 どうすればちゃんとソートできるようになるのでしょうか? お願いいたします 文字コードはUTF-8でバージョンは8.1.8です。
601 :nobodyさん :2007/05/29(火) 21:14:55 ID:???.net >>600 あんたの「ちゃんと」と定義する並びの文字コードを利用してください。
602 :nobodyさん :2007/05/29(火) 23:45:24 ID:???.net >>600 小学校で習わなかったか?
603 :nobodyさん :2007/05/30(水) 08:52:35 ID:???.net >>600 ちゃんとソートできてるよ。 それが嫌なら別のソート順確保用カラムでも追加するんだね。
604 :nobodyさん :2007/05/30(水) 10:41:44 ID:8UkqO0LS.net >>601 >>602 まじですか? これが正しい日本語の並び順なの? それは納得できん! >>603 今までそうだったのですが、ふりがなを濁点を入れないで入力します。 というか、たとえ学問的に国語がそうだとしても、現実にはちがわない? がかあ かかい かかう が自然だと思う。 うちの会社でも、クライアントにも、取引会社でも、みんなこの並び順はおかしいとなったので、 濁点なしで入力してたんですけど。
605 :nobodyさん :2007/05/30(水) 10:49:04 ID:???.net >>604 文字コード的には正しいだろ。
606 :nobodyさん :2007/05/30(水) 12:15:16 ID:???.net >>604 お前さん(と周囲)の考えが不自然だと思ったほうが良い どうしても嫌なら入力時に内部的に置き換えるしかなかろう
607 :604 :2007/05/30(水) 22:24:52 ID:amo3UjDj.net >>605 確かに文字コード的には正しい。正しいと言うよりも、コード化するのに そうするより仕方なかった感じかな。 >>602 と>>606 (たぶん同一人物)は絶対おかしい。 というか日本人じゃないでしょ。 やっぱ日本語って英語と比べて、デジタル化というかパソコンには向かないよね。 上の都道府県の例でもそう。言語というより文化も含めて合理的じゃないんだよね。 まあ、そこが良いところでもあるんだけど。
608 :nobodyさん :2007/05/31(木) 00:44:23 ID:???.net なんか頭の固い御仁だな 今後苦労しそうだ
609 :nobodyさん :2007/05/31(木) 09:09:45 ID:???.net > 現実にはちがわない? そのあたりは揺らぎがあるからなぁ。 ↓の例のどちらが正しいかは、厳密に規定されていないはず。 例: 濁音・半濁音は清音と同一視し、同一視した際に同じ語になる場合は、清音→濁音→半濁音の順とする。 濁音・半濁音は、清音と別の文字として扱う。順序は、清音→濁音→半濁音の順とする。
610 :nobodyさん :2007/05/31(木) 18:47:08 ID:???.net バージョン 7.4.13です 下記のようなテーブルがあり、name1に姓、name2に名が入っているのですが htmlのテキストフォームから名前を入力してもらい、その値を元に問い合わせをするのに 「カラムの結合」というのは可能でしょうか? Column |Type ---------------- name1 |text ←"姓" name2 |text ←"名" できるとしたらこんな形になると思うのですが… SELECT * from テーブル where name1 結合演算子 name2 = '入力された値'; または何か代替え手段を教えて頂けるとありがたいです。
611 :nobodyさん :2007/06/04(月) 11:16:02 ID:???.net >>610 文字列の結合は、|| を使う。 おそらくこれでいけるとは思うが、7.4は試してない。
612 :nobodyさん :2007/06/04(月) 11:19:09 ID:???.net >>604 >がかあ >かかい >かかう >が自然だと思う。 では、「がかあ」と「かかあ」はどうなる? かかあ がかあ が自然、とか言うなよ?
613 :nobodyさん :2007/06/04(月) 11:22:27 ID:???.net つーか、何日も間が開いてるんだな。 まあ↓ものんびりしてるけど、よかったらこっちへ。 【Windows】 PostgreSQL8 Part.1 【対応】 http://pc11.2ch.net/test/read.cgi/db/1102247223/
614 :nobodyさん :2007/06/04(月) 11:26:40 ID:???.net >>612 >>609 の上の例
615 :nobodyさん :2007/06/05(火) 21:44:04 ID:2VYXdggd.net データの追加が出来ません。 OSはCentOS4.5です。 test=> insert into test values(1,'あいうえお'); ERROR: invalid byte sequence for encoding "EUC_JP": 0x94b0 となってしまいます。解決策をどうか教えて下さい。
616 :nobodyさん :2007/06/06(水) 18:11:32 ID:???.net それだけじゃわからん。0x94b0の出所が不明だな。 とりあえず、ターミナルの文字コードはどーなってんの。 SET client_encording TO SJIS; とか試してみて。
617 :nobodyさん :2007/06/12(火) 21:15:35 ID:8ZZji6XO.net >>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にあったけど http://ml.postgresql.jp/pipermail/pgsql-jp/2004-December/018144.html 原因って何なんですかね?
618 :617 :2007/06/13(水) 00:22:06 ID:???.net >>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 :2007/06/13(水) 02:50:47 ID:???.net さらに追記 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.net 頭を悩ましているのでお願いします。 営業時間を入力しておいて、今営業中か検索できるようにしたいのですが、 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さん :2007/06/17(日) 00:58:26 ID:???.net >>620 開店時間(open_time::time)と営業時間(sales_hours::interval)で WHERE (localtime - open_time) < sales_hours でどうかな。開店後何時間経ってるかで比較する。
622 :620 :2007/06/18(月) 01:48:25 ID:3Ht3k2HG.net >>621 レスありがとうございます。 それだと、0:00を過ぎたときマイナスの値が帰ってきてしまうので WHEREがtrueになってしまうと思うのですが。 timeだと日にちが変わったことが解らないからなのかな? 例えば、CRONを毎日0:00に起動して、営業時間を入れたカラムを見に行って 数日分(あんまりじっくり考えてないけど、その日と翌日分で良いのかな?) の日付入りのテーブルを自動生成して、そこに検索かけるとか・・・ 今が営業しているか、って意外と大変ですね。 開店時間が何時より早いお店とか、閉店時間が何時より遅いお店なら簡単に実装できそう。 それでいいかな・・・ なんか簡単な方法あったら引き続き情報お願いします。
623 :nobodyさん :2007/06/18(月) 03:02:36 ID:???.net >>622 ああスマン、open_timeをinterval型にキャストするの抜けてた。 WHERE ( localtime - open_time::interval ) < sales_hours; 開店時刻をinterval型に変換するのは反則のような気もするが、 これで、開店後の経過時間が出ます。(負の値にはなりません)
624 :nobodyさん :2007/06/18(月) 03:50:30 ID:???.net 店舗ID,開店時間,閉店時間 1, 07:00, 23:59 1, 00:00, 03:00 (朝7時から翌朝3時までの店の場合) みたいに一つの店舗でも営業時間を二行にわけてやればいいじゃね?
625 :622 :2007/06/19(火) 08:04:50 ID:???.net >>623 >>624 超遅レスですが レスありがとうございます >>623 確かに、そうすると負になりませんね。 なぜそうなるのか原理というか理屈が良くわかりませんが^^; 勉強になりました。 それならいけそうです。ありがとうございます。 >>624 なるほど、それでどちらかに入っていればいいと。 それもわりと簡単。 いろりろアイデアがあるモンですな。 ありがとうございました。 よく考えて、ベンチもとって、どちらかの方法でやらせて頂きたいと思います。
626 :nobodyさん :2007/06/19(火) 11:33:30 ID:???.net 正規化するといいよ 24時以降は24足すのさ そして範囲チェックは BETWEEN でやると見やすい
627 :nobodyさん :2007/06/19(火) 18:36:18 ID:???.net でたな正規化厨!
628 :nobodyさん :2007/06/19(火) 19:02:58 ID:???.net テーブルの正規化と意味が違うのに脊髄反射するやつw
629 :nobodyさん :2007/06/20(水) 02:18:52 ID:???.net でたな性器化中!
630 :nobodyさん :2007/06/23(土) 18:35:19 ID:T/euHpQb.net 不可解なことでなやんどります。 複数のデータベースを作成していて、一方でVACUUMを実行したのですが、 どういうわけか、VACUUMをかけたほうだけではなく、かけてないほうで著しくパフォーマスが劣化します。 データベースA <= VACUUM実行 データベースB <= 運用中 で、遅くなっている様子が、IO負荷ではなくCPUをいつも以上に使用しているように見えます。 VACUUMの実行を中断すると通常の状態に戻るので、VACUUMと何らかの関連があると 思うのですが、VACUUMの実行によってVACUUMしていないデータベースの実行プランが 影響受けるなんてことあるんでしょうか? 誰かヒントくださいまし... ちなみに8.1.5でございます。
631 :nobodyさん :2007/06/25(月) 18:32:04 ID:???.net 同じサーバで同じpostmasterでDBが違うだけなの? だったら片方で負荷がかかれば足引っ張られると思うが
632 :630 :2007/06/25(月) 19:07:01 ID:???.net そうなんだけど、IOで引っ張ってるんじゃなくてまるで実行プランが変わったように突然CPU使用率が上がるんだよ。 で、VACUUMをとめても実行プランが変わるまで同じ調子でCPUがんがん使ったまま…。 ANALYZEがかかると収まる。そんな感じ。
633 :nobodyさん :2007/07/25(水) 21:58:43 ID:???.net ムーバブルタイプというブログ作成ツールをインストールする際にポスグレを使っております。 インストールは無事に終わったのですが、 データベースのアップグレードをする際に ERROR: parser: parse error at or near "0" というエラー文言が出てきてしまいます。 通常は"0"の部分に原因となるヒントが出ているものなのですが、 0とだけ出ていても何が原因なのかが全く把握できません。 この0っていうのはどういったケースで発生するものなのでしょうか??
634 :nobodyさん :2007/07/26(木) 01:11:19 ID:???.net >>633 "0" 付近で構文解析エラー ってころだろ。 "0"に特別な意味はなくて、SQL文中に"0"が出現したところあたりが怪しいってことだ。 勝手に想像すると、"SELECT * FROM ${table}0 ;" 見たいなSQLで 変数$tableが空だった為に正しいテーブル名が渡せなかったとか。
635 :nobodyさん :2007/07/26(木) 10:24:17 ID:???.net デバッグ出力時に、sqlも吐いとくとわかりやすい。 DB側のログに出すことも可能ではあるが
636 :nobodyさん :2007/07/26(木) 11:34:31 ID:???.net >>634-635 ありがとうございます。 参考になります。 これからソースとにらめっこ&デバッグして原因を探ってみます!
637 :nobodyさん :2007/07/26(木) 13:13:51 ID:???.net DBを一旦削除したあともう一回作ったら何故かうまく行きました。。 特に何もしてないんのだけど。。 作成にミスるって事もあるのかなぁ。
638 :nobodyさん :2007/09/22(土) 21:58:23 ID:???.net Perlで辞書検索CGIを書きましたが、DBI/DBD::Pgのあまりの遅さに辟易して、Pg使ってます。 各モジュールのパフォーマンスに関する記述ってあまりないようなんですが、皆さんはどちらを使っているのでしょうか。 ちなみに、作成したCGIはSELECT文を1回実行するもので、Dprofでプロファイリングしてみると CGI全体でDBI/DBD::Pgで800ms、Pgで600msかかっていて、いずれも::INITで時間がかかっていました。
639 :nobodyさん :2007/10/09(火) 20:34:44 ID:???.net 1台のPostgreSQLサーバーにデータベースをたくさん作っていたのですが、 これを1つのデータベースにまとめる方法はありませんか?COPYではできませんよね? なお、テーブル名に重複はありません。
640 :nobodyさん :2007/10/23(火) 17:46:23 ID:???.net COPYでできると思うけど。 まあ、 pg_dump DBNAME1 | psql DBNAME2 とか繰り返せばいいんじゃない? って久しぶりに見たからえらい遅レスになっちまった
641 :nobodyさん :2007/12/20(木) 15:45:11 ID:???.net あるテーブルからSELECTする際に「別のテーブルに含まれていない」という条件を「Not IN」とかで 指定できたと思うんですが、この「Not IN」って名前なんて言うでしたっけ? 構文とかが良くわからないからGoogleろうと思ったけどnotとinって一般的過ぎて検索ワードにならないです サブクエリ(副問い合わせ)だったかと思ったけど違ったし…。 http://www.postgresql.jp/document/pg721doc/reference/sql-select.html にはNot IN自体載ってなかった…。 bash-2.05$ psql -V psql (PostgreSQL) 7.1.3
642 :nobodyさん :2007/12/20(木) 16:53:36 ID:???.net >>641 IN述語でググれ。 よく「句」と間違えている人がいるようだが、 INやEXISTSは述語な。
643 :nobodyさん :2007/12/20(木) 17:16:36 ID:???.net >>642 ありがとうございます ただ、「IN 述語」だと9万件以上引っ掛るのに 「IN 述語 postgre」だと30件ちょい…。 とりあえず↓がおもしろそうだから読んでみます!(・∀・) http://www.geocities.jp/mickindex/database/idx_database.html
644 :641 :2007/12/20(木) 17:30:18 ID:???.net >>642 わかったー SELECT カラム from テーブル where カラム IN (SELECT カラム from テーブル2); で生けました。 PostgreのマニュアルってPHPのそれよか充実してないですよね…。 どっかいいサイトあったら教えてください
645 :641 :2007/12/20(木) 17:33:19 ID:???.net 連投ごめんなさい >>2 にあった PostgreSQL7.1マニュアル全文検索 http://osb.sra.co.jp/PostgreSQL/Manual/cgi-bin/namazu.cgi これ、500エラー吐いてるけどタマタマですかね? メンテされないのであればテンプレから外した方がいいのかな、と思いました。 1スレで4年以上もつからしょうがないけどw
646 :nobodyさん :2007/12/20(木) 17:47:31 ID:???.net >>645 みんなDB板 http://pc11.2ch.net/db/ に行ってるんで、 このスレは死に体。
647 :nobodyさん :2007/12/20(木) 17:51:35 ID:???.net >>643 せめて 「IN述語 PostgreSQL」でググれよ。 >>644 それだと 相関クエリをつかったEXISTSの方がいい。 特に7.1.xならなおさらINはなるべく回避してEXISTSを使うべき。
648 :nobodyさん :2008/01/14(月) 16:29:28 ID:VAusV2xL.net >>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さん :2008/01/14(月) 16:33:02 ID:???.net >>648 begin;
650 :648 :2008/01/14(月) 16:41:15 ID:???.net >>649 おぉ。。。ありがとです。
651 :nobodyさん :2008/07/22(火) 05:55:10 ID:fILzfF3O.net Warning: pg_exec(): Query failed: ERROR: UNION types text and integer cannot be matched in 〜 これはどういうエラーでしょうか? ググってもなかなか情報が無くて困っています。
652 :nobodyさん :2008/07/22(火) 17:37:19 ID:YIgoKKKq.net UNION types text and integer cannot be matched という意味です。
653 :nobodyさん :2008/07/22(火) 18:00:25 ID:???.net >>651 個々のSELECT文の取得列のデータ型が 勝手にTEXT型にキャストされてたりするんじゃないか?
654 :nobodyさん :2009/09/15(火) 02:11:46 ID:0k+4XNIC.net やってますか
655 :nobodyさん :2009/09/18(金) 00:01:10 ID:???.net >>651 ググったら上から2つがこのスレのお前の書き込みで3番目が>>653 みたいな答え書いてるblogだったが
656 :MBXzJeqplkasTKO :2009/10/23(金) 00:53:36 ID:???.net Asian newspapers, where it hit a nerve. ,
657 :LMnziRhWhQFGPkU :2009/10/23(金) 05:36:11 ID:???.net Larry Hodges, the computer scientist on the team, thinks that audio quality is, in several of their applications and exper- iments, consistently more important than visual quality. ,
658 :nobodyさん :2010/01/10(日) 23:55:08 ID:XBzggYOw.net PostgreSQLのポータブル版なんてあったんだ。これとXAMPPを組み合わせれば学校でも使える? http://www.portablefreeware.com/forums/viewtopic.php?p=21663
659 :nobodyさん :2010/03/03(水) 21:17:49 ID:???.net てすと
660 :nobodyさん :2010/07/01(木) 08:39:54 ID:94Imy5Qs.net てす
661 :nobodyさん :2010/10/06(水) 08:25:29 ID:???.net 初歩的な質問で申し訳ないのですが・・・ pg_dump_allでバックアップしたデータのリストアって、何もせずただpsqlで普通にdumpデータ流しこむだけじゃだめなんですよね? 今あるデータベースの内容に関係なくリストアする(SQLを流し込む)ために、全(各?)データベースを一度削除したり、 キレイにリストアできるようにリストア前の準備をするのが普通(必須)なんでしょうか? いろんな本やネットを見ても、「dumpしたものをpsqlなりで流し込む」くらいのこといか書いていないような気がして・・・ (実際ただ流しただけでは完全にリストアはされてませんでした。当たり前かもしれないけれど、データベースを全部削除してから流し込んだらうまくいきました) とんでもない変なこと言ってたらすみません・・・
662 :nobodyさん :2010/10/07(木) 17:05:27 ID:???.net これは、、、別のスレにm書いてあるからペンディングでいいのかな?
663 :nobodyさん :2011/04/15(金) 10:44:18.23 ID:dMSlOwf6.net 2箇所にPCを設置して 片方は閲覧専用のPC、 片方でDBへの入力編集を行っています 双方のプログラムは同じプログラムでlibpqでサーバーへ接続している 入力されたデータは、LISTEN,NOTIFYの機能を利用して 全てのPCで情報を受け取り表示している 入力専用のPCであっても登録後の表示はNOTIFYで返って来た情報で 表示を行うようにしてあります、つまり、表示のみのPCと条件は全く同じ しかし、時間が経つ(数時間?)と 表示のみでPCに触らない側ではLISTENを受け付けなくなり情報が獲られなく なってしまいます、自動で定期的にLISTENをしてやるとまた受け取れる ようになるようなのですが LISTENにタイムアウトの設定等があるのでしょうか? ご存じの方がおられれば教えてください
664 :nobodyさん :2011/04/23(土) 01:17:48.72 ID:???.net ルータ越しで接続してるなら、NATテーブルのエントリが無通信時間 タイムアウトで消されて、TCPコネクションが切れているのかも
665 :nobodyさん :2011/09/29(木) 14:38:34.43 ID:???.net ユーザーIDをserial型で登録していくテーブルがあり、 新規登録したユーザーのIDを即時取得するために、登録日時をtimestampで記録し、 SELECT user_id FROM user_table WHERE join_date = '登録日時'; のようにしているのですが、もっとスマートに登録したばかりのユーザーIDをそのまま取得する機能や方法はありますか?
666 :nobodyさん :2011/10/09(日) 18:43:35.76 ID:???.net 昔、INSERTで帰ってきたidで検索しなおしたり 先にnextvalしてそのid使ったりしてたけど 今のバージョンならinsert文 にreturning入れればいけると思う もちろんexecじゃ結果わからんからqueryで
667 :665 :2011/10/09(日) 22:58:50.86 ID:???.net >>666 ありがとうございます。クエリの最後にRETURNING ユーザーID と書くだけで、ユーザーIDを取得できるようになりました。 これで、登録日時をtimestamp型からdate型にすることができます。 もっている2冊の本にはRETURNING句の記述がなかったので 本当に助かりました!
668 :nobodyさん :2012/03/28(水) 18:36:07.74 ID:???.net 2千万レコードぐらいのテーブルにDROP INDEXしたら 2時間以上ロックされちゃってるんだけどこういうもんなの?
669 :nobodyさん :2012/05/15(火) 05:16:17.74 ID:???.net まだロックされてるのかな… 他にトランザクションが無ければdrop indexなんてすぐに終わる代物 つまり他のトランザクションに阻害されてるだけ
670 :nobodyさん :2012/08/09(木) 10:28:33.00 ID:???.net FreeBSD 9.0-RELEASEのportsに # cd /usr/ports/databases/ruby-postgres が無く、検索しても見つからないのですが どこにいったのでしょうか? 代替はありますか?
671 :nobodyさん :2014/07/28(月) 19:52:59.23 ID:???.net http://kanae.2ch.net/test/read.cgi/php/1405860979/ ここで、 A END OF PHP IS A END OF PHPER って書いたら中学生程度の頭で喜んでるぺちぱーがANじゃないことに突っ込むかな ぺちぱーは馬鹿だから嬉しそうに突っ込みそうだけど、馬鹿すぎて気付かない可能性もある れっつとらい
672 :nobodyさん :2014/07/29(火) 04:55:07.25 ID:???.net なんだこりゃ。 よく分からんが先を見るとtheじゃないの?って突っ込まれてるけど
673 :nobodyさん :2014/08/22(金) 05:19:59.80 ID:???.net http://jobinjapan.jp/job-listing/keyword-postgresql.html
674 :nobodyさん :2016/01/30(土) 18:24:23.38 ID:???.net Ver9.5出たみたいだね。
675 :nobodyさん :2017/10/19(木) 21:26:42.50 ID:???.net なんだこの過疎っぷり 近年ボラクルがあまりにも横暴なのでBIとか参照系ではそこそこ使われだしたとかも聞くんだけど
676 :nobodyさん :2017/10/20(金) 11:41:30.63 ID:???.net そりゃここ本スレじゃないもん DB板行け
677 :nobodyさん :2017/12/30(土) 13:03:59.10 ID:YhlYw6jg.net 誰でも簡単にネットで稼げる方法など 参考までに、 ⇒ 『半藤のブブイウイウレレ』 というサイトで見ることができます。 グーグル検索⇒『半藤のブブイウイウレレ』 HB5QS9PT42
678 :nobodyさん :2018/02/20(火) 04:34:17.92 ID:???.net ☆ 日本の、改憲を行いましょう。現在、衆議員と参議院の 両院で、改憲議員が3分の2を超えております。 『憲法改正国民投票法』、でググってみてください。国会の発議は すでに可能です。平和は勝ち取るものです。お願い致します。☆☆
679 :nobodyさん :2019/07/19(金) 00:26:00.17 ID:???.net windowsなのですが、まずサンプルのdvdrentalを入れるやり方からわかりません 検索して出てきたやつらを見ても訳がわからないです
680 :nobodyさん :2023/10/15(日) 01:57:53.72 ID:QosfE9dJG 人間の尊厳カ゛‐だのと心にもないことをぬけぬけとぬかしていやがる岸田異次元増税憲法ガン無視地球破壊覇権主義文雄や 世界最悪の殺人テ口組織公明党強盜殺人の首魁蓄財3億円超の斉藤鉄夫は暴カを続け多くの人に苦しみを与え人間の尊厳を踏みにし゛れは゛ 住民は妥協し知的能カ者も抗議をやめると見込んでいる、しかし知的能カ者もわれわれも諦めない 世界最悪の脱炭素拒否テ口國家に送られる化石賞連続受賞して世界中から非難されなか゛ら憲法13条25条29条と公然と無視してカによる−方的な 現状変更によってクソ航空機倍増,閑静な住宅地から都心まて゛数珠つなぎで鉄道の30倍以上もの莫大な温室効果カ゛スまき散らして騒音まみれ 気侯変動させて海水温上昇させてかつてない量の水蒸氣發生させて土砂崩れ,洪水,暴風,熱中症にと災害連発させて住民の生活破壞して 静音か゛生命線の知的産業を壞滅させるなと゛のクソ航空機による惨劇を止めねばならない,侵略者を打ち負かすため団結するべきだ 氣侯変動騒音犯罪は処罰され生活を破壞された人たちは賠償され侵略者は皆殺しにされるべきだと訴え正義を実現するための行動を起こそう! (羽田)ttps://www.call4.jp/info.php?type=items&id=I0000062 , ttps://haneda-project.jimdofree.com/ (成田)ttps://n-souonhigaisosyoudan.amebaownd.com/ (テ□組織)ttps://i.imgur.com/hnli1ga.jpeg
204 KB
新着レスの表示
掲示板に戻る
全部
前100
次100
最新50
read.cgi ver 2014.07.20.01.SC 2014/07/20 D ★
本文 スレッドタイトル 投稿者