PostgreSQL 2テーブル目 at PHP
[2ch|▼Menu]
1:nobodyさん
03/03/11 02:34 9JR4latc
PostgreSQLについて語って2万テーブルをめざしましょう。
関連アプリケーション特有の話題は、以下のスレッドへ。
pgsql-mlのヲチもここで。

前スレ
[PostgreSQL]
スレリンク(php板)

☆関連スレッド
[PHP + PostgreSQL]
スレリンク(php板)
[PerlでPostgreSQL]
スレリンク(php板)
[MySQL vs PostgreSQL]
スレリンク(php板)



2:1C
03/03/11 02:40
関連。

日本PostgreSQLユーザー会
URLリンク(www.postgresql.jp)

PostgreSQL7.1マニュアル全文検索
URLリンク(osb.sra.co.jp)

3:nobodyさん
03/03/11 13:56
前スレ963で「遅い」と書いた者です。
あのあとvacuum analyze とかやってたら
1.7秒くらいになりました。
以前はあったindex scanが逆に全くなくなってしまったのが不思議です。
explainで見るとHash Join、Hash Condばかり、ほとんどHashです。
また、order byの有る無しで時間が全く違っています。
無しにすると1秒縮まるのでソートに1秒かかってるようです。
並べ替えないわけにもいかないし・・・

4:nobodyさん
03/03/11 18:56 mhiQ8bxf
並び替えたい順のindexを作っておく。
必要な列は全部指定しておく。
列の指定順序に要注意。
JOINしてる場合も、各テーブルに
つけておく。

これで改善されないか?

5:nobodyさん
03/03/11 23:59
mod_perl なんですけど、finish しないとどうなるんでしょうか?

メモリが開放されない?

6:あぼーん
あぼーん
あぼーん

7:nobodyさん
03/03/15 00:37 qfIx2KLL
オフィシャルサイト
URLリンク(www.postgresql.com)

日本 PostgreSQL ユーザー会
URLリンク(www.postgresql.jp)

PostgreSQL7.2.3日本語ドキュメント
URLリンク(www.postgresql.jp)

PostgreSQLメーリングリスト(pgsql-jp)
URLリンク(www.postgresql.jp)

改訂第3版 PC UNIXユーザのためのPostgreSQL完全攻略ガイド (シーラカンス本)
URLリンク(www.gihyo.co.jp)

石井達夫氏の PostgreSQL information page
URLリンク(www.sra.co.jp)

CSE - Common SQL Environment の つみき Web
URLリンク(www.hi-ho.ne.jp)

8:nobodyさん
03/03/15 13:37 YPCssbUz
>全スレ998
サンクス
PHPとPostgreSQLの事で質問したものです。
PHPの方のmultipart文字コード変換ルーチンがバグってました、
ところでPHPの便利な検索サイトで"PHPマニュアル全文検索"
というのを重宝してるんですが
URLリンク(apollo.u-gakugei.ac.jp)
PostgreSQLでこんなサイト知らない?
マニュアルは見るのですが探すのに時間かかるんで
"PHPマニュアル全文検索"だと文字を打ち込んでボタン一発でマニュアルの中を検索してくれるんでとってもいいのだ。

9:前スレ998
03/03/15 16:09 V2aA/g1w
>>8
PostgreSQL7.1マニュアル全文検索
URLリンク(osb.sra.co.jp)

7.2.3 の検索をしたければ、自分で Namazu の検索を構築してね。
Namazu はそんなに難しくない。

10:前スレ998
03/03/15 16:11
ていうか >>2 にリンク張ってあるじゃん。
>>8 はちゃんとテンプレ読め。そして私も読め。

11:nobodyさん
03/03/15 17:22 YPCssbUz
サンクス
>9
>10
すまんですたい
やっぱPostgreSQLにもおなじもんがあったんですね


12:nobodyさん
03/03/15 23:37
URLリンク(search.net-newbie.com)
ここにいくと、php も PostgreSQL7.2.3 も検索できます。

13:nobodyさん
03/03/15 23:51
PHP+PostgreSQLケンサク (・∀・)イイ

14:nobodyさん
03/03/16 01:10 MfieTvGJ
長くてごめんね、もう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
で、$sqlは結局どうなっとるの?

16:nobodyさん
03/03/16 01:41
とりあえずphoneがint型なのにクォートされている。
エラーとはちょっと違うけどな。
なんにせよ、echo $sql で確認汁

17:nobodyさん
03/03/16 02:09 MfieTvGJ
どうもです
$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
両方同時に学ぼうとしないで、まずはPHPの学習に専念すれば?
問題の切り分けが全然できてないじゃん。

19:nobodyさん
03/03/16 02:18
>>17
そのpg_query()文の後ろにある、$encounter_nu, ってなによ。


20:nobodyさん
03/03/16 02:19 MfieTvGJ
>18
らじゃ

21:nobodyさん
03/03/16 02:34 MfieTvGJ
よろしく
>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
SQLやPHPの前に日本語勉強せろ。

23:乗りかかった舟
03/03/16 03:07
>>21
>>22に禿同なんだが、

>>17
$res = pg_query($conn, $sql);$encounter_nu,
って構文がおかしいだろ!
その後ろにecho $sql;なんて入れてるからエラーが出るんだYO


24:nobodyさん
03/03/17 01:36
ちょっとすいません、テーブルのしつもんです
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
TABキーが使えんのか....


26:nobodyさん
03/03/17 02:26
マニュアルのデータ型の説明のところに載ってるよ。
intはintegerと同じ
varcharは長さ制限無しらしい。

27:nobodyさん
03/03/17 02:29
>26
ありがとさん

28:nobodyさん
03/03/18 01:14
4/1まで不在
キタキタキタ━━(∀゚=゚∀゚=゚∀)━━!!!!!!!

29:nobodyさん
03/03/18 01:16 iRf6zAa0
サゲタ━━━ヽ(゚Д゚)ノ━━━ !!!!!

30:nobodyさん
03/03/19 18:10 8OO+f4X+
みなさまは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
su -c "pg_dump 〜" postgres
をcronに仕込んだ気がする。

32:あぼーん
あぼーん
あぼーん

33:nobodyさん
03/03/19 18:33
* 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 zYXO3E0g
私は >>33 のスクリプトを、postgres スーパーユーザの cron で実行してる。
0 6 * * * nice -19 /home/postgres/pgd.sh

みんなはどうしてる?

35:nobodyさん
03/03/19 20:08 8OO+f4X+
>>33
なるほどぉ、漏れの場合は出来れば3日分のバックアップログを
取っておいて、4日前のバックアップは削除するみたいな機能を
付けたいのです。そうなるとPerlが使えると楽なんだけどなぁ。
ああ、なんで出来ないんだ??
シェルスクリプトでも出来るんだろうけど。。。。

36:nobodyさん
03/03/19 20:15
>>35
logrotate使えば?

37:nobodyさん
03/03/19 20:27 8OO+f4X+
>>36
サンクスでし。
logrotateとはこんなモンなんでしね。勉強すます。
URLリンク(www16.u-page.so-net.ne.jp)

38:nobodyさん
03/03/19 23:52
>>30
なんで .cgi なのかワカランが。
その手のコンソールから OK で cron からダメってのはたいてい環境変数。
cron 実行時は .bash_profile とかは読まないから。
crontab の中で環境変数設定できるから、man 5 crontab せい。

39:nobodyさん
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時になってしまいます。

これは↑のうちのどこが悪いのでしょう?


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

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