03/03/21 22:44
他人へのもののたずねかたを知らないのはらたつ。
「2ちゃんだから」って理由での態度ならなおさら。
そういう人は何やらせてもダメそう。
せっかく>>33のスクリプト見せてもらってるのに
それに4日前のバックアップを削除する機能すら付け加えられない無能くん。
せいぜいlogrotateくらいはまともにつかえるようにがんがってね。ハート
40:あぼーん
あぼーん
あぼーん
41:nobodyさん
03/03/22 00:09
>>39
職場か戦場でいやなことでもありましたか?
空爆されたとか。
42:nobodyさん
03/03/22 00:34
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
print $sql; とすると
SELECT * FROM board WHERE '2ch' になるのだが、
これは希望通りのSQL?
44:nobodyさん
03/03/22 00:51
まちがえてました$が抜けてました^^;
$result = pg_query($sql) ;
続きがあって
if ($result) {
print ("2chは見つかりました。");
if (!$result) {
print ("2chはみつかりました。);
というわけで、テーブルの中に"2ch"という文字が
あるか無いかをしりたいんですけど。
45:nobodyさん
03/03/22 00:52
すまそ
print ("2chはみつかりました。");
です
46:nobodyさん
03/03/22 00:55
>>41
あとMLで他人の署名まで全文引用するのもキライです。
いやなことありまくりです。そっとしといてください。
>>42
まともなsql文すら書けない人は行ってよし。
47:nobodyさん
03/03/22 01:01
まともなsql文が書けたらし質問しない罠
48:nobodyさん
03/03/22 01:08
>>47
何気に問題箇所は「sql文」だと>>46は切り分けてるからなあ
49:nobodyさん
03/03/22 01:23 lQb2nQAC
>>42はboardというテーブルの
何て列に入ってるのかということに
実は気付いていないという罠(w
50:nobodyさん
03/03/22 01:37
結局みんななんだかんだ言って暗に教えてあげてるからやさすぃねw
51:nobodyさん
03/03/23 00:43
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 T5828xOT
>>51
バージョンはどうなってる?
53:51
03/03/23 02:27
>>52
7.3.2です。
54:名無しさん@Emacs
03/03/23 03:47
7.2.3だと出ないなぁ。
55:nobodyさん
03/03/23 19:17
>>51
それって odbc 経由で Windows からつないでる?
psql からやっても同じエラーでるの?
56:nobodyさん
03/03/24 15:05 Z0MnyWwn
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
>>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
>>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
結合順序コントロールするにはサブクエリにするしかないかも。
select 名前
,replace(join_str(好物),' ','@') as 好物
from (select * from 好物 order by 好物) as k
group by 名前;
既に全然スマートじゃないという罠。
60:nobodyさん
03/03/25 22:02
>>59
すごいでつね。正規化したのはいいけれど、動的配列を繋げて一行で取り出すのって一苦労。
集約関数は奥が深い深い。勉強になります。
うちはまだ、好物1,好物2, ...., 好物25 をくっつけてますよ。
61:56
03/03/26 11:32
>>57-59
なるほどー。すごく勉強になりました。ありがとう。
ちなみに、7.2.1 では replace() が使えませんでした。
7.3.2 では使えました。
同じマシンに異なるバージョンの Postgres をインストールするのって、
簡単にできるんですねえ。
62:nobodyさん
03/03/27 17:09
> 火災と申します
プロジェクトに「火がついた」か。
63:nobodyさん
03/03/27 17:12
>>62
はやっ! (w
64:nobodyさん
03/03/28 01:24
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
>>64
# SELECT (CURRENT_DATE - '2001-12-01'::DATE);
?column?
----------
482
どうも返り値がinteger型のようだ。
66:64
03/03/28 13:45
>>65
integer型のようですね(´Д`;)
結局
# select CURRENT_DATE - '2 month'::INTERVAL >= '2001-12-01'::DATE;
?column?
----------
t
(1 row)
としたら動きました。うーむ謎~。
#よくわかってないだけかも。
67:nobodyさん
03/03/28 17:21
データの作成って、みなさんはどんな方法を採ってます?
MicrosoftのAccess で入力フォームを作って、それをテキストにexport、
文字コード等を適当なものに変換、最後にcopy コマンドでpostgres に
持ってくる、という煩雑なことをしているのですが、もうちょっとなんとか
ならないのかな??と悩んでまして。。。
68:nobodyさん
03/03/28 19:11
>>66
DATE型 - TIMESTAMP型 = INTERVAL型 で
DATE型 - DATE型 = INTEGER型 なんだよな。
仕様なのかバグなのかMLで聞いてみれば。
いc氏あたりが答えてくれるかも。
69:nobodyさん
03/03/29 02:18
>>67
なんか省略してないか。
とりあえずAccess使うならODBCでPostgreSQKに接続すればいいだけだが。
70:nobodyさん
03/03/30 15:36 /7/BL2Cw
[pgsql-jp: 29501] DELETEコマンドの使い方について。
釣り日和でつ。
,
,/ヽ
,/ ヽ
∧_∧ ,/ ヽ
( ´∀`),/ ヽ
( つつ@ ヽ
__ | | | ヽ
|―| (__)_) ヽ
 ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄| ヽ
/⌒\/⌒\/⌒\/⌒\|彡~゚ ゜~ ~。゜ ~ ~ ~ ~~ ~ ~~ ~ ~~ ~~ ~~
⌒\/⌒\/⌒\/⌒\/⌒\彡 ~ ~~ ~~ ~~ ~ ~
71:nobodyさん
03/03/30 15:50 dniM4gxK
PostgreSQLをWindowsでcygwinを介さないで使うことはできませんか?
72:nobodyさん
03/03/30 16:41
>>71
PowerGres (PostgreSQL on Windows)
~オープンソースデータベースのスタンダード "PostgreSQL" を Windows で~
URLリンク(osb.sra.co.jp)
73:71
03/03/30 17:29
>>72
へぇ~できるんですね。ありがとうございます。
欲を言えば、PostgreSQLの開発元がなんとかして欲しいものです。
74:nobodyさん
03/03/30 17:48
>>72
有償なのはいいとしても、ソース公開じゃないから、単なる
「Windowsで動作するPostgreSQL互換RDBMS」にしか
過ぎなくなっちゃったんだよね。
石井さんはPostgreSQLがオープンソースであるメリットを
熱く語っていたけど...。
75:nobodyさん
03/03/30 18:27
>>74
商売としてはしかたないと思うんだけど、SRAはPostgreSQLがWindowsで動く道を閉ざしてしまった気がする。
76:nobodyさん
03/03/30 23:07
>>74
BSD ライセンスのオープンソースだからこそ、
こういった派生品でのビジネスもできる。
そして、オープンソースは、関わる人間の多さが成功の要。
たとえ派生品でも、ベースとなる製品についての知識を有する人が
一人でも増えるのは喜ばしいことだよ。
増えたうちの一人がほんの少しでも本家にコミットしてくれるなら、
最終的に本家の利益にもつながる。
>>75
メールの本文はほとんど読まずに、Subject しか読んでないから全然詳しくないんだけど、
本家の postgres-hackers ML では MS Windows 版の話とか出てるよね。
7.4 でネイティブサポートするとか書いてあったような。
77:nobodyさん
03/03/30 23:24
>>76
URLリンク(hp.vector.co.jp)
URLリンク(hp.vector.co.jp)
本家はプロセスモデルでPowerGresはスレッドモデルってことでいいかな。
78:nobodyさん
03/03/31 07:13
>>76
SRAはPowerGresを本家にフィードバックするんだろうかね?
79:nobodyさん
03/03/31 13:53
現場は、フィードバックすると言っているがね。
ただ、(WindowsのスレッドモデルをUNIXに持ってくることに)
どの程度意味があるかは分からん。
S○Aも、UNIXでいくならUNIX一本でもっと機能拡張とかすればいいのに。
中途半端にUNIXもWindowsも手を染めてどうすんだか。
80:質問です。
03/04/01 17:16 0gCa7Sb2
ポスグレって
Windows版 ってないのですか?
81:nobodyさん
03/04/01 17:19
,
,/ヽ
,/ ヽ
∧_∧ ,/ ヽ
( ´∀`),/ ヽ
( つつ@ ヽ
__ | | | ヽ
|―| (__)_) ヽ
 ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄| ヽ
/⌒\/⌒\/⌒\/⌒\|彡~゚ ゜~ ~。゜ ~ ~ ~ ~~ ~ ~~ ~ ~~ ~~ ~~
⌒\/⌒\/⌒\/⌒\/⌒\彡 ~ ~~ ~~ ~~ ~ ~
82:nobodyさん
03/04/02 01:19
[pgsql-jp: 29545] 削除依頼
祭りか徹底無視か?
83:nobodyさん
03/04/02 01:37
あら、意外とすんなり収束したね。
84:nobodyさん
03/04/02 17:32
>>83
時間が時間だけに。
オマケはついたが。
85:nobodyさん
03/04/04 06:06 PaLgsWqP
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
うーんなんでだろ。
select * from pg_convertion (だったかな)
とかはヨサゲ?
87:nobodyさん
03/04/05 05:05
insert や delete に Left join を使うとエラーがでるのですが、
ポスグレではselect文だけにしか使えないのでしょうか?
だとしたら2つのテーブルを比較して足りないモノだけを
1方のテーブルに追加していく、なんてことはできないのでしょうか?
やれるとしたらどんな手段があるか、参考になるサイトがあれば教えてください。
88:nobodyさん
03/04/06 17:10 iXfPNuQP
既存のディスクが一杯になってきたので、ディスクを追加して、
今後は「今までのディスク+追加したディスク」を使いたいのだが可能なの?
やっぱり、一つのデータベースが複数のディスクにまたがるのは無理なのかなぁ
89:nobodyさん
03/04/06 18:13
>>87
普通にできましたが。
バージョンは?
どんなsqlでエラーになったの?
どんなエラーが出たの?
オレは釣られたの?
90:nobodyさん
03/04/06 22:20
>>89
メール欄
91:nobodyさん
03/04/07 00:49
cygwinでPostgreSQL動かしてJavaのJDBC+ODBCでアクセス
してみたら、読み込みはうまくいったけど書き込みは
文字化けしてテーブルに書き込まれてしまった。
文字コード調べてみたらSJIS->EUC-JPのような変換が
行われ、そのEUC-JPのコードをSJISで見たときの文字化け
のままテーブルに書かれてしまった感じ。
解決策があったら教えてください。
92:91
03/04/08 00:41
自己解決。
jdbc:postgresql:test?charSet=SJIS
デコードの指定を付けたらすべてうまくいきました。
93:nobodyさん
03/04/09 03:20 Ub7v47GH
ところで、PowerGres、どうよ?
PostgreSQLでできること、全部できる?
94:あぼーん
あぼーん
あぼーん
95:nobodyさん
03/04/09 06:30
>93
誰も買ってない悪寒。だから言ったのに・・・。
96:nobodyさん
03/04/09 19:01 xm6OICY+
>93
Ver7.4のWindowsネイティブ対応っぷり次第だな。
それまで待てれば待ったほうがいい。
97:nobodyさん
03/04/10 11:21
ひょっとしてPostgreSQLのパターンマッチングって同じ文字の連続(aaa、あああ など)って検出できない?
98:nobodyさん
03/04/10 11:50
>>97
はぁ?
おまえができないだけでしょ。
99:nobodyさん
03/04/10 12:29
w)
100:nobodyさん
03/04/10 15:51
>>98
うそだ!
select * from table where string ~ '(.)\1\1';
とかできなかったぞ!できるというなら例を見せてみれ!
101:nobodyさん
03/04/10 18:42 Gvrywi5t
特定のフィールドを指定してセレクトするのではなく、
逆に、「あるフィールド以外すべてセレクト」というふうなクエリーはかけないのでしょうか?
102:nobodyさん
03/04/10 20:08
>>100
where string ~ 'a{3}';
103:102
03/04/10 20:27
ん? 勘違いしてた。
104:nobodyさん
03/04/10 22:07
>>103
だよね。できないよね?
105:nobodyさん
03/04/10 22:22
>>101
WHERE foo <> 'ある条件';
106:nobodyさん
03/04/11 01:37
>>101
105は間違い。
SELECT ~hogehoge WHERE ...
チルダをつければいい
107:nobodyさん
03/04/11 01:46 nN51pMH3
>106
そっか!ありがと。試してみます。
108:nobodyさん
03/04/12 16:38
>>106おいおい(w
109:nobodyさん
03/04/12 19:46 UOkuI+UD
気づくの遅すぎ(藁
110:nobodyさん
03/04/13 15:52
>>107騙されるな
SELECT ^hogehoge
だぞ
111:nobodyさん
03/04/13 20:29
>>107
昔は
SELECT !hogehoge
と書いたもんだ
112:nobodyさん
03/04/15 14:02
>>111 あんたかなりのベテランだな
一部のDBでは
SELECT `hogehoge
だったころもあるね
113:nobodyさん
03/04/16 13:29 sI0EuNRH
つーか
SELECTしたい列名なんて明示的に書くのが王道だろ
それとも
テーブル設計をコロコロ変えやがるのかと小一時間...
114:山崎渉
03/04/17 12:01
(^^)
115:33
03/04/17 13:09
>>35
n 日前のバックアップファイルを削除する、という機能が欲しくなったので付けてみた。
find と xargs コマンドが必要。
find ${BACKUPDIR} -type f -daystart -mtime +${EXPIRE_DAY} |xargs /bin/rm -f
全文は長いので >>116 に張ります。必要ないって? そんなこと言わないで・・・。
116:33
03/04/17 13:09
#/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
∧_∧
( ^^ )< ぬるぽ(^^)
118:nobodyさん
03/04/23 02:29 b3QZu4Pm
PostgreSQL のデータベースを UTF8 で作ったとき、日本語の入ったカラムに
ORDER BY かけると JIS 漢字順ではなくなるのかな?
119:nobodyさん
03/04/23 23:03
linさんのコメントにどんな意図があるかは知らないけど
サイトのJavaScriptでしばらく楽しんでしまった。。。
120:あぼーん
あぼーん
あぼーん
121:nobodyさん
03/04/24 19:29 Q1w3nY2w
質問です。
複数のカラムを対象に、selectしたいのですが、どう書けばよろしいでしょうか?
mysqlだとFull Text Searchとあると思うのですが、Postgresでできますでしょうか?
122:nobodyさん
03/04/25 11:28
管理ツールDbVisualizerってどうよ?
URLリンク(www.minq.se)
Javaアプリだけど、個人的には好感触。
123:nobodyさん
03/04/25 12:18
>>122
psqlで十分。
エディタもviでいい。
巡回ダウソもwgetでいい。
なんてなぁ、新しいのを覚えられないだけ。
CSE入れてみたけど起動してみて、
さ ぁ ど う し た も の か と 小 一 時 間 ...
124:nobodyさん
03/04/27 05:21
>>121
意味わかんね。
select * from table
ってやれば複数のカラム対象にselectできてるし。
125:nobodyさん
03/04/27 12:54
>>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 RGglVdIs
psqlからのcopyコマンドで"\N"という文字列がテーブルに入れれない・・・(WITH NULL AS指定はなしで )
"\b"、"\n"、"\."は
"\\b"、"\\n"、"\\."に変換すれば入るのに・・・
"\N"は"\\N"に変換してもだめ・・・
"\N"という文字列はだめなんでしょうか?
127:nobodyさん
03/04/27 21:51 ClMbC1OP
>>121
第一正規化、って知っていますか?
128:121
03/04/27 21:52 u/4ug4s4
>> 124
失礼しました。whereで複数カラムを指定するという意味です。
>> 125
全文検索というと、確かにNamazuとかそういう方向いっちゃいますね。
単純に複数カラムを検索条件にかけたいだけです。
where andでつなぐと遅くなるので、(レコード数が230万件あるので)
mysqlのFull Text Searchつかったらと先方にいわれ、いまさら乗り換える
のはややこしいので、Postgresでもそういう機能がないかと探しておりま
した。
設計ミスか余計な機能ではとありますが、検索対象の列が5つあって、
最初はそれぞれにかければいいという仕様でしたが、5つのどれかに
ヒットするようにしなさいと仕様が変更されたのです。
他に方法あるでしょうか? って自分で考えろという感じですが、
いろいろと調べてはいるのですが、思いつきません。。
129:nobodyさん
03/04/27 22:21
>>128
ふつうにorすればいいのでは。。。
130:121
03/04/27 22:41 u/4ug4s4
> 129
すいません、where andではなく、where or で、遅くなるという意味です。
131:nobodyさん
03/04/27 23:03
>>128
>設計ミスか余計な機能ではとありますが、検索対象の列が5つあって、
>最初はそれぞれにかければいいという仕様でしたが、5つのどれかに
>ヒットするようにしなさいと仕様が変更されたのです。
そんなの、仕様変更されるのが当たり前だな。
仕様変更に対応できるようにしてなかった設計ミス。
ところで、230万件×5の全文検索ってMySQLなら速くできるのかな?
132:nobodyさん
03/04/27 23:07
>>130
検索対象のカラムにindexは張ってあるの?
133:122
03/04/27 23:32
>>123
psqlで充分ってか。ある意味うらやますぃ。
個人的には使っていこうと考えているけど、確かにpsqlで充分かもね。
134:nobodyさん
03/04/28 01:11
>>132
index張ってあっても、like '%語句%'で検索するなら意味ないと思われ。
135:132
03/04/28 02:16
>>134
あー、likeで%から始まる奴は駄目だね。
ホントに全文検索っぽくやってるとしたら、like '%語句%'ってやってる
可能性は高いか。
121にもうちょっと情報を出してホスィところだなぁ。
136:nobodyさん
03/04/28 11:27
where coalesce(列1,'') || coalesce(列2,'') || coalesce(列3,'') like '%検索ワード%'explain してみたら、costは同じだけどrowsは or より少ないよ
137:121
03/04/28 13:42 carn+S7w
>> 134,135
ご指摘の通り、like '%語句%'とやっております。
実は今からでもテーブルの設計は変更可能なのですが、
どのように変更したらよろしいでしょうか。
今はID,NAME,AA,BB,CC,DD,EEというカラム構成で、
AA,BB,CC,DD,EEの中で、どれかに検索キーワードがあればヒットする
というようにしたいです。
>> 136
こちらありがとうございます。
coalesceってこういう時に使うのですね。習ってはいたのですが、
いつ使うんだろと思っていました。勉強になります。
138:nobodyさん
03/04/28 15:37
>>121
>>127
139:nobodyさん
03/04/29 11:45
textの部分一致は、例えば「abcdefg」という文字列があったとして、
like '%cd%' とすると遅くなるから、
abcdefg
bcdefg
cdefg
defg
efg
fg
g
というテーブルを別に作って、like 'cd%' すると速くなるよ、と
言われたことがある。もちろん、インデックス作って。
実際自分でやってみたことはないが。
140:121
03/04/29 18:01 JKdqeuMi
>> 127
正規化については、こちらを読みました。
URLリンク(www.rfs.jp)
今回のケースとは特に関係ないかと思うのですが、私の洞察力不足でしょうか。
>> 139
ありがとうございます。
そこまでやると複雑になるので、おとなしくMySQLに移行するかと思って
しまいます。。
141:nobodyさん
03/04/29 19:13 8zWvKIjl
URLリンク(my.vector.co.jp)
142:あぼーん
あぼーん
あぼーん
143:しろ
03/04/30 09:50
>140
> 正規化については、こちらを読みました。
> URLリンク(www.rfs.jp)
> 今回のケースとは特に関係ないかと思うのですが、私の洞察力不足でしょうか。
今回のケースと関係あるかないかどうかは「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
正規化汁!と言ったひとの早とちりでしょう。
145:121
03/04/30 22:31 0656yZRu
>> 143
NAME,AA,BB,CC・・・は、担当者、商品名A、商品名B、商品名C・・・という
構造です。特にカラムが一緒ではないので、正規化は関係ないかと思うのですが、、、
ちがいます?
146:nobodyさん
03/04/30 22:44
>>145
それって、担当者「NAME」が最近扱った商品A、B、C、Dとか…?
そういうパターンだったら正規化の対象だと思ふ。
147:146
03/04/30 23:01
(担当者テーブル: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
最近の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
PostgreSQLってテーブル名とかフィールド名が大文字英数だと、
SQL書くときテーブル名, フィールド名をダブルクォーテーションで
くくらないといけないんだな。
なんでこんな仕様になってんだ?
150:nobodyさん
03/05/02 09:43
>>149
それは予約語とかぶった時の話では?
151:nobodyさん
03/05/02 20:04
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 ixQKgJiY
>>151
intersect
153:nobodyさん
03/05/02 20:57
>>151
上は「両方ともhogeじゃない」
下は「TBL1のIDがhogeもしくはTBL2のIDがhoge」
154:nobodyさん
03/05/02 21:05
SELECT 1
FROM TBL1, TBL2
WHERE TBL1.ID = TBL2.ID
AND TBL1.ID = 'hoge';
155:402
03/05/03 00:55
>>149
大文字の混ざった識別子をダブルクォートするのは
PostgreSQLの仕様というよりSQL92の仕様のはずです。
156:nobodyさん
03/05/04 18:28
ここで聞くのが適当かどうかわかりませんが、まったく同じ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 V6Q641Ow
>>156
何か見るからに変なSQL書いてるな。
具体的に何がどう違う結果になってるのか書け。
あと全部Perlで試しているのか?それともpsqlか?
158:nobodyさん
03/05/05 00:40
>>157
コンソールからはPerlで書いたスクリプトで、存在しているIDをときはきちんと
1を返します。
psql(コマンドインタプリタ)からでも同じSQLだと同じ1を返します。
ただ、Web上からPerlで書いたCGIに同じSQLを実行させた結果、0を
返します。因みにDBIとDBD-Pgを使って永続接続させています。
159:nobodyさん
03/05/06 16:42
>>158文を SELECT 1 WHERE true; みたく単純にしてみて、同じコトをやってみたら?
160:nobodyさん
03/05/10 12:46
>>158
PostgreSQLに接続するユーザーの問題では?
ユーザーを明示的に指定してやったらどうよ?
161:nobodyさん
03/05/13 09:51 77a0e79m
プログラミングではなく、運用の質問なんですが、
Postgresの監視って、プロセス上がってるかどうか
程度でいいですかねぇ?
162:nobodyさん
03/05/13 11:44
>>161
・プロセスあがってるかどうか監視
・最大プロセス超えてないかどうか監視
・クエリーの応答時間が甚だしく増えていないかどうか監視
くらいじゃねーの?
ディスク容量とかも必要かも試練が
こっちは鯖の監視の範疇に入るかな
163:nobodyさん
03/05/13 11:47 sZdPhQWk
>>161
接続できるかどうかぐらいはテストしたら?
164:161
03/05/13 17:15 77a0e79m
>>162
サンクスです。
>>163
シェルで一発で済ましてしまいたんですよ。
ベンダにやってもらうので
そこまでやってもらうと
お金の問題が出てきそうなんですよね。
mysqladmin pingみたいのがあれば
と思ったんですが・・・・・・。
ありがとうでした。
165:nobodyさん
03/05/14 05:36 aknt5UHd
原因がまったく解明しないため、質問させていただきます。
今までどおり、
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
>>165
この情報からだとスペルミスか、何らかの理由で定数のimportが
できなかったのかというくらいしか思いつかんが。
原因はわからんが、そういうミスを事前にチェックできるよう、use strict; を
使うのが常識。あと、PGRES_TUPLES_OKは整数なので、比較は ne じゃ
なくて != でよい。
167:165
03/05/14 21:34 aknt5UHd
原因が判明しました。しかし、その意味がどうしてもわかりません。
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
またもや自己解決。。。ようやくわかりました。
Pg::PGRES_TUPLES_OK
これだけです。これで解決しました。
いろいろと失礼致しました。
169:nobodyさん
03/05/18 19:21 EvuGQeIP
「40万件有るデー」って、いなかのスーパーの安売りみたいですね。
170:nobodyさん
03/05/18 20:08
>>169
漏れは関西弁かとおもたYO!!!
171:nobodyさん
03/05/18 20:08
しょーもないカキコでageるなコラ。
172:nobodyさん
03/05/18 21:06 5+xOckh5
PostgreSQLはなんでshift-jisのエンコーディングをサポートしてくれないの?
173:あぼーん
あぼーん
あぼーん
174:あぼーん
あぼーん
あぼーん
175:あぼーん
あぼーん
あぼーん
176:あぼーん
あぼーん
あぼーん
177:nobodyさん
03/05/19 20:20
UNIX積算秒を timestamp型にUPDATE文でセットするにはどのような方法があるのでしょうか?
マニュアルの date_trunc() や timestamp() 関数を見てもそれらしいのが見あたら
なくてなやんでいます。
178:nobodyさん
03/05/20 20:28 tVu/NkZD
すんまそん、
緊急の為、過去ログ見ないで聞きます
文字コードを設定する方法を教えてくだつぁい
困りはてました・・・
環境はapache(Linux)+PostgreSQL+PHP
もう日本語めひゃくひゃ・・・
179:nobodyさん
03/05/20 22:01 7LQQ/2dr
PostgreSQL 7.3.2 付属ドキュメント
URLリンク(www.postgresql.jp)
180:nobodyさん
03/05/20 22:13
緊急で
文字コードを設定する方法を教えてくだつぁい
って疑問にぶち当たるシチュエーションってのが想像つかん。
181:nobodyさん
03/05/20 22:43 mI4NkyBO
Serialを指定したテーブルからNextValの値を取得したいと
思っています。
Javaで行う場合に、
REsultSet rs = executeQuery("select nextval('zzz_id_seq')");
としているのですが、これからどのように取得すればいいのでしょうか?
それとも、根本的に取得の方法が間違っていますか?
182:nobodyさん
03/05/20 23:42
>>178
名前の欄に
fushianasan
と書けばOKです!!!
183:山崎渉
03/05/22 01:59
━―━―━―━―━―━―━―━―━[JR山崎駅(^^)]━―━―━―━―━―━―━―━―━―
184:nobodyさん
03/05/22 10:32 JcOANcCI
オマイら
dbの容量計算の仕方教えて下さい。
185:nobodyさん
03/05/22 14:27
>>184
select count(*) from hogehoge;
186:nobodyさん
03/05/24 20:17 aDXBSjIE
ポスグレ!
187:nobodyさん
03/05/24 23:21
( ゚-゚)b
188:nobodyさん
03/05/24 23:26
略すなYO!!!
189:nobodyさん
03/05/27 10:31 oAIrGLTh
select count(*) from hogehoge;
って件数じゃん
190:あぼーん
あぼーん
あぼーん
191:nobodyさん
03/05/27 13:02 ehUv/K+8
で、hogehogeってなに?
192:あぼーん
あぼーん
あぼーん
193:nobodyさん
03/05/27 13:44
(´-`).。oO(いつもながらツッコミが遅いです・・・)
194:
03/05/27 15:44
(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 dZ0fIA92
次のようなテーブルがあるとして、思ったような
操作ができずに困っています。どなたかよい方法を
ご存知の片がおられましたら、教えてください。よろしくお願いします。
下のようなテーブルがあったとします。
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 dZ0fIA92
つまり上の例から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
>>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
今197がいいこと言った!!!
199:nobodyさん
03/05/28 12:30 37obhOpS
>>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:あぼーん
あぼーん
あぼーん
201:あぼーん
あぼーん
あぼーん
202:nobodyさん
03/05/28 13:41
単発で質問スレを立てないように。終了。
203:195
03/05/28 20:14 8u4ScsfX
>>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 l3/TekvE
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.
URLリンク(www.t.ring.gr.jp)
205:nobodyさん
03/05/29 17:54
squid で proxy 作って、WEB 見るときはそれを使うようにした。
そしたら、日本 PostgreSQL ユーザー会のページ(postgresql.jp)が見れなくなった。
他のページは見れるし、proxy 外したらユーザー会のページもOKなのに。
なんでだろう。
・・・スレ違いだね。ごめん。
206:あぼーん
あぼーん
あぼーん
207:あぼーん
あぼーん
あぼーん
208:nobodyさん
03/05/31 23:38 NfBpY+67
Release rush ですね
>>204
postgresql 7.3.3
php 4.3.2
...Mozilla 1.4 RC1
209:nobodyさん
03/06/03 11:27 LFu6QbCl
こんにちは。
decimal型で、&演算子を用いて演算する方法は無いでしょうか?
1ビットごとに意味を持たせておいて、&でマスクをかけて検索している
のですが、int8の64ビットだと、64種類までなので、
それては不足しています。
そこで、decimal型でやりたいのですが、int型しか&を使えない
というエラーが出てしまいます。intにcastしても、その時点で
int8の最大値を超えているとエラーが出てしまうので、
困っています。
よい解決方法がありましたら、ご教授ください。
210:nobodyさん
03/06/03 14:50
bit型を使うわけにはいけない?
もしくはバイナリをつっこむとか。
文字列で表現する方法もあるし。
そもそもdecimalのデータ格納効率はintなどと比べて悪いんじゃない?
211:209
03/06/03 16:24 LFu6QbCl
そうだったんですか・・・ありがとうございます。
indexをはりたかったので、decimalでしました。
いろいろやった結果、
floor ( decimalカラム / 探したい数値 ) % 2 = 1
という式でなりました。お世話になりました(^^
格納効率も、次回から考慮してみますね
212:あぼーん
あぼーん
あぼーん
213:nobodyさん
03/06/04 14:29 7jLojF8m
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:あぼーん
あぼーん
あぼーん
215:nobodyさん
03/06/04 14:45 ulcLr4fi
でいつWindows版は出るわけ?
216:nobodyさん
03/06/04 18:24
>>215
URLリンク(osb.sra.co.jp)
217:nobodyさん
03/06/04 22:45
7.4はWindowsでもビルドできるって?
218:213
03/06/05 00:19 tKeK+oMF
213です。すんません、どなたか>>213の解決策、ご存じの方いらっしゃいませんか…まじ困ってます(;´Д`)
Google探しまくってますが有効策みあたりません。。
おながいします"_m(_'_)m_"
219:nobodyさん
03/06/05 00:52 eid+uK9F
こんばんは。
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
>>219
やってみたら出来た。試す前に投稿した自分を許して下さい。。
221:nobodyさん
03/06/05 02:28
>>213
カタログ情報が壊れているのかな
なんか相当ヘンなことしなかった?
>バックアップはとっていません。。
日時のダンプくらい取れYO・・・
>(つか、意外にひ弱なPostgreSQL?)
他人のせいにして・・・
もうダメぽ・・・
データファイルから本体のデータを復旧するツールってないのかな?
もしなくても
デキる香具師なら
ソース読んで2,3日で作れそうだが
222:213
03/06/05 09:20 8BFr2soT
>>221
>>日時のダンプくらい取れYO・・・
そのとーりです。はい。取る前におきてしまったんでつ。もう、どうしようもないです。
>>他人のせいにして・・・
それが私の特徴です(←こら AccessとかMS-SQL Server2000じゃこんなことゼッタイ無かったのにぃ~と嘆いています。
使い始めて9日目…やっぱ復旧ツールって無いんですね…これこそダメぽ……
223:nobodyさん
03/06/05 11:49
Jet使うとしょっちゅう壊れると思うんだが。
復旧できるからまだしも、そうでなかったらどうしようもない。
224:nobodyさん
03/06/10 15:30 +sYGrsNt
windowsからlinux上にインストールしたpostgresqlサーバに
アクセスして、テーブルとかをいじれるツールってあるのでせうか?
ODBCとか使って、accessからアクセスできないかななんちゃって(サムイ
225:nobodyさん
03/06/10 16:13
>>224
access は知らんが、CSE はできる。
226:nobodyさん
03/06/10 18:37
>>224
激しくできます。ぐぐって見てください。
227:224
03/06/11 01:48
>>225
CSE試してみました。
まだじっくりいじっていないのですが、
SQLコマンドを打ち込む補助ツールのようですね。
SQL初心者には、まだまだわからないことがいっぱいです。
もっと、GUIでテーブル操作とか、リレーションとかしてみたいです。
>>226
ありました!
URLリンク(www.hizlab.net)
こことかで解説みて、成功しましたが、
テーブルの作成やプロパティの変更、クエリの作成などは
出来ないのエスね。。。
228:nobodyさん
03/06/11 12:40 dVQT51zl
>>227
access server を買って使ってくれ・・・
229:postgresql勉強始めました
03/06/12 23:09 aCqR/moW
ここで、質問しても良いのでしょうか・・・?
postgresqlの勉強を始めたばかりで、わからないことばかりなのですが、
いったん作成したテーブルに、新たな列を後から追加・削除することは可能でしょうか?
230:nobodyさん
03/06/12 23:30 b2p7Tjjy
>>229
バージョンによるが、可能。
詳しくは >>179 のドキュメントに書いてあるよ。
231:nobodyさん
03/06/12 23:30
ALTER TABLEを使う
URLリンク(www.postgresql.jp)
基本的なことは>>2のユーザー会のマニュアルを見るべし。
DBは突っ込んで勉強するとけっこう深い。ガンガレ
232:231
03/06/12 23:31
かぶったーよ
233:nobodyさん
03/06/12 23:37
>>1 のテンプレにはマニュアルへのリンクを張った方が良いな。
前スレへのリンクはあまり利用価値が無いと思う。
234:nobodyさん
03/06/14 02:40 8UJU9HVd
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 8UJU9HVd
234です。
事故解決しました。
postmasterを起動するときに、
export も同時にやるとうまくいったよ。
236:
03/06/16 16:41
すいません、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
>>236
コピペ?
あまりにも典型的なハマリ(ry
もし実話だったら
とりあえず新幹線に乗って
京都・奈良で寺巡りでもして来い
壮大な歴史の中では
自分がいかにちっぽけな存在であるか
よーく分かるはずだ
238:nobodyさん
03/06/16 23:54
>>236
まぁ、Postgresのバージョン間の互換性には期待するな、ということで。
239:236
03/06/17 16:12
>>237
違うよ。はまりたくてはまってるわけではないけど
頼むから register_globals を期待しないで欲しい>前の業者
>>238
漏れは期待してません。PHPに関しても然り。
その上でどうやったらこの問題を解決できるか知りたいのれす。
神はここにはいらっしゃいませんか。
240:あぼーん
あぼーん
あぼーん
241:nobodyさん
03/06/17 19:28
>>239
整数のフィールドを持つテーブルに対して、一つ一つトリガを作るとか。
手間はかかるがコードの修正よりは単純作業だし、漏れが出にくいよ(w
UPDATEやINSERTが必ず通る道で待ち伏せするわけだから。
テーブルの一覧をざっと眺めて、半日なり1日なり単純作業をすれば見切り発車はできるかと。
で、後からじっくりマターリとコードを直して行く。。。
すんごい小手先だけど、コード多い・時間無い・エラーが出るのはマズイって状況なら
これぐらいしか思いつかん。
設定で一発でなんとかできりゃあ良いんだろうけど、俺は知りませぬ。
#もしシステムのユーザが一般人ではなくてオペレータとかだったら、「空白入れんなヴォケ!」
#ってマニュアル対応で逃(ry
242:236
03/06/17 19:32
なるほど、トリガですか。何とかなるかな…
ちょっと盲点だったかもしれません。
ありがとうございます、助かりました。
243:nobodyさん
03/06/18 02:42 SST1kRd8
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
>>230
>>231
遅レスすいません。
ありがとうございました。
おかげで解決いたしました。
245:nobodyさん
03/06/22 09:55
>>243
なんか libqp.dll があやしそう。libpq.dll をいれなおしてみては?
246:nobodyさん
03/06/22 09:57 SKC4SEC9
「PostgreSQL構築・運用ガイド」期待age
URLリンク(ml.postgresql.jp)
247:nobodyさん
03/06/22 09:59
URLリンク(ml.postgresql.jp)
248:あぼーん
あぼーん
あぼーん
249:nobodyさん
03/06/22 10:19
本書は,PostgreSQLの導入方法はもちろん,
企業情報システムでの利用を前提にした,運用方法や信頼性,
可用性を高めるための方法,企業情報システムで広く使われている
Oracleデータベースとの比較なども紹介し,
企業ユーザーにとって有用な情報をお届けします。
URLリンク(ml.postgresql.jp)
URLリンク(bpstore.nikkeibp.co.jp)
URLリンク(bpstore.nikkeibp.co.jp)
250:nobodyさん
03/06/22 10:28
で、これは何本って言えばいいんだ?
うぐい本か?日本野鳥○会の人 解説きぼん。
251:nobodyさん
03/06/22 10:53
>>250
ぽすぐれ本
252:nobodyさん
03/06/22 11:15
なんで魚なんだ?>ヲレ
自己突っ込み完了しますた。
次の話題どぞ。
253:nobodyさん
03/06/22 16:44
>>246
なんかまたペンギンの影があるね。
亀は使えないのかな?
254:成功者!
03/06/22 23:57 pFJThKfu
誰でも仕事が出来ます。
資本金0円でスタート
ココを見てください!
URLリンク(www.c-gmf.com)
255:nobodyさん
03/06/23 20:54 dxcUTx3u
Java+PostgreSQLでwebアプリを作る場合、文字コードは何にするのが一般的ですか?
webページをSJIS、DB内はEUCにしようかと思ってますが、EUCにすると
全角半角どちらも1文字扱いになるらしいので、どうしようかな~って感じです。
本番サーバはLinuxでApache+Tomcat、開発はwindowsで同じ環境作ってやってます。
winでの開発はJISが楽ですよね、やっぱり・・・
256:あぼーん
あぼーん
あぼーん
257:nobodyさん
03/06/23 22:12
>>255
PostgreSQLはunicodeでエンコーディングしないと、全角ハイフンなどが化けます。
258:nobodyさん
03/06/25 12:22
バグ出しさせてください、おながいします。
259:nobodyさん
03/06/25 13:52
>>258
環境を教えてください
260:nobodyさん
03/06/26 23:18 UmxIAMQr
>>285-259ワラタ
261:nobodyさん
03/06/27 20:33 r28icV76
Postgres自体でSQLの実行ログがどこかに保存される設定とかってあるのでしょうか?
自前で実装する(SQL実行時にテキストに書き出す or DBにテーブルを作成して書き込む等)
しか仕方ないですよね?
262:nobodyさん
03/06/27 22:35 Fj3NiizR
>>
あるよ。
$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 14usrn45
PHP+PostgreSQLで排他処理を行いたいと思うのですが、
解説本か、サイトあれば教えてください。
無ければ、簡単にご説明くださいませんか?
264:あぼーん
あぼーん
あぼーん
265:nobodyさん
03/06/28 04:20
>>263
ロックする。以上。
266:nobodyさん
03/06/28 05:20 14usrn45
DBのロックってできるの?
267:nobodyさん
03/06/28 07:37
>>266
マニュアル読めや
268:nobodyさん
03/06/28 09:59
ID:14usrn45はDB使わない方が(・∀・)イイヨイイヨー
269:nobodyさん
03/06/29 19:33
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 5q6N3/KD
>>262
当方、バージョンが少し古くて、log_statement = trueではエラーが出たので
ググってみたところdebug_print_query = trueという指定でできました!
ありがとうございます。
271:あぼーん
あぼーん
あぼーん
272:nobodyさん
03/06/30 12:26 5tKrGL8Q
データベース板できました
URLリンク(pc2.2ch.net)
273:nobodyさん
03/06/30 12:40
スレリンク(db板)
274:nobodyさん
03/06/30 12:48
>>272
ひでぇ有様だな(w
スレ一覧みてワロタ
275:nobodyさん
03/06/30 12:59
URLリンク(i.2ch.net)
明らかにデータベース板
276:nobodyさん
03/07/01 00:31
>>274 ← 何気にマジレスっぽ(プ
277:nobodyさん
03/07/01 02:20
ドラゴンボールヲタ?>>276
278:nobodyさん
03/07/01 09:23 oVA7Xb+Q
>>274=>>277 マジレス図星だったようだなw
279:274
03/07/01 09:40
>>278
新板の荒れ様を見てワロタっていう素直な感想を書いただけだから、
確かにマジレスには違いないけど。。
何を無理やり煽り文体にしてるの?
何で絡まれてるの?俺。
280:nobodyさん
03/07/01 11:21
ドラゴンボール関連のスレは消されたみたい。
やっぱりデータベース板だそうだ。
281:nobodyさん
03/07/02 01:55
>280
ついさっきまで確信が持てなかったヲレ。
282:nobodyさん
03/07/02 17:01
>>280
URLリンク(www.ff.iij4u.or.jp)
データベースだし。
283:nobodyさん
03/07/04 04:50
激烈初心者です。
数値のデータ型で、
int2で指定したところに「0001」という数字を代入すると、
1になりますよね?
これを、000の部分を残すためには、文字列型しかないですか?
284:nobodyさん
03/07/04 09:35
「0001」は文字列だから、数値型のカラムに突っ込んで
勝手に「1」になるのは仕方が無いんじゃない?
表示する時に0埋めするようにすれば?
"0000"と文字列にコンバートした1とか10を右から4文字切り取って
表示するとかなら、SQLでできるし。
285:nobodyさん
03/07/10 16:23 57Eu1LHu
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 ubgylsck
>>285
REINDEX
287:nobodyさん
03/07/10 18:09 8n4LR913
BEGIN
処理A
BEGIN
処理B
COMMIT
処理C
ABORT
としても処理AとBはコミットしちゃいますよね?
288:あぼーん
あぼーん
あぼーん
289:nobodyさん
03/07/10 19:40
>287
つか、nested transactionは処理できない。
使おうとしている時点で間違い。
290:nobodyさん
03/07/10 19:40
>>287
BEGINからCOMMITまでがトランザクションだから、
現在のトランザクションはありませんってエラーがでるんでないの?
291:290
03/07/10 19:42
>>289
>>287ネストさせようとしてたのか!
292:nobodyさん
03/07/10 20:16
>291
どう見てもネストしてるじゃん。
ちなみに、beginした後でもう一度beginしると、
「もうトランザクション始まってんのじゃボケェ」と言われます。
293:287
03/07/10 22:42
どうもです。
できるのを前提にコードを書いていたので、
一番外側でだけクエリを発行するようなラッパー関数つくって回避しました。
(途中のアボートは例外処理)
調べてみたらトランザクションのネストができない実装の方が一般的なんですね。
294:285
03/07/11 15:47
>>286
ありがとうございます。一応reindexを毎日するように設定してしばらく様子見てみます。
ちなみにreindexとvacuum fullは順番的にはどちらを先にした方が良いのでしょうか?
295:nobodyさん
03/07/11 17:21 C9rBOC2S
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
>20億トランザクション越えたのにvacuumされませんですた。
>トランザクションID使い果たして、データの喪失が発生しますた。
297:山崎 渉
03/07/15 11:07
__∧_∧_
|( ^^ )| <寝るぽ(^^)
|\⌒⌒⌒\
\ |⌒⌒⌒~| 山崎渉
~ ̄ ̄ ̄ ̄
298:nobodyさん
03/07/23 23:29
299:nobodyさん
03/07/24 12:05 TEX2oC6v
ラージオブジェクトって、pg_dumpでバックアップできるの?
7.1からだっけ?
300:あぼーん
あぼーん
あぼーん
301:
03/07/24 15:51
ちょっとお尋ねしますが、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 IBsY8pQ4
PHP + PostgreSQL
PERL + PostgreSQL
C + PostgreSQL
どれが一番高速でアクセスできますか?
303:nobodyさん
03/07/25 12:25 oPyKjtod
>>302
ミドル次第。
304:nobodyさん
03/07/26 17:34 grYAyx0u
PostgreSQLってRollBack使えないんすか?
305:nobodyさん
03/07/26 22:34
ハァ?
306:nobodyさん
03/07/27 23:23 guTNEK25
>>304
使えよ
307:nobodyさん
03/07/28 09:21 b/HKh3mz
投稿者が女名だと、同じ内容の回答が続くね。
308:nobodyさん
03/07/28 09:44 b/HKh3mz
しかも、「紹介者がいないときは自分自身になります」って条件読んでないし。
309:nobodyさん
03/07/28 10:13
おいらも今度から女の名前で質問しよう。
310:nobodyさん
03/07/28 11:55
>>309
人格つくりすぎて、あぼーんするハメにならんようにな。
311:nobodyさん
03/07/28 23:51
旦那になって戻ってくるから大丈夫。
312:ももこ
03/07/29 00:11
>>311
もどってきてね♥
313:nobodyさん
03/08/01 07:34 fLmmiO+8
すいません。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 esvzZjrA
祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り
ニーノさんのホームページ作り2
スレリンク(entrance板)
ニーノ ◆p9GipySMGk によってラウンジにたてられたこのスレで、
URLリンク(page.freett.com)
【ニーノさんのホームページ】
というサイトが作られた。(現在もコンテンツは爆発的に増えてるよ。)
さぁ、君もアイディアを出して、2CHネラーだけの最強サイトをつくろう!
祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り祭り
315:nobodyさん
03/08/01 07:50
>>313
euc-jpじゃないのかage。
316:315
03/08/01 07:51
ageてねーや。でもspamカキコがくるからageなくていいや。
317:nobodyさん
03/08/01 22:20 bI0qs527
createdb -E EUC_JP データベース名
318:nobodyさん
03/08/01 23:09 vlQX/M9J
URLリンク(www.vesta.dti.ne.jp)
ここなら簡単に見れたぞ
319:山崎 渉
03/08/02 02:20
∧_∧
( ^^ )< ぬるぽ(^^)
320:ぼるじょあ ◆ySd1dMH5Gk
03/08/02 04:48
∧_∧ ∧_∧
ピュ.ー ( ・3・) ( ^^ ) <これからも僕たちを応援して下さいね(^^)。
=〔~∪ ̄ ̄ ̄∪ ̄ ̄〕
= ◎―――◎ 山崎渉&ぼるじょあ
321:nobodyさん
03/08/02 07:48
FAQになってる予感がするけど、列制約を変更したくなりました。
create table asでも列制約は新しく定義できないみたいだし。
あと1列だけ型も変更したい。
慎重に設計しなかった自分が悪いわけですが、なんか突破口
ないですか?手で再入力だけは避けたいです。。
322:nobodyさん
03/08/03 08:56
>>321
突破口って。。。
マニュアル読めばいいだけと違うの?
323:_
03/08/04 16:26
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
CREATE FUNCTION get_account( text ) RETURN SETOF RECORD AS '
[...snip...]
' LANGUAGE 'plpgsql';
325:nobodyさん
03/08/05 13:23
すこしスレ違いかもしれませんが、どちらに質問していいかわからなかったので、
ここで質問させてください。
ある大きな2つのテーブルをJOINしたいのですが、そのままJOINすると
時間が掛かりそうなので、片方を一時テーブルに書き出して、それをJOINしようと
思ったのですが、一時テーブルを作った後、違うページで一時テーブルとJOINしようと
するとテーブルが存在しないと言われてしまいます。
PHPから一時テーブルを作成した場合、その一時テーブルにアクセスできるのは
どのタイミングまでなのでしょうか?
マニュアルにはセッションの終わりまでのようなことが書いてありますが、
PHPのセッションは終了してません。
それとも、一時テーブルを作成しないでもいい方法などありませんでしょうか?
よろしくお願いします。
環境は、PHP 4.2.3 PostgreSQL 7.2.3です。
326:308
03/08/05 13:57
すいません、自己解決しました。
327:nobodyさん
03/08/05 15:59
>325
pconnect使わなければ、PHPからPostgreSQLへのセッションは
毎回切った張ったされますが。
328:nobodyさん
03/08/05 16:25
>>325
一時テーブルをVIEWにするかサブクエリにするのが一般的だけど、
性能上の問題からその一時テーブルの結果を使いまわしたいなら
名前をつけてテーブル作成するしかないかな。
pg_pconnect使ってもApache/PHPの状態によってはDBセッションが同一にならないから、
ページを跨いだ一時テーブルの利用はできない。
329:nobodyさん
03/08/05 18:56
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
>>327, 328
ありがとうございました。
pconnectを使って、ページをまたいで一時テーブルを使おうとしてたので、
テーブルが残ってるのか残ってないのか、よくわからなくて混乱してました。
pg_connectを使って、なんとか同じページ内で一時テーブルを使って処理してます。
VIEWは、まだ勉強中なので試行錯誤してみます。
331:nobodyさん
03/08/06 04:59 7sg7mWSc
教えてください。
DISK障害でテーブル内データのほとんどが消えました。
実体の/usr/local/pgsql/data/base/内は無事のようです。
/base/DB名からなんとかリカバリできないでしょうか?
postgresql6.5.3です。
332:nobodyさん
03/08/08 10:59
ZDNetの誤字ひどいな。
『SRA 最新PostGreSQLをベースにした「PoerGres on Linux」「PowerGres Plus」を発表』
URLリンク(www.zdnet.co.jp)
333:nobodyさん
03/08/18 01:33
age
334:nobodyさん
03/08/25 03:03
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 r6wfNhzL
7.4の自動バキュームって使えそう?
フルバキュームまで自動でやってくれるの?
336:nobodyさん
03/08/27 12:18
何を勘違いしたか今までポスタージャSQLって読んでたよ…
337:nobodyさん
03/09/01 22:46
私信に近い雑談をMLに流すな~!
338:nobodyさん
03/09/01 22:57
>>334
ズレはしないかもしれないが、カチ合う可能性はあるよ。
それを防ぐには、SERIALIZABLEにするか明示的にテーブルロックする。
339:nobodyさん
03/09/01 23:02
cygwinインストール中に落ちてしまって、インストールできないのですが
どうすれば。。あっここで聞くことじゃないですか。。そうですか。。
340:nobodyさん
03/09/01 23:31
>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 yFWWpiPw
PostgreSQL 7.2.1使ってるんですけど、
運用中にREINDEXとかDROP INDEX~CREATE INDEXとかの
INDEXの再生成って行って良いんですかね?
念のため運用を一時的に止めた方が良いんでしょうか?
342:nobodyさん
03/09/07 04:52
やってもいいっすよ。ロックかかるけど。
343:nobodyさん
03/09/16 10:01 Wb82WrlA
バッチグーage
344:nobodyさん
03/09/16 10:29
MLヲチスレでつか?(藁
345:nobodyさん
03/09/16 15:02 Wb82WrlA
>>344
1をみてくらさい。
346:/
03/09/16 22:32 GYSWeRnL
おまえら、7.4 は高速化が図られてるようですよ。
【PostgreSQLウォッチ】第1回 PostgreSQLの次期版7.4の性能を検証
URLリンク(itpro.nikkeibp.co.jp)
347:nobodyさん
03/09/17 11:21 An2EWdc3
select hoge,hogehoge from table group by hoge;
をしたいのですがどのようにしたら実現できますか?
グループ化してないhogehogeもselectしたいのです
348:nobodyさん
03/09/17 12:17
select hoge,hogehoge from table group by hoge,hogehoge;
349:nobodyさん
03/09/23 22:55 PMiaWnnI
>>347
hoge|hogehoge
aaaa|bbbb
aaaa|cccc
とあったら、何を出せバインダー
350:nobodyさん
03/09/24 01:47 Mc741Fcx
おもろい
URLリンク(www.39001.com)
351:nobodyさん
03/09/24 05:33 namugEPq
>>350
「メル友みっけ」か...
352:nobodyさん
03/09/24 05:41
ここが一番上にきとる。
移転したんじゃなかったっけ?
PostgreSQL 2テーブル目
スレリンク(db板)
353:nobodyさん
03/09/24 05:56
バイナリデータの挿入の仕方がマニュアルに書いてない
気がするんですが、どうやるんでしょう。
create table images (imagname text, img bytea);
このimg列に /tmp/hoge.jpg を挿入したいです。
354:nobodyさん
03/09/24 06:17
>>352
しらんかった。
っていうか、ドラゴンボール板さわぎのどさくさで、気付いてなかった。
ということで
--- 糸冬 了 ---
355:tes
04/01/15 23:32
tes
356:nobodyさん
04/06/25 15:10
適当な文字列が入っているcolumnにたいして、
大文字小文字関係なく、検索文字をマッチさせるにはどうしたらいいの?
select * from foo where text_column ^ lower('BAR') or text_column ^ upper('BAR')
とかだと、「Bar」みたいのはヒットしないんだよなぁ。
357:nobodyさん
04/06/25 15:12
あげとく
358:nobodyさん
04/06/25 16:09
>>356
text_column ~* 'BAR'
DBのみのネタはDB板へ
URLリンク(pc5.2ch.net)
359:356
04/06/25 16:33
>>358
THX
~が^になっていた orz
360:nobodyさん
04/07/01 16:49
■ PostgreSQLのことならここで聞け ■
スレリンク(db板)
361:nobodyさん
04/07/14 02:54 IeDlw13K
postgres7.3を使用予定ですが、REINDEXの使用方法を教えてください。
REINDEX対象のテーブル名をpg_stat_user_tablesより
取得しながら、REINDEXを全テーブルに順番にかけるシェルを作ろうと思っています。
その際、pgbashを使用し、cronで自動実行を予定しています。
もしソースコードがわかれば教えて下さい。
またみなさんはどんな方法で、行っていますか?
362:nobodyさん
04/07/14 02:55 IeDlw13K
postgres7.3を使用予定ですが、REINDEXの使用方法を教えてください。
REINDEX対象のテーブル名をpg_stat_user_tablesより
取得しながら、REINDEXを全テーブルに順番にかけるシェルを作ろうと思っています。
その際、pgbashを使用し、cronで自動実行を予定しています。
もしソースコードがわかれば教えて下さい。
またみなさんはどんな方法で、行っていますか?
363:nobodyさん
04/08/26 20:45 QkQTY22p
ネットワークから接続しているユーザのIPを
抜き出してログを取りたいのですが
SQLコマンドで、自分はどこから接続しているかを
確認できる関数ってPostgresにはありませんか?
とにかく、接続しているクライアントのIPさえ分かればOKです。
宜しくお願いします。
364:nobodyさん
04/08/26 21:22 vvcjm84y
管理人が拳銃発砲!!!
URLリンク(bbs2.orange-e.net)
365:nobodyさん
04/09/03 11:18 dro8VJ79
apache2.0.5とPostgreSQL7.4の環境でmod_auth_pgsqlを使ってBasic認証を
行なっているのですが、認証するたびにpostgresユーザーで下のようなプロセスが
溜まっていきます。
postgres: apache database 127.0.0.1 idle
そして挙げ句の果てに
mod_auth_pgsql database connection error reset failed FATAL:
connection limit exceeded for non-superusers とメッセージが出てサーバーエラー
になってしまいます。多分mod_auth_pgsqlがパスワードのデータベースへ接続した後、
切断してくれないからじゃないかと思うのですが、どこか明示的に設定しなければ
ならない場所があるのでしょうか?
366:nobodyさん
04/09/03 12:21
>>365
Auth_PG_connection_reuse がonだとコネクションプーリングするみたいですよ。
デフォルトはoffのようだが。
367:nobodyさん
04/09/03 13:48 dro8VJ79
レスありがとうございます。早速 Auth_PG_connection_reuse off を設定して
みました。(それ以前は、Auth_PG_connection_reuseは何も設定していません。)すると
Invalid command 'Auth_PG_connection_reuse', perhaps mis-spelled or defined
by a module not included in the server configuration
となりサーバーエラーが返ってきました。別の原因は考えられますか?
ちなみにmod_auth_pgsqlは2.0.1、ディストリは fedora core 2です。
368:366
04/09/03 19:40
>>367
ざっとソースを眺めてみた限りにおいて、2.0.1では切断をしていなさそうだ。
postgresqlの設定を変更して接続許可数を増やすか、
2.0.2b1にUpするしかないんじゃないか。
369:nobodyさん
04/09/03 21:48
わざわざ調べて頂いてありがとうございます。バージョン特有の問題なのですね。
当面の間は、max_connectionsを増やして、cronで定期的に service httpd graceful
を走らせてしのごうと思います。お世話になりました。
370:nobodyさん
04/09/04 17:32
>>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 xemAm0Ui
行き詰まってしまって解決できなくなってしまったので、
質問させて頂きます。
TESTというテーブルの中に、A,Bというカラムがあり、
Aでgroup byしてから、Bをdistinctしたものの
カウントを取りたかったくて、下のようなSQLを組んだのですが、
Bをdistinctできてないものをgroup byした結果が、
出てきてしまいます。
私が意図したSQLはどうすれば実現できるかご教授おねがいします。
SELECT A,count(distinct(B)) FROM TEST group by A;
372:nobodyさん
04/09/09 19:21
>>371
質問の意図を取り間違っているかもしれないが。
SELECT a,count(*) FROM text GROUP BY a,b;
以後、DBのみの話ならDB板へ
■ PostgreSQLのことならここで聞け ■
スレリンク(db板)
PostgreSQL & pgsql-jp ML 3テーブル目
スレリンク(db板)
373:371
04/09/09 22:19 xemAm0Ui
>372
意図したこととは違いましたが、そのSQL見てて、
ふと思いつき、解決できました。ありがとうございます。
374:nobodyさん
04/09/30 06:39:58
データが8000件位入ったテーブルtestに
さらに8000件近いレコードを追加したいのですが
insert文をエクセルで8000個作ることまではできたのですが、
これをポスグレに読ませる際、一括でコピペするとパースエラーになってしまいました。
10件位づつこまめにコピペするとエラーは起きないのですが
時間がかかりすぎるのでファイルから読み込ませたいのです。
ググった所"copy"だと扱えるデータがタブ区切り形式らしいのですが
insert文が書かれたファイルを読み込ます事はできるのでしょうか?
PostgreSQL7.2.3です。
375:nobodyさん
04/09/30 07:13:18
>>374
psql -f filename
376:374
04/09/30 07:38:51
>>375
レスありがとうございます。
早速ググりましたが
psql -f filename db名で
URLリンク(jpug.postgresql.jp)
にありました。
ありがとうございました!
377:nobodyさん
04/10/05 15:22:15 xTnP4bvw
不安なのでちょっと質問して宜しいでしょうか。
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
>>377
date型にキャストした方が速いかも。
WHERE modify_date::date='2004/11/04';
379:nobodyさん
04/10/05 15:41:36
>>378
おお!なるほど、そういうやり方があったんですね。
感謝ですm(_ _)m
380:378
04/10/05 15:43:11
>>378
あ、この方法だと、'2004/11/04'もdate型に変換するだろうから、
結局>>377とあまり違わないのかな?
俺はこの方法を用いているのだけど。
381:377
04/10/05 15:46:28
>>380
377では速度の最適を求めるような書き込みになってしまいましたが
to_charでYYYY・・・・と変換するのに抵抗を感じてしまって他のやり方が
あればと思って質問したので、十分満足しています。もっと最適なものが
あれば尚いいとは思いますが、378さんのやり方を使っていきたいと思います。
382:nobodyさん
04/10/06 11:37:12
ポストグレスキューエルそろそろ囓ってみようと思うんだけど
こんなボンクラはまずどんな本を読めばいいですか?
教えて下さい ISBNコードのみで( ´,_ゝ`)
383:nobodyさん
04/10/06 18:22:48
初めてこのDBに挑戦したら
initdb: command not found
でいきなり死亡しました。
URLリンク(www.terra-intl.com)
↑に書いてある通りにやったら
7. のinitdb でだめだったんですが、
このような経験のある人いませんか?
384:nobodyさん
04/10/06 20:34:45
>>383
せめて、使ったCygwinとPostgreSQLのバージョンくらい載せるべし。
このページと同一のバージョンが入手できた訳じゃないよね?
あるいは、PostgreSQL と Cygwin でぐぐって、新しめのページをを探すべし。
385:nobodyさん
04/10/06 21:48:18
同じバージョンしか落とせなかったんですが、古いみたいですね。
新しいので朝鮮します。
386:nobodyさん
04/10/07 12:14:27
URLリンク(discypus.jp)
今度はこのページ見てやったんですが、「Cygwin-X」なんてできないし、
デスクトップのcygwinを起動しても一瞬黒いウインドウが出るだけで
何も起こりませんでした。
昨日はできたbashもできなくなって余計ひどくなってしまいました。
環境変数は本当にシステム環境変数でいいのでしょうか?
昨日はユーザー環境変数で設定したんですが。
387:nobodyさん
04/10/07 13:55:35
>>386
Cygwinなんて使わずに8.0入れたらだめなの?
388:nobodyさん
04/10/07 14:22:42
特定のレコード(たとえばIDがaaaのレコード)がなければインサート、
あればアップデートという処理をしたいのですが、
selectであるかどうかチェック>insertかupdateに振り分ける
という方法以外に簡潔にやる方法はありますでしょうか?
389:nobodyさん
04/10/07 23:12:25
>>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
URLリンク(allabout.co.jp)
結局ここの通りにやって成功しました。
これからの問題はJavaServletでどう扱うのかってことだけです。
なぜかPHPの解説サイトばっかなんだけれども・・・。
8.0は解説無しじゃ難しいと思ったので、辞めておきました。
391:nobodyさん
04/10/12 12:56:48 V57uzdCO
質問させて下さい
PostgreSQL(7.2.3)を使ったWebサイトを作っているのですが、最新項目の表示のため
日付(date型)でorder byしてますとえらく処理に時間がかかっています。
そういうものなのでしょうか?
日付でソートしたい場合の効率的な方法などがありましたら教えてください
392:nobodyさん
04/10/12 13:56:22
まず、vacuumdb -f dbname やってミソ。
393:nobodyさん
04/10/12 13:58:02
>>391
DATE型は内部的には4Byteの整数だから、DATE型にしてソートが遅くなると言うわけはないだろう。
一度、VACUUM FULL table;をしてみては如何だろうか。
394:nobodyさん
04/10/12 18:57:34
>>391
型の問題ではないと思うが。そのカラムにインデックスつけてる?
395:391
04/10/12 20:08:58
>>392,393,394
す、すいません
みなさんのご指摘の組み合わせでした。
indexつけたあとvacuumしてなかったせいみたい。。。
ご指摘ありがとうございました!
396:nobodyさん
04/10/25 02:34:54
.open()
でエラーがたまに出るけど、みんなどうやって処理してます?
自分は2回リトライさせてるだけなんですけど、
「普通はこうやるんだ」みたいな決まりってあるんでしょうか?
397:nobodyさん
04/10/25 04:26:44
>>396
でたことないので、出たら出ないように調べると思う
398:nobodyさん
04/10/28 02:30:23
ポストグレスキューエルを信じて裏切られることはありまつか?
399:nobodyさん
04/10/30 09:21:22
PostgreSQL ベースの某社の製品にならあるけど。
400:7.4.5
04/10/30 20:56:47
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 gbkcKDZ/
PHP4.39とPGSQL7.46で学習してます
トランザクションについて教えてください
BEGIN
SELECT テーブルAのid(SERIAL)のNEXTVALを取得
INSERT テーブルAに上で得られた値をidにいれて挿入
INSERT テーブルBに上で得られたidの値を挿入
COMMIT
以上のような流れがあったとしてテーブルAのidの唯一性は保証されてますか?
要はテーブルAにINSERTしたときのidを取得としてテーブルBにも入れたいんです。
NEXTVALを取ったあとに他のプロセスが参照してデータの整合性がなくなるのが心配です。
402:nobodyさん
04/11/10 17:52:12
シーケンスの nextval で取得される値は
トランザクションとは関係なく
唯一性が保証されるように思う
403:nobodyさん
04/11/17 16:35:31
(;´Д`)ハァハァ ポストグレスキューエルはマイエスキューエルにまだアドバンテージはあるのかい?
404:nobodyさん
04/11/24 18:16:16 fGkcMHGT
SELECTして出てきた行に1から始まる連番をつけるってことできますか?
データのランキングをだしたいんですが。
405:nobodyさん
04/11/24 19:32:44
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
>> 405 の件は、自己解決しました。
grant select,insert,update,rule on tbl_b to nobody;
以上で実現しました。
板汚し失礼しました。
407:nobodyさん
04/11/24 20:56:44
>>403
Myに比べて多機能だしいろいろあるだろ
>>404
できる
408:404
04/11/27 22:42:48
>>407
具体的にどうやるんですか?マニュアル読み漁ってもわかりません。
サブクエリで連番つくる方法は検索して見つかったんですけど
もっと簡単にできないものかと。
409:nobodyさん
04/12/03 01:31:36 2+kl6sm2
カラム内のデータを置き換えすることはできないものでしょうか。
イメージとしましては、
update table_name set f =~ s/abcde/qwert/g;
こんな感じのようなことをやりたいのですが、説明がどうもうまく
なくて申し訳ありません。
ご教授いただければ幸いです。
宜しくお願いします。
410:nobodyさん
04/12/03 02:07:28
お主の望みは正規表現置換かや?
ならば、PL/Perl などを使ってユーザ定義関数を作れ、とのご神託である
411:nobodyさん
04/12/03 10:44:31 2+kl6sm2
>>410
SQL内でなんとかできないものでしょうか。
フィールド値の内容を丸まる変更は当然出来ますが、
likeを使用しつつもどうにかできないものかと模索中で
ございます。
412:nobodyさん
04/12/03 12:23:36
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 2o4fy8y0
>>410、>>412
ERROR: Unrecognized language specified in a CREATE FUNCTION: 'plperl'.
Recognized languages are sql, C, internal, and created procedural languages.
となったので、どうやらPL/Perlが入っていないみたいなので、入れる権限のない
私なりに何か他に方法がないか探してみました。
URLリンク(www.nanbu.com)
これでなんとか凌ぎました。
グローバルオプションこそつけられないものの、置き換えは何とかできるので
助かってます。
ご教授有難うございました。
414:nobodyさん
04/12/16 13:06:24 qpxocizM
foo というテーブルで、hoge fuga hige moe
ちう2つのレコードがあります。
で、hoge fuga higeが3つとも同じレコードについては、まとめて1レコードとみなし。
fooテーブルが何レコードあるか調べたいのですが、
どうゆうSQL文を書いたらよいのでしょうか?
select sum(*) from favorite group by hoge, fuga, hige
とやってもだめでした(そりゃそうだよね。。。)
どなたか教えていただければ幸いです。
415:414
04/12/16 13:07:38
訂正:
>foo というテーブルで、hoge fuga hige moe
>ちう2つのレコードがあります。
foo というテーブルで、hoge fuga hige moe
という2つの「フィールド」があります。
すみません
416:414
04/12/16 21:08:42
回答ないようなのでDB板逝ってきます
417:nobodyさん
05/01/19 17:22:21
ゲイツOSに対応した、postgreSQL8
キタ━━(゚∀゚)━━ッ!!
418:nobodyさん
05/01/21 13:24:22 DguRcNyC
フィールドが一個だけのテーブルが必要なんですが
こういうことって変ですか?
419:nobodyさん
05/01/21 15:11:06
>>418
それだけの情報で何をどう答えろと?
そうですか、では私はエスパーですか
420:nobodyさん
05/01/22 02:07:24
>>418
必要なのなら変ではない。
必要ないのにあるのなら変。
421:nobodyさん
05/02/01 16:43:18 HYaKzyWg
vacuum fullを実行すると2~3時間ぐらいかかり、
しかもその間、httpdに完全に接続できなくなります。
vacuum fullって、そんなもんなのでしょうか?
vacuumしないと、3日もしないうちに重くなってDB接続エラーでまくります。
3日1回httpd止めて作業となると大変なので軽減させたいのですが、
何か良い方法があれば教えてくださいm(_ _)m
構成は、こんな感じです。
Xeon2.8GHzDUAL
メモリ2GB
HDD120GB
Linux-FedoraCore2
・apache_1.3.33
・postgresql-7.4.5
・php-4.3.9
422:nobodyさん
05/02/01 17:35:59
>>421
VACUUM FULLを定期的にする必要なんてないっしょ。
普通cronで1日1回vacuumdb -aで十分。
8.0ならVACUUM遅延機能があるからなおよし。
423:nobodyさん
05/02/01 17:47:45
>>421
3日に1回って、そんなにすごい頻度で delete / update してるDBなのか
424:nobodyさん
05/02/01 18:13:44
おいらはvacuumdb -a -z派
425:nobodyさん
05/02/01 18:21:39
>>423
Apacheが絡んでるから、mod_auth_pgsql使っててなおかつログ取ってるとか
セッションストレージにPostgres使ってると思われ。
ツッコミどころはそこじゃなくてVACUUM "FULL"じゃないかな。