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/
00021C
03/03/11 02:40ID:???日本PostgreSQLユーザー会
http://www.postgresql.jp/
PostgreSQL7.1マニュアル全文検索
http://osb.sra.co.jp/PostgreSQL/Manual/cgi-bin/namazu.cgi
0003nobodyさん
03/03/11 13:56ID:???あのあとvacuum analyze とかやってたら
1.7秒くらいになりました。
以前はあったindex scanが逆に全くなくなってしまったのが不思議です。
explainで見るとHash Join、Hash Condばかり、ほとんどHashです。
また、order byの有る無しで時間が全く違っています。
無しにすると1秒縮まるのでソートに1秒かかってるようです。
並べ替えないわけにもいかないし・・・
0004nobodyさん
03/03/11 18:56ID:mhiQ8bxf必要な列は全部指定しておく。
列の指定順序に要注意。
JOINしてる場合も、各テーブルに
つけておく。
これで改善されないか?
0005nobodyさん
03/03/11 23:59ID:???メモリが開放されない?
0006あぼーん
NGNG0007nobodyさん
03/03/15 00:37ID:qfIx2KLLhttp://www.postgresql.com/
日本 PostgreSQL ユーザー会
http://www.postgresql.jp/
PostgreSQL7.2.3日本語ドキュメント
http://www.postgresql.jp/document/pg721doc/
PostgreSQLメーリングリスト(pgsql-jp)
http://www.postgresql.jp/PostgreSQL/pgsql-jp.html
改訂第3版 PC UNIXユーザのためのPostgreSQL完全攻略ガイド (シーラカンス本)
http://www.gihyo.co.jp/books/syoseki.php/4-7741-1226-7
石井達夫氏の PostgreSQL information page
http://www.sra.co.jp/people/t-ishii/PostgreSQL/
CSE - Common SQL Environment の つみき Web
http://www.hi-ho.ne.jp/tsumiki/
0008nobodyさん
03/03/15 13:37ID:YPCssbUzサンクス
PHPとPostgreSQLの事で質問したものです。
PHPの方のmultipart文字コード変換ルーチンがバグってました、
ところでPHPの便利な検索サイトで"PHPマニュアル全文検索"
というのを重宝してるんですが
http://apollo.u-gakugei.ac.jp/man/php/namazu.cgi?query=php-mode&submit=Search%21&whence=0&max=50&result=normal&sort=score
PostgreSQLでこんなサイト知らない?
マニュアルは見るのですが探すのに時間かかるんで
"PHPマニュアル全文検索"だと文字を打ち込んでボタン一発でマニュアルの中を検索してくれるんでとってもいいのだ。
0009前スレ998
03/03/15 16:09ID:V2aA/g1wPostgreSQL7.1マニュアル全文検索
http://osb.sra.co.jp/PostgreSQL/Manual/cgi-bin/namazu.cgi
7.2.3 の検索をしたければ、自分で Namazu の検索を構築してね。
Namazu はそんなに難しくない。
0011nobodyさん
03/03/15 17:22ID:YPCssbUz>9
>10
すまんですたい
やっぱPostgreSQLにもおなじもんがあったんですね
0012nobodyさん
03/03/15 23:37ID:???ここにいくと、php も PostgreSQL7.2.3 も検索できます。
0013nobodyさん
03/03/15 23:51ID:???0014nobodyさん
03/03/16 01:10ID:MfieTvGJCREATE 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 );",
よろしくね
0015nobodyさん
03/03/16 01:17ID:???0016nobodyさん
03/03/16 01:41ID:???エラーとはちょっと違うけどな。
なんにせよ、echo $sql で確認汁
0017nobodyさん
03/03/16 02:09ID: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の使い方がおかしいのだろうか?
0018nobodyさん
03/03/16 02:14ID:???問題の切り分けが全然できてないじゃん。
0020nobodyさん
03/03/16 02:19ID:MfieTvGJらじゃ
0021nobodyさん
03/03/16 02:34ID: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);
0022nobodyさん
03/03/16 02:38ID:???0023乗りかかった舟
03/03/16 03:07ID:???>>22に禿同なんだが、
>>17の
$res = pg_query($conn, $sql);$encounter_nu,
って構文がおかしいだろ!
その後ろにecho $sql;なんて入れてるからエラーが出るんだYO
0024nobodyさん
03/03/17 01:36ID:???CREATE TABLE t_hoge (
numberint,
namevarchar(80),
sexvarchar(6),
phoneint,
mailvarchar(50),
);
CREATE TABLE t_hoge (
numberint,
namevarchar,
sexvarchar,
phoneint,
mailvarchar,
);
こうして変数のサイズを明示しなかった時に
intとvarの変数の大きさをPostgreSQLはどれくらいの確保してるの?
0025nobodyさん
03/03/17 01:38ID:???0026nobodyさん
03/03/17 02:26ID:???intはintegerと同じ
varcharは長さ制限無しらしい。
0027nobodyさん
03/03/17 02:29ID:???ありがとさん
0028nobodyさん
03/03/18 01:14ID:???キタキタキタ━━━(∀゚=゚∀゚=゚∀)━━━!!!!!!!
0029nobodyさん
03/03/18 01:16ID:iRf6zAa00030nobodyさん
03/03/19 18:10ID:8OO+f4X+CRONでシェルスクリプトとか起動させてやってるんでしょうか?
漏れはシェルスクリプトとか分からないもんで、適当なperl
書いてそいつをユーザpostgresのCRONで起動してやってみた
んだけどうまくいかないんす。
そのスクリプトは簡単に書くと下記の感じなんですけど
(backup.cgi)
#!/usr/bin/perl
`pg_dump データベース名 > /usr/local/pgsql/backup/backup.out`;
普通にコンソールから./backup.cgiと直接起動させると出来るんだけど
CRONからの起動だと0バイトのファイルが出来るのみ・・・?
0031nobodyさん
03/03/19 18:23ID:???をcronに仕込んだ気がする。
0032あぼーん
NGNG0033nobodyさん
03/03/19 18:33ID:???#/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}
003433
03/03/19 18:37ID:zYXO3E0g0 6 * * * nice -19 /home/postgres/pgd.sh
みんなはどうしてる?
0035nobodyさん
03/03/19 20:08ID:8OO+f4X+なるほどぉ、漏れの場合は出来れば3日分のバックアップログを
取っておいて、4日前のバックアップは削除するみたいな機能を
付けたいのです。そうなるとPerlが使えると楽なんだけどなぁ。
ああ、なんで出来ないんだ??
シェルスクリプトでも出来るんだろうけど。。。。
0037nobodyさん
03/03/19 20:27ID:8OO+f4X+サンクスでし。
logrotateとはこんなモンなんでしね。勉強すます。
ttp://www16.u-page.so-net.ne.jp/xb4/katsumi/os/linux/root/logrotate.html
0038nobodyさん
03/03/19 23:52ID:???なんで .cgi なのかワカランが。
その手のコンソールから OK で cron からダメってのはたいてい環境変数。
cron 実行時は .bash_profile とかは読まないから。
crontab の中で環境変数設定できるから、man 5 crontab せい。
0039nobodyさん
03/03/21 22:44ID:???「2ちゃんだから」って理由での態度ならなおさら。
そういう人は何やらせてもダメそう。
せっかく>>33のスクリプト見せてもらってるのに
それに4日前のバックアップを削除する機能すら付け加えられない無能くん。
せいぜいlogrotateくらいはまともにつかえるようにがんがってね。ハート
0040あぼーん
NGNG■ このスレッドは過去ログ倉庫に格納されています