PostgreSQL 2テーブル目
■ このスレッドは過去ログ倉庫に格納されています
0001nobodyさん
03/03/11 02:34ID:9JR4latc関連アプリケーション特有の話題は、以下のスレッドへ。
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/
0042nobodyさん
03/03/22 00:34ID:???こうしたのだが、
Warning: pg_query() query failed: ERROR: Bad boolean external representation '2ch'
となるんだけどどこがおかしのかわかりましぇーん
省略しすぎたけど一応PHPってことでたのんまふ。
$id = "2ch" ;
$sql = "SELECT *FROM board WHERE '$id'" ;
$result = pg_query(sql) ;
教えてくらはい。
0043nobodyさん
03/03/22 00:38ID:???SELECT * FROM board WHERE '2ch' になるのだが、
これは希望通りのSQL?
0044nobodyさん
03/03/22 00:51ID:???$result = pg_query($sql) ;
続きがあって
if ($result) {
print ("2chは見つかりました。");
if (!$result) {
print ("2chはみつかりました。);
というわけで、テーブルの中に"2ch"という文字が
あるか無いかをしりたいんですけど。
0045nobodyさん
03/03/22 00:52ID:???print ("2chはみつかりました。");
です
0046nobodyさん
03/03/22 00:55ID:???あとMLで他人の署名まで全文引用するのもキライです。
いやなことありまくりです。そっとしといてください。
>>42
まともなsql文すら書けない人は行ってよし。
0047nobodyさん
03/03/22 01:01ID:???0049nobodyさん
03/03/22 01:23ID:lQb2nQAC何て列に入ってるのかということに
実は気付いていないという罠(w
0050nobodyさん
03/03/22 01:37ID:???0051nobodyさん
03/03/23 00:43ID:???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
と記録されてしまいます。
結果が出てるのにエラー文が出るというのが気持ち悪いんですが
何が間違ってるんでしょうか。
0052nobodyさん
03/03/23 02:15ID:T5828xOTバージョンはどうなってる?
0054名無しさん@Emacs
03/03/23 03:47ID:???0056nobodyさん
03/03/24 15:05ID:Z0MnyWwnなんかもっとスマートな方法無いでしょうか?
結果レコードのカラム名を変数で指定できると嬉しいんだけど、
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';
0057nobodyさん
03/03/25 10:48ID:???集約関数つかってみた。でもデリミタ指定できなくなっちゃった。
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;
0058nobodyさん
03/03/25 17:13ID:???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 の結合順序ってコントロールできるんですか?
005957
03/03/25 17:46ID:???select 名前
,replace(join_str(好物),' ','@') as 好物
from (select * from 好物 order by 好物) as k
group by 名前;
既に全然スマートじゃないという罠。
0060nobodyさん
03/03/25 22:02ID:???すごいでつね。正規化したのはいいけれど、動的配列を繋げて一行で取り出すのって一苦労。
集約関数は奥が深い深い。勉強になります。
うちはまだ、好物1,好物2, ...., 好物25 をくっつけてますよ。
006156
03/03/26 11:32ID:???なるほどー。すごく勉強になりました。ありがとう。
ちなみに、7.2.1 では replace() が使えませんでした。
7.3.2 では使えました。
同じマシンに異なるバージョンの Postgres をインストールするのって、
簡単にできるんですねえ。
0062nobodyさん
03/03/27 17:09ID:???プロジェクトに「火がついた」か。
0064nobodyさん
03/03/28 01:24ID:???test=# select CURRENT_DATE - '2001-12-01'::DATE > '2 month'::INTERVAL;
?column?
----------
f
(1 row)
となるのが・・・なんでだろ〜(´Д`;)
DATE型じゃなくてTIMESTAMP型にすると
ちゃんとtrueで帰ってくるのですが……
0065nobodyさん
03/03/28 01:38ID:???# SELECT (CURRENT_DATE - '2001-12-01'::DATE);
?column?
----------
482
どうも返り値がinteger型のようだ。
006664
03/03/28 13:45ID:???integer型のようですね(´Д`;)
結局
# select CURRENT_DATE - '2 month'::INTERVAL >= '2001-12-01'::DATE;
?column?
----------
t
(1 row)
としたら動きました。うーむ謎〜。
#よくわかってないだけかも。
0067nobodyさん
03/03/28 17:21ID:???MicrosoftのAccess で入力フォームを作って、それをテキストにexport、
文字コード等を適当なものに変換、最後にcopy コマンドでpostgres に
持ってくる、という煩雑なことをしているのですが、もうちょっとなんとか
ならないのかな??と悩んでまして。。。
0068nobodyさん
03/03/28 19:11ID:???DATE型 - TIMESTAMP型 = INTERVAL型 で
DATE型 - DATE型 = INTEGER型 なんだよな。
仕様なのかバグなのかMLで聞いてみれば。
いc氏あたりが答えてくれるかも。
0070nobodyさん
03/03/30 15:36ID:/7/BL2Cw釣り日和でつ。
,
,/ヽ
,/ ヽ
∧_∧ ,/ ヽ
( ´∀`),/ ヽ
( つつ@ ヽ
__ | | | ヽ
|――| (__)_) ヽ
 ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄| ヽ
/⌒\/⌒\/⌒\/⌒\|彡~゚ ゜~ ~。゜ ~ ~ ~ ~~ ~ ~~ ~ ~~ ~~ ~~
⌒\/⌒\/⌒\/⌒\/⌒\彡 〜 〜〜 〜〜 〜〜 〜 〜
0071nobodyさん
03/03/30 15:50ID:dniM4gxK0072nobodyさん
03/03/30 16:41ID:???PowerGres (PostgreSQL on Windows)
〜オープンソースデータベースのスタンダード "PostgreSQL" を Windows で〜
http://osb.sra.co.jp/PowerGres/introduction.php
0074nobodyさん
03/03/30 17:48ID:???有償なのはいいとしても、ソース公開じゃないから、単なる
「Windowsで動作するPostgreSQL互換RDBMS」にしか
過ぎなくなっちゃったんだよね。
石井さんはPostgreSQLがオープンソースであるメリットを
熱く語っていたけど...。
0076nobodyさん
03/03/30 23:07ID:???BSD ライセンスのオープンソースだからこそ、
こういった派生品でのビジネスもできる。
そして、オープンソースは、関わる人間の多さが成功の要。
たとえ派生品でも、ベースとなる製品についての知識を有する人が
一人でも増えるのは喜ばしいことだよ。
増えたうちの一人がほんの少しでも本家にコミットしてくれるなら、
最終的に本家の利益にもつながる。
>>75
メールの本文はほとんど読まずに、Subject しか読んでないから全然詳しくないんだけど、
本家の postgres-hackers ML では MS Windows 版の話とか出てるよね。
7.4 でネイティブサポートするとか書いてあったような。
0077nobodyさん
03/03/30 23:24ID:???ttp://hp.vector.co.jp/authors/VA023283/PostgreSQL.html
ttp://hp.vector.co.jp/authors/VA023283/PowerGres.html
本家はプロセスモデルでPowerGresはスレッドモデルってことでいいかな。
0079nobodyさん
03/03/31 13:53ID:???ただ、(WindowsのスレッドモデルをUNIXに持ってくることに)
どの程度意味があるかは分からん。
S○Aも、UNIXでいくならUNIX一本でもっと機能拡張とかすればいいのに。
中途半端にUNIXもWindowsも手を染めてどうすんだか。
0080質問です。
03/04/01 17:16ID:0gCa7Sb2Windows版 ってないのですか?
0081nobodyさん
03/04/01 17:19ID:???,/ヽ
,/ ヽ
∧_∧ ,/ ヽ
( ´∀`),/ ヽ
( つつ@ ヽ
__ | | | ヽ
|――| (__)_) ヽ
 ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄| ヽ
/⌒\/⌒\/⌒\/⌒\|彡~゚ ゜~ ~。゜ ~ ~ ~ ~~ ~ ~~ ~ ~~ ~~ ~~
⌒\/⌒\/⌒\/⌒\/⌒\彡 〜 〜〜 〜〜 〜〜 〜 〜
0082nobodyさん
03/04/02 01:19ID:???祭りか徹底無視か?
0083nobodyさん
03/04/02 01:37ID:???0085nobodyさん
03/04/04 06:06ID:PaLgsWqPset client_encoding to 'SJIS'; を実行すると、
Conversion between SJIS and EUC_JP is not supported.
となってしまいます。
PostgreSQLのlib/にはそれらしき(?)、euc_jp_and_sjis.so があります。
一体何が原因なんでしょうか?
0086nobodyさん
03/04/05 00:01ID:???select * from pg_convertion (だったかな)
とかはヨサゲ?
0087nobodyさん
03/04/05 05:05ID:???ポスグレではselect文だけにしか使えないのでしょうか?
だとしたら2つのテーブルを比較して足りないモノだけを
1方のテーブルに追加していく、なんてことはできないのでしょうか?
やれるとしたらどんな手段があるか、参考になるサイトがあれば教えてください。
0088nobodyさん
03/04/06 17:10ID:iXfPNuQP今後は「今までのディスク+追加したディスク」を使いたいのだが可能なの?
やっぱり、一つのデータベースが複数のディスクにまたがるのは無理なのかなぁ
0091nobodyさん
03/04/07 00:49ID:???してみたら、読み込みはうまくいったけど書き込みは
文字化けしてテーブルに書き込まれてしまった。
文字コード調べてみたらSJIS->EUC-JPのような変換が
行われ、そのEUC-JPのコードをSJISで見たときの文字化け
のままテーブルに書かれてしまった感じ。
解決策があったら教えてください。
009291
03/04/08 00:41ID:???jdbc:postgresql:test?charSet=SJIS
デコードの指定を付けたらすべてうまくいきました。
0093nobodyさん
03/04/09 03:20ID:Ub7v47GHPostgreSQLでできること、全部できる?
0094あぼーん
NGNG0095nobodyさん
03/04/09 06:30ID:???誰も買ってない悪寒。だから言ったのに・・・。
0096nobodyさん
03/04/09 19:01ID:xm6OICY+Ver7.4のWindowsネイティブ対応っぷり次第だな。
それまで待てれば待ったほうがいい。
0097nobodyさん
03/04/10 11:21ID:???0099nobodyさん
03/04/10 12:29ID:???0100nobodyさん
03/04/10 15:51ID:???うそだ!
select * from table where string ~ '(.)\1\1';
とかできなかったぞ!できるというなら例を見せてみれ!
0101nobodyさん
03/04/10 18:42ID:Gvrywi5t逆に、「あるフィールド以外すべてセレクト」というふうなクエリーはかけないのでしょうか?
0103102
03/04/10 20:27ID:???0107nobodyさん
03/04/11 01:46ID:nN51pMH3そっか!ありがと。試してみます。
0109nobodyさん
03/04/12 19:46ID:UOkuI+UD0113nobodyさん
03/04/16 13:29ID:sI0EuNRHSELECTしたい列名なんて明示的に書くのが王道だろ
それとも
テーブル設計をコロコロ変えやがるのかと小一時間...
0114山崎渉
03/04/17 12:01ID:???011533
03/04/17 13:09ID:???n 日前のバックアップファイルを削除する、という機能が欲しくなったので付けてみた。
find と xargs コマンドが必要。
find ${BACKUPDIR} -type f -daystart -mtime +${EXPIRE_DAY} |xargs /bin/rm -f
全文は長いので >>116 に張ります。必要ないって? そんなこと言わないで・・・。
011633
03/04/17 13:09ID:???# 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}
0117山崎渉
03/04/20 06:27ID:???( ^^ )< ぬるぽ(^^)
0118nobodyさん
03/04/23 02:29ID:b3QZu4PmORDER BY かけると JIS 漢字順ではなくなるのかな?
0119nobodyさん
03/04/23 23:03ID:???サイトのJavaScriptでしばらく楽しんでしまった。。。
0120あぼーん
NGNG0121nobodyさん
03/04/24 19:29ID:Q1w3nY2w複数のカラムを対象に、selectしたいのですが、どう書けばよろしいでしょうか?
mysqlだとFull Text Searchとあると思うのですが、Postgresでできますでしょうか?
0122nobodyさん
03/04/25 11:28ID:???http://www.minq.se/products/dbvis/index.html
Javaアプリだけど、個人的には好感触。
0123nobodyさん
03/04/25 12:18ID:???psqlで十分。
エディタもviでいい。
巡回ダウソもwgetでいい。
なんてなぁ、新しいのを覚えられないだけ。
CSE入れてみたけど起動してみて、
さ ぁ ど う し た も の か と 小 一 時 間 ...
0125nobodyさん
03/04/27 12:54ID:???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使う時点で、設計ミスか余計な機能な気もするけど。
0126nobodyさん
03/04/27 21:48ID:RGglVdIs"\b"、"\n"、"\."は
"\\b"、"\\n"、"\\."に変換すれば入るのに・・・
"\N"は"\\N"に変換してもだめ・・・
"\N"という文字列はだめなんでしょうか?
0127nobodyさん
03/04/27 21:51ID:ClMbC1OP第一正規化、って知っていますか?
0128121
03/04/27 21:52ID:u/4ug4s4失礼しました。whereで複数カラムを指定するという意味です。
>> 125
全文検索というと、確かにNamazuとかそういう方向いっちゃいますね。
単純に複数カラムを検索条件にかけたいだけです。
where andでつなぐと遅くなるので、(レコード数が230万件あるので)
mysqlのFull Text Searchつかったらと先方にいわれ、いまさら乗り換える
のはややこしいので、Postgresでもそういう機能がないかと探しておりま
した。
設計ミスか余計な機能ではとありますが、検索対象の列が5つあって、
最初はそれぞれにかければいいという仕様でしたが、5つのどれかに
ヒットするようにしなさいと仕様が変更されたのです。
他に方法あるでしょうか? って自分で考えろという感じですが、
いろいろと調べてはいるのですが、思いつきません。。
0130121
03/04/27 22:41ID:u/4ug4s4すいません、where andではなく、where or で、遅くなるという意味です。
0131nobodyさん
03/04/27 23:03ID:???>設計ミスか余計な機能ではとありますが、検索対象の列が5つあって、
>最初はそれぞれにかければいいという仕様でしたが、5つのどれかに
>ヒットするようにしなさいと仕様が変更されたのです。
そんなの、仕様変更されるのが当たり前だな。
仕様変更に対応できるようにしてなかった設計ミス。
ところで、230万件×5の全文検索ってMySQLなら速くできるのかな?
0135132
03/04/28 02:16ID:???あー、likeで%から始まる奴は駄目だね。
ホントに全文検索っぽくやってるとしたら、like '%語句%'ってやってる
可能性は高いか。
121にもうちょっと情報を出してホスィところだなぁ。
0136nobodyさん
03/04/28 11:27ID:???0137121
03/04/28 13:42ID:carn+S7wご指摘の通り、like '%語句%'とやっております。
実は今からでもテーブルの設計は変更可能なのですが、
どのように変更したらよろしいでしょうか。
今はID,NAME,AA,BB,CC,DD,EEというカラム構成で、
AA,BB,CC,DD,EEの中で、どれかに検索キーワードがあればヒットする
というようにしたいです。
>> 136
こちらありがとうございます。
coalesceってこういう時に使うのですね。習ってはいたのですが、
いつ使うんだろと思っていました。勉強になります。
0139nobodyさん
03/04/29 11:45ID:???like '%cd%' とすると遅くなるから、
abcdefg
bcdefg
cdefg
defg
efg
fg
g
というテーブルを別に作って、like 'cd%' すると速くなるよ、と
言われたことがある。もちろん、インデックス作って。
実際自分でやってみたことはないが。
0140121
03/04/29 18:01ID:JKdqeuMi正規化については、こちらを読みました。
http://www.rfs.jp/sitebuilder/sql/01/06.html
今回のケースとは特に関係ないかと思うのですが、私の洞察力不足でしょうか。
>> 139
ありがとうございます。
そこまでやると複雑になるので、おとなしくMySQLに移行するかと思って
しまいます。。
0141nobodyさん
03/04/29 19:13ID:8zWvKIjl■ このスレッドは過去ログ倉庫に格納されています