PostgreSQL 2テーブル ..
[2ch|▼Menu]
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



次ページ
最新レス表示
スレッドの検索
類似スレ一覧
話題のニュース
おまかせリスト
▼オプションを表示
暇つぶし2ch

5366日前に更新/193 KB
担当:undef