PostgreSQL 2テーブル ..
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"じゃないかな。
426:421
05/02/01 18:31:46
>>422-424
ありがとうございました。
PostGre使い出したのは最近なので、このvacuumにてこずってます。。。
1日1回vacuumdb -a を実行するとして、その間、みなさんはhttpdを落としたりしてますか?
ちょっと前、vacuumdbをアクセスが少ない時間帯に自動で実行させてそのままほっといてたら、
物凄く時間がかかった上に、DBエラーがでまくりで、とても公開できたもんじゃありませんでした。。。
(2〜3時間ぐらいはアクセスできない状態が続いていていました。)
参考までに、vacuumdbにどのぐらいの時間がかかるものなのか教えてくださいm(_ _)m
427:nobodyさん
05/02/08 18:04:40
4.27) どのような暗号化オプションを利用できますか?
URLリンク(www.postgresql.org)
> サーバーを走らせるのに暗号化ファイルシステムを使うこともできます。
は何を指しているのでしょうか?cryptfs? 実績はありますか?
428:nobodyさん
05/02/18 21:22:36 RLTHZ6TX
今、phppgadminを使っているんですが、
これってテーブルの中身のデータを検索するのって
出来ないんですか?
どうも検索システムを使っても、テーブル名しか
検索していないようなんですが…
429:nobodyさん
05/02/19 06:45:44 nMzWTz6R
>>428
SQL発行じゃダメなのか?
430:nobodyさん
05/02/19 19:15:51 gwEGKWwx
>>429
たとえば、検索して、その中からいくつかをチョイスして削除とか
そういうのをグラフィカルに出来たらいいなあ、と思うのですが。
今はSQLを発行してやってます。
431:nobodyさん
05/02/20 00:15:29
Postgresをpg_hda.confで各DBにアクセス制限をかけているのですが、
phpPgAdminでどれか一つのDBへアクセスできると、他のDBにも
アクセスできるようになってしまいます。
各DBを完全に独立させるのはどのような設定を行えばよいのでしょうか。
ご教示いただけますと助かります。
432:nobodyさん
05/02/20 01:47:50
pg_hda はソケットレベルでの接続を制御するもの
DB毎にアクセスを制御したければ SQL の grant でスキーマレベルでの権限を設定する
433:nobodyさん
05/02/28 02:38:12
ちょっと聞いてみたい。
一回ページを表示するのに多いとこで何回くらいクエリ投げてる?
というか何回くらい投げてたら多いと思う?
434:nobodyさん
05/02/28 03:11:15
50回くらい投げてたら多いと思うね。
435:nobodyさん
05/02/28 21:12:21 43Vt3CIQ
select now() - (select max(date_create) from counter);
というSQLで出る18:11:08.696398という時間を、秒数(60*
60*18+60*11+8)に変換して出したいのですが、何かやり方
はございますでしょうか。
ご教授いただけますと幸いです。
436:nobodyさん
05/03/01 05:54:49
環境:MacOSX10.3.8
PostgreSQLの7.4.7(7.4.6でも同じ症状)をインストールしてinitdb --encoding=EUC-JP --no-localeで初期化しようとすると、
initializing pg_shadow... FATAL: XX000: failed to initialize lc_messages to ""
LOCATION: InitializeGUCOptions, guc.c:1867
というエラーメッセージが出てしまう。
googleでML等を調べまくってイヤという程某氏のマルチポストを眺めながら解決法を調べましたが、
全然うまくいきません。お願いします。力を貸して下さい。
(--debug付きの場合)
(前略)
DEBUG: start transaction
DEBUG: close relation (null)
DEBUG: commit transaction
(中略)
DEBUG: start transaction
DEBUG: commit transaction
DEBUG: start transaction
DEBUG: commit transaction
DEBUG: proc_exit(0)
DEBUG: shmem_exit(0)
DEBUG: exit(0)
ok
initializing pg_shadow... FATAL: XX000: failed to initialize lc_messages to ""
LOCATION: InitializeGUCOptions, guc.c:1867
initdb: failed
437:nobodyさん
05/03/04 15:47:39 S8fbJs1c
alter user postgres with password '';
でpostgresのパスワードを無しにしたのですが、こう設定した場合、
postgresユーザでのDB接続は出来なくなると考えて宜しいので
しょうか。
pg_hba.confでは
local all all md5
host all all 127.0.0.1 255.255.255.255 md5
local all all reject
host all all 127.0.0.1 255.255.255.255 reject
と設定済みです。
438:nobodyさん
05/03/10 20:07:41
pgbenchってやってます??みなさんどれくらいの値出ます??
ちなみにうち
pgbench -c 10 -t 100 bench
tps: 112 (including) , 113 (excluding) [Athlon XP-M 1700+,RAID1,RH7.3,psql7.2.4]
tps: 261 (including) , 264 (excluding) [Pentium4 2.83GHz,RAID1,RH9,psql7.3.4]
pgbench -c 10 -t 100 -S bench
tps: 1925 (including) , 2290 (excluding) [Athlon XP-M 1700+,RAID1,RH7.3,psql7.2.4]
tps: 2907 (including) , 3253 (excluding) [Pentium4 2.83GHz,RAID1,RH9,psql7.3.4]
良いのか悪いのか全くわからん。
OpteronとかXeonだったらどれくらいいくんだろう。
ってか、pgbenchの結果を晒しあってるスレあったら誘導してくれ。。。
439:nobodyさん
05/03/13 15:32:22
Windowsネイティブ対応キタ━━━(゚∀゚)━━━ !!!!!
440:nobodyさん
05/03/18 19:32:34 NKwPelPw
一年生、男性、5人
二年生、女性、3人
というクエリー結果を
男性 女性
一年生 5人
二年生 3人
っていう風に見せたいときどうする?
やっぱPHPで加工するしかないのかな?
441:nobodyさん
05/03/18 21:00:03
case文つかえ
442:nobodyさん
05/04/22 12:41:11
>>30あたりでダンプの話題が出ていたようですが複数のDBがあるので
pg_dumpalを使ってみました。生成されたファイルをみてみると
最初の方で全てのDB分CREATE USERがしてあってそのあと全てのDB分
CREATE DATABASE "DB名"の様になっていましたが
ある一つのDBだけリストアしたい場合には
pg_dumpallから生成されたファイルは使えないのでしょうか?
@7.2.3です
443:nobodyさん
05/04/26 14:59:54
circle型のインサート構文がリファレンスに書いてないしぐぐっても出てこないので
誰か教えて下さい。
insert into table(field)values((0,0),1); とか
insert into table(field)values(GeometryFromText('Circle((0,0),1)')); とか
色々試してみたけどダメでした。
444:nobodyさん
05/04/26 16:19:41
>>443
INSERT INTO Table(field) VALUES(circle'((0,0),1)');
445:nobodyさん
05/04/26 16:27:20
>>443
おまけ。
INSERT INTO Table(field) VALUES('<(0,0),1>');
INSERT INTO Table(field) VALUES('0,0,1');
その他いろいろ... まぁバージョンによって認識してくれる書式に
多少の違いがあるかもしれん。
446:nobodyさん
05/04/26 18:18:09
pgadmin3のバグ(だと思う)報告。
適当なデータベースでテーブル(列は一つで主キーも無く名前・オーナー・テーブル空間・OIDを持つのみを設定)を作り、
データベース→使ったデータベース名→スキーマ→public→テーブル→作成したテーブル名
とたどり、テーブル名を右クリックしてプロパティを開く。
列タブに移動して唯一の列を削除して同一の名前の列(データ型は異なる)を追加する。
OKを押す→エラー発生(これは例外処理として正常だが)
ここでさきほど右クリックしたテーブル名を再び右クリックしてリフレッシュを選択。
その後再び列追加のOKを押すとpgadmin3が突然消える。
俺の環境ではこの操作でこの現象は100%再現する。
他にも細かいおかしな挙動がたくさんあったが忘れた。
(俺がpgadmin3使うの初めてなんでおかしな操作してるのかもしれない)
447:443
05/04/26 18:33:06
>>444-445
レスありがとう!助かりました。
448:nobodyさん
05/04/26 18:51:43
gistインデックスを作る際に指定するgist_geometry_opsには
比較演算子のセットを指示しろとpostGISのマニュアルに書いてあったけど、
&& << >> <^ >^ と書いたら&&の時点で怒られた。
何を書けというの?
せめて一つくらいコード例書いといてくれよ・・・>マニュアル
449:nobodyさん
05/04/26 18:53:01 x+Vlqkfm
ものすごくつまらないことを聞いてもいいですか?
今現在、postgresがオーナーになっているDBがありまして
他のユーザーをオーナーにしたい場合ってどうすればいいんでしょう?
450:nobodyさん
05/04/26 20:44:42
>>449
ALTER DATABASE database OWNER TO newowner;
451:nobodyさん
05/06/08 13:03:23
JNDIから取得したDataSourceでコネクションプーリングする方法を
教えてください。
452:nobodyさん
05/06/08 15:36:20
コネクションプーリングの実装は難しいから、自分でくまない方がいいとおもうけど。
JNDIからプーリングしてもらったコネクションを取得するようにしたほうがいいと思われ。
453:nobodyさん
05/06/08 21:49:29
普通にJNDIルックアップして取得したDataSourceって
ConnectionPool実装してないよね?
InitialContext ctx = new InitialContext();
DataSource ds = (DataSource)ctx.lookup("DataSourceName");
Connection conn = ds.getConnection();
ってな具合に普通にコネクション取ってるだけど
Jdbc3PoolingDataSourceとかでキャストすると落ちるし。
そもそもJNDIで定義してるDataSourceのクラスってどこ変更すりゃいいの?
ってか猛烈にスレ違いだなー
454:nobodyさん
05/06/08 22:33:26
普通にって、そりゃどこでどういう風にJNDIに登録してるかだろ。
コネクションプーリングしたコネクションをJNDIに登録して、それとってくればコネクションプーリングされてるだろ。
455:nobodyさん
05/06/08 23:15:34
DataSourceをJNDIに登録する時に、ドライバークラスはもちろん指定できるんですが
データソースのクラスまで指定する事ってできるんでしょうか?
指定しないで登録すると、デフォルトのjava.sql.DataSourceで登録しますよね。
456:nobodyさん
05/06/08 23:40:26
しらんよ、あんたの実装のことなんか。
457:nobodyさん
05/06/08 23:52:27
>>456
ですよね。
もうちょっと調べてみます。
458:nobodyさん
05/06/09 00:04:51
結局なにがしたいのか謎だったな。
WebならTomcatにまかせとけばいいし、気にすることないからなぁ。
459:nobodyさん
05/06/09 00:16:30
結局、JBoss使ってるんですけど、
DataSourceのJNDI定義するXMLをそのままデプロイすると
java.sql.DataSourceで登録されちゃうんでなんとかならないかなと思ってたんです。
この定義するXMLの中にDataSourceクラスを定義する
ディレクティブが無いんですよね。
460:nobodyさん
05/06/09 01:38:08
で、それはコネクションプーリングしてくれてないの?
461:nobodyさん
05/06/09 02:13:55
くれないです。
java.sql.DataSourceは、ConnectionPooling実装してないんで使い捨てですね。
してくれたら、このクラス、仕様どおりに動いて無い事になるので逆に困りますw
Factoryから自作してやろうかと思ったんですが危ないし、
その筋の人間の作ったJDBCドライバーかデータソースに完全に任せたいです。
462:nobodyさん
05/06/09 05:10:57
java.sql.DataSourceなんてないと思うのだが。
javax.sql.DataSourceはインターフェイスだからConnectionPooling実装してるとかしてないとか、関係ないと思うが。
というか、ConnectionPoolingって、インターフェイス?
463:nobodyさん
05/06/09 17:25:42
>>462
ですね。DataSourceはインターフェースです。
ConnectionPoolingっていうのは、仕組みなのでクラスでもインターフェースでもないです。
ちょっと検証できそうなものを見つけました。
URLリンク(www2b.biglobe.ne.jp)
464:nobodyさん
05/06/09 17:47:39
キッチリ解決しました。
MySQLの資料ですが、まんまいけるハズです。
URLリンク(kamakura.cool.ne.jp)
465:nobodyさん
05/06/09 22:11:26
つうか、JBossがわざわざJNDIに登録してるものが、コネクションプーリングしてないとは思えんのだが。
466:nobodyさん
05/06/16 02:31:27
質問させてください。
現在レン鯖の「speever」なる所でpostgreSQLを始めたのですがphpPgAdminが入ってたんで
tableの作成、テスト用データのinsertは上手くいってselectもできました。
ただ、webからphp経由で
$pgsql_conn = pg_connect("host=localhost port=5432 dbname=DB名 user=名前 password=パス");
とした時に$pgsql_connに何も入りません。
設定がいけないのかと思うのですがpg_hba.conf、postgresql.conf以外に何か設定ファイルがありましたら教えて下さい
いじったのはpg_hba.confがlocalだけだったので「host all all 127.0.0.1 255.255.255.255 trust」と
postgresql.confは#tcpip_socket = falseだったのをアンコメントしてfalseをtrueにしました
phpがver4.3.0
postgresがver7.3.2でした
467:nobodyさん
05/06/16 02:39:31
>>466
設定を変えたときPostgreSQLの再起動をした?
って言うか、貸鯖で設定ファイルを弄らしてくれるのかよ...
それよりもtcp/ipによる接続の必要性が無いのなら
UnixDomainSocketでいいんじゃね。
$pgsql_conn = pg_connect("dbname=DB名 user=名前 password=パス");
468:nobodyさん
05/06/16 02:42:30
>>467 こんばんわ
再起動は/etc/rc.d/initdからしました
なんかvps?とかで似非root権限があるそうです。
$pgsql_conn = pg_connect("dbname=DB名 user=名前 password=パス");
↑host=localhostでソケット通信かとおもてた、ちょっと試してきます
469:nobodyさん
05/06/16 02:50:33
>>467
だめでしたわ('A`)
if ($pgsql_conn) {
print "Successfully connected to database: " . pg_dbname($pgsql_conn) ." on " . pg_host($pgsql_conn) . "<br/>\n";
} else {
print pg_last_error($pgsql_conn);
print "ヽ(`Д´)ノ";
exit;
}
ヽ(`Д´)ノ←こんなん出力されたorz
470:nobodyさん
05/06/16 02:59:33
>>469
う〜ん。とりあえず、エラー表示が一切無いのも気になる。
スクリプトの先頭で
error_reporting(E_ALL);
ってすれば何かエラーでないか?
471:nobodyさん
05/06/16 14:44:13
>>470
すいません、php.iniを眺めてたらerr_display=Offになってた。
onにしてhttpd再起動したら
Warning: pg_connect() [function.pg-connect]: Unable to connect to PostgreSQL server: FATAL: Database "test_db" does not exist in the system catalog. . in /var/www/html/dddddd/db_test.php on line 3
どうやらweb鯖とdb鯖が別になってる…?
すいませんでした、いそいで吊ってきます
472:nobodyさん
05/06/16 17:18:41
>>471
そのエラー表示だと、DBそのものはローカルで動いていると思われ。
dbnameがおかしいんじゃね。
473:nobodyさん
05/06/30 04:40:53
どもです。はじめまして。
phpPdAdminの質問なのですが、特権一覧と言うところに「102」という
ユーザーがいるんですが、これは自動的に追加される何らかのユーザー
なのでしょうか??
SQLを直で覗いてユーザー一覧を見たのですが、
このユーザーはいませんでした。
phpPgAdminからしか認識できません。
どなたか知っている人がいましたら、アドバス願います。
474:nobodyさん
05/06/30 20:13:04 cHU+f8gL
アドバス願います。
475:nobodyさん
05/07/23 07:34:11 WyqF/aD4
RDBMS背負ったWebアプリを開発必要があり、
Perl、DBI、PostgreSQLの勉強を進めています。
要件がなかなかFIXしないため暫定的にスタートしなくては
ならない状態なのですが、運用途中でテーブルの「列」を増減させる事は
可能なのでしょうか。
あるいは新たな構造のテーブルを作り、データを移す、とかの方法になりますか?
476:nobodyさん
05/07/23 08:02:53
>>475
ALTER TABLE ADD COLUMN で可。
URLリンク(www.postgresql.jp)
477:nobodyさん
05/07/23 18:38:51
>>476
どうもありがとうございます。
このドキュメント、いいですね。
7.4.7なので近いバージョンのをじっくり読んでみようと思います。
478:nobodyさん
05/07/29 13:20:03 p5If7shl
郵政公社が公開している郵便番号データをテキストに変換
13101 102 1020072 トウキョウト チヨダク イイダバシ 東京都 千代田区 飯田橋
(空白はタブ区切り)
そのテキストをテーブルに取り込む際
>COPY test FROM "13tokyo.txt";
としたところ
invalid input syntax for integer
というエラーが表示され、うまくいきません。
なにが原因なのでしょうか?
Column | Type | Modifiers
---------+--------------+-----------
pubcode | integer |
zip5 | character(5) |
zip7 | character(7) |
pref_k | text |
city_k | text |
town_k | text |
pref_j | text |
city_j | text |
town_j | text |
よろしこ
479:nobodyさん
05/10/25 18:12:46 2GYRQ0/r
PostgreSQL8.0.3 を使ってWebアプリをJavaで構築してます。
ユーザーが入力した情報がtext型に入ってて、このカラムに対してキーワード検索をしたい、という
要件が入ってます。
普通にlike文で検索すれば良いと思うのですが、実際、レコード件数が最大で億を超えることが予想されるようです。
text型ですけど、1万文字の文字数チェックを入れる予定です。
この場合,like文ですとインデックスが当然きかないのでかなりの時間がかかる処理になってしまうと思います。
一般的にこのような場合はDBに頼らず別の仕組みをつかっているんでしょうか??
良くある会員サイトで使われている検索はlike文で頑張っているんでしょうかね?
まだシステム仕様変更をするための時間があるのでアドバイスいただけるとありがたいです。
480:nobodyさん
05/10/25 18:28:23
>>479
普通は「全文検索」モジュールなんかを使うんじゃないのか?
つ URLリンク(www.oss.ecl.ntt.co.jp)
481:nobodyさん
05/10/25 19:38:24
pg_rast, pg_senna あたりを勧めたいところだけど
>レコード件数が最大で億を超えることが予想されるようです。
ということなら Rast や Senna ではキツいですね。
Hyper Estraier は件数が増えても性能劣化しないように作られているけど
pgestraier は PostgreSQL のカラムに対するインデックス作成ができないので使えないわけで。
8.1 で導入されるテーブル・パーティショニングを使ってカテゴリごとにテーブルを分けるとかすれば
pg_rast や pg_senna でもいけるかな?
482:479
05/10/25 21:21:40 sIrMsQ6K
ありがとうございます。全文検索ですか。はじめて扱いますがドキドキですw
>>480で紹介されているTsearch2 はオープンソースとのことですが、
先に述べたレコード数ですとパフォーマンス劣化は大丈夫でしょうか。
>>481さんの内容ですと、Hyper Estraier というのがBestという感じでしょうかね…。
ともあれ、ありがとうございました。
483:nobodyさん
05/10/25 21:46:04
>>482
ちょっと説明不足でした。
Hyper Estraier というのはオープンソースの全文検索エンジンで、PostgreSQL とは直接関係ないものです。
で、PostgreSQL から Hyper Estaier のインデックスを検索できるように作られたのが pgestraier なわけだけど
これは検索専用で、登録・更新・削除ができないのです。
というわけで Hyper Estraier をそのまま使うのは不可能。
ただし Java バインディングがあるので、INERTと同時に全文検索インデックスへの登録も行うようにして
(この際、主キー相当の項目を属性として登録するのを忘れずに)SELECT のときは pgestraier を使うような
運用方法にすればいけないこともないと思われます。
Tsearch2 のスケーラビリティについてはよく知らないですが KAKASI を MeCab に置き換えたものを
作ってる人もおられるみたいですね。(KAKASI の今のバージョンは UTF-8 が扱えないので)
自分はというと登録・更新・削除もできる Hyper Estraier の PostgreSQL バインディングが出るか、
Rast か Senna のスケーラビリティが上がるまで様子見です。
484:479
05/10/25 22:38:46 sIrMsQ6K
>>483
さらに詳しい説明、感謝致します。
詳しくはHyper Estraieを調査すればわかるとおもいますが、一つだけ。
「インデックスへの登録」という部分は、たとえばText型に入る内容を
Hyper Estraierに対して投げる、という感じでしょうか。その属性にpkyを付加すると。
であれば、Hyper Estraierが持つであろうインデックスファイルなどは結構な量になると
思われますが、正しい認識でしょうか。データ量が多くになると、RDBMSとは別に
全文検索用のサーバーを用意するという運用体型になるって感じでしょうか。
なかなか楽しい世界ですね。ありがとうございます。
485:479
05/10/26 10:41:49
>>484 の補足というか。Hyper Estraierについて簡単に調べました。
要求に十分こたえられる仕様だと思っています。
紹介してくださってありがとうございました。
486:nobodyさん
06/02/13 18:56:37
OIDについて質問です。
あるテーブルでの一意性を保証したいのですが、
単純に該当テーブルのOIDに対してUNIQUEを指定してしまえばいいということなんでしょうか...?
PostgreSQL7.4を想定しています。
URLリンク(www.postgresql.jp)
OID は 32 ビット長であり、クラスタ全体で 1 つのカウンタから割り当てられます。
巨大な、または、長期間運用しているデータベースでは、カウンタが一周する可能性があります。
従って、OID が一意であることを前提とすることは、OID を一意にすることを保証する手段を講じていない限り非現実的です。
OID を使用して行の識別を行う推奨方法は、その OID が使用される各テーブルの OID 列に一意性制約を作成することです。
宜しくお願い致しますm(_ _)m
487:nobodyさん
06/03/07 20:45:26
>>486
serialでも使えば?
488:nobodyさん
06/04/29 23:20:03
DB板での書き込みを再掲させて戴きます。レスがつかなかったもので…orz
PostgreSQLを使って、下記のような処理を作ろうと考えています。
現在「特定テーブルのCSV出力」に何を使うかで悩んでいます。
ストアドプロシージャか、PHPを使うかの二択から選んでくれと言われたのですが、
クライアントアプリがこれらをキックすることを考えるとどちらが簡単でしょうか。
----------
クライアント:Windows(.NETで開発)
サーバ:RedHat Linux + PostgreSQL
やりたいこと。
1.通信はhttpのみ。
2.クライアントはサーバにアクセスして、
「特定テーブルのCSV出力」を命令する。<--------------(・ω・)
3.クライアントは処理の終了を待つ。
4.クライアントは出力されたCSVファイルをダウンロードする。
489:nobodyさん
06/04/29 23:29:08
>>488
.NETからストアドたたけるんだろうから、ストアドでやれば?
と思ったけど、httpのみかよ。
http通信で直接ストアドなんて呼べるのか?
結局phpでラップすることになるんではないかな。
490:nobodyさん
06/04/30 00:06:46
>>489
レスありがとうございます。
ADO.NETを使っていいものなら話は簡単なんですけどね…。
「セキュリティの観点」からダメだと言われてしまいました。
ちなみにPHPをキックすること自体は簡単にできるものでしょうか?
491:nobodyさん
06/04/30 00:21:53
>>488
なんの言語でやるのかしらんが、たとえばPHPでやるとして
*.csvファイルをPHPで処理するように関連付けて
*.csvファイルの中にcsv出力する[プログラム書いて
ヘッダーをtext出力にすればOk。
492:nobodyさん
06/04/30 04:22:25
>>490
> ちなみにPHPをキックすること自体は簡単にできるものでしょうか?
> 1.通信はhttpのみ。
なんだから、単純にphpのファイルにhttpアクセスするしかないのでは?
493:nobodyさん
06/05/08 08:53:52
>>491-492
了解しました。いかにも素人の質問に答えてくださってありがとうございます。
494:good
06/05/11 15:23:40 UxCS1jwo
PostgreSqlでdate型は、文字として認識されるようですが
仕様でしょうか?
たまに数値型で、抽出できたりするんですが、どうしてでしょう?
WK_SQL = WK_SQL & "(F1_RINYUYMD BETWEEN " & WK_DOU1 & " AND " & WK_DOU2 & ")
F1_RINYUYMD date型
495:nobodyさん
06/05/17 22:06:30 /QUzYdtQ
あるテーブルのint型の変数にNULLを代入しようとすると、
エラーではじかれてしまうのですが、
何がいけないのでしょうか?
charでは問題ありませんし、特にNULLがダメというわけでもないように思っているのですが、
そういうケースがあるんでしょうか?
496:nobodyさん
06/05/17 22:35:27
'NULL'ってやってるとか?
queryをダンプして貼ったらレスも付き易いかと。
497:nobodyさん
06/05/17 22:46:12
すみません、あまり経験も乏しいので説明が要領を得ないかもしれませんが、
insert into test(param) values('');
という感じです。(test というテーブルの param に代入)
実際には、COPYコマンドでファイルから代入しようとして蹴られます。
a,b,,,,c,,d, というようなデータ列で、','を区切り文字としています。
,, の部分がNULLとして扱われると思うんですが、
varchar(20)などでは問題ないのに、intのところでエラーが出ます。
それでコマンドラインでも試してみたところ、やはり同じエラーが出ました。
マニュアルなどでデータ型を見た限りだと、NULLでも問題なさそうに思うのですが、
何か操作上の間違いがあるのでしょうか。
あと、言い忘れていましたが、試しているのは Windows の psql です。
498:nobodyさん
06/05/18 00:46:59
>a,b,,,,c,,d, というようなデータ列で、','を区切り文字としています。
ここを
a,b,NULL, NULL, NULL,c, NULL,d,
みたいだとどうだろ(試してないけど
499:nobodyさん
06/05/18 01:27:13
>>497
COPY じゃ無くて \COPY を使っているとか?
COPYは ,, をNULLとして扱うようだけど、
\COPYは ,, を ""(空白文字列) として扱っている。
\COPY table FROM filename NULL ''
でいけるんじゃね?
> insert into test(param) values('');
''とNULLは別もんだよ。
500:497
06/05/18 02:19:43
>>499
うげ、そうだったんですか。
明日早速やってみます。
>>498
そういうのもありなんですか。
ただ、今やってるのは、他の人が用意したcsvをそのまま利用しているので、
そういうやり方だと何かしらのコンバートが必要になりますよね。
いずれにせよ、アドバイスありがとうございます。
501:nobodyさん
06/05/18 21:20:56
先週まで正常に動いていたPostgreSQL→phpのwebアプリが
突然にphpからの接続(insert処理)ができなくなりました。
ブラウザからINSERTを実行した際に
Warning: PostgreSQL query failed : no connection to the server
のエラーがクエリを吐いた回数分表示されます。
設定側pg_hba.conf、postgresql.confともに弄っていません、
またphpの方もバックアップとdiffをとりましたが変化ありませんでした。
また、バキュームしてみたら何か変わるかと思いSSHからvacuumdbを実行すると
FATAL 2: open of /var/lib/pgsql/data/pg_clog/0732 failed: そのようなファイルやディレクトリはありません
server closed the connection unexpectedly
This probably means the server terminated abnormally
before or while processing the request.
connection to server was lost
vacuumdb: vacuum xxxxxxxx failed
と言われました。
postgresの再起動もしてみましたが「postmaster ok」と通常通り立ち上がっているんですが…。
ブラウザから同じtableにselectを発行すると正常に値をとれます、selectもinsertもDBの接続処理は同じ関数つかってるのに…。
接続は以下のようにしています
function db_conect () {
global $CON;
$CON = pg_connect ("dbname=xxxx user=yyyyyyyyyyy");
}
長々すいません、バージョンは7.2.3です、アドバイスください
502:497
06/05/18 22:12:42
今日やってみたところ、期待通りの動作をしました。
とても助かりました。
どこのどなたか存じませんが、ありがとうございました。
503:nobodyさん
06/05/19 10:16:13 S+/mH4DM
8.1ってiモードの絵文字(外字領域)使えますか?
DBはEUC_JPで構築しています。
504:nobodyさん
06/07/19 22:01:12 6lmDHlcw
バイナリ本体は/usr/local/pgsqlに置いて、DBを/home/pgsql/varに置くようにコンパイルってどうすればできますか?
505:nobodyさん
06/07/19 22:17:41
>>504
initdb & PGDATA
506:504
06/07/20 23:55:57
なんだ、コンパイルのオプションと違ったんだ。
ありがと。
507:nobodyさん
06/07/22 00:36:09 TflzrAiN
URLリンク(pgfoundry.org)
ここからダウンロードしたODBCだと文字化けするんだけど、何かご存じないですか?
鯖が7.4で、EUC-JP
クライアントはAccessとCSEで確認して化けらったです。
SET CLIENT ENCODINGはためしてみました。
以前に片岡さんのほうのドライバいれてました。
バージョンアップしてみたのは、numeric型を認識してくれないのと、
ADOでトランザクションの発行がうまくいかなかったからです。(´・ω・`)
508:nobodyさん
06/07/22 00:37:57
>>507
URLリンク(www.geocities.jp)
を使いましょう
509:nobodyさん
06/07/22 07:31:10
○○日間アクセスしてないユーザを削除する、という処理をさせたいんですが
Postgresだけでこれを実現する機能があれば教えてください
(OSの方で定期的にスクリプトを実行するのが普通なんでしょうか?)
510:nobodyさん
06/07/22 17:56:12
cronかアクセスがあるごとに削除クエリ実行するしかないだろう
511:509
06/07/22 18:14:09
やっぱりそうですよね。。。ありがとうございました
512:nobodyさん
06/08/01 18:36:35
client_encodingのことで質問です。
eucで書いたperlプログラムから、DBIを使ってWindows版のPostgreSQL8.1.4のDBに接続しています。
postgresql.confのclient_encodingの指定はコメントアウトしています。接続先のDBはEUC_JPです。
別のPCのPostgreSQL8.1.4のDBから、pd_dumpで書き出したeucテキストのダンプデータを、
psqlを使用して取り込もうとしたところ、invalid byte sequence for encoding "SJIS" というエラーが
出てしまい、調べましたら、psqlのクライアントエンコーディングがSJISに設定されていることがわかりまして、
ダンプデータの中に SET CLIENT_ENCODING TO 'EUC_JP' という1文を入れたところエラーは出なく
なりました。ところが、今度は取り出したデータがSJISになってしまいました。
CGIプログラムも出力するhtmlのコードもEUCなので、すべてをEUCで統一できればと思うのですが、
どこを設定すればよいですか? どなたか教えてください。
513:nobodyさん
06/08/01 18:45:57
自己レスですorz
接続した直後に set client_encoding to 'EUC_JP' をすればいいだけでした。
お騒がせしました。
514:nobodyさん
06/08/02 12:41:10 IBuG4Wqs
2GBくらいある巨大テーブルがあって、
けっこう複雑なクエリを、いろんな方向からかけるので、
どうしてもseqが走ってしまって、遅くなって困ってます。。
8.1のテーブルパーティショニングを試してもみたんですが、
オプティマイザがバカになって使えないし。。。
殆どがディスクI/O待ちなのですが、こういうときどういった対策があるでしょうか。
どなたか助けて下さい(´・ω・`)
515:nobodyさん
06/08/02 14:08:15
>>514
explainやったの?
516:514
06/08/02 14:47:09 IBuG4Wqs
はい。そのへんの対策はだいたい。
517:nobodyさん
06/08/02 18:06:07
>>516
なんでそれで修正できないんだ?
explainでseqになってるところにindexはるなり、テーブル分割するなり
したら基本的に全部なくせるはずだけど?
518:514
06/08/04 12:12:04 dYxM1faY
>>517
集計関数が多いことが、大きな理由だと思います。
様々な角度で切り込まないといけないので、
中間テーブルを作るとなると膨大な量になってしまって。。。
519:nobodyさん
06/08/04 12:24:10
>>518
で、結局君は何を求めてここに書いているわけ?
どんなテーブル構造になってるかも分からない、seq になる SQL も分からない。
それで、何をどうアドバイスしろ、と。
一言で言うと、「知らんがな」
520:nobodyさん
06/08/22 09:04:21
以下を実行したいのですが, centosに最初に入っているPostgreSQLの
データベースクラスタがあるために、うまくinitdbできません。
(template0と1がSQL_ASCII固定のまま)
initdb --encoding=UNICODE --no-locale
どうすればデータベースクラスタを完全に削除できるのでしょうか?
UNICODEについては, createdb -E UNICODEでもできるのですが,
やはりinitdbで設定したいです.
PostgreSQLを終了させて, ./dataを削除したりしましたが,
キャッシュ?されているらしく完全削除ができない状況です....
521:nobodyさん
06/08/22 14:03:02
make install
522:nobodyさん
06/10/21 02:59:30
こんばんわ
URLリンク(www.postgresql.jp)
にあるALTER TABLEのSET DEFAULTについてなんですが、psqlから
ALTER TABLE xxxxx ALTER res_insert SET DEFAULT timestamp;
を発行した所
ERROR: column "timestamp" does not exist
とカラム名res_insertを指定いるつもりが
timestampというカラム名を指定するクエリになってしまっているようなんですが
この状態で何か抜けてますでしょうか?
----------------
SELECT version();
version
----------------------------------------------------------------------------------------------------
PostgreSQL 7.4.13 on i686-pc-linux-gnu, compiled by GCC gcc (GCC) 3.4.6 20060404 (Red Hat 3.4.6-3)
(1 row)
523:nobodyさん
06/10/21 03:53:49
current_timestamp のことではなくて?
524:nobodyさん
06/10/21 03:59:12
>>523
タイプミスしないように¥dで表示されるTypeの項目から拾ってきちゃってた…
せめて"そんなデフォルトは指定できません"的なエラー吐いてくれれば…
ありがとうございました
525:nobodyさん
06/10/23 04:52:02
先輩が書いたコードを読んでたら
SELECT * from xxtablexx where xxcomunxx 〜 '^[ま-も]' ;
というqueryが書いてあったんですが、〜 '^[ま-も]'の【〜】の意味が分かりません、マニュアル等に載ってますでしょうか?
526:nobodyさん
06/10/23 09:04:41
>>525
POSIX正規表現なんじゃないの?
527:nobodyさん
06/10/23 18:03:17
hogeテーブルに各種データとtimestamp型でInsertされた日付が格納されているんだけど
日付=todayのように日付でみるんじゃなく、「何時間以内」という様な指定でデータを取得することは可能ですか?
@7.4です
528:nobodyさん
06/10/23 22:26:23
>527
intervalでマニュアルを検索しる。
529:nobodyさん
06/10/25 09:54:38 X5/anJFE
select * from (select * from aaa order by bbb limit 1) as ccc;
↑これは動くのですが
delete from aaa order by bbb limit 1;
delete from (select * from aaa order by bbb limit 1) as ccc;
↑これらは動きません
構文エラーがでてしまいます。
(syntax error at or near "(" at character 13)
一体何がダメなのか、どなたか教えて頂けませんか?宜しくお願いします。
やりたいことは、bbbで昇順した上位1件を削除です。
(環境:windowsXP、postgres8.1.4)
530:nobodyさん
06/10/25 12:03:50
>>529
根本的にSQLが間違ってる、って思わない訳?
531:nobodyさん
06/10/26 00:18:23 PySunuHV
やはりそうですか。。
答えが見当たらなかった為、
今はselectで取得したキーを使って、
変数に格納してから、deleteを発行しなおしてます。
動作が遅くなりそうな気もしますが。。。
532:nobodyさん
06/10/26 00:38:43
>>531
つか、普通はサブクエリを利用してDELETEするにしても、
ちゃんと削除対象のテーブルをFROMに指定するもんじゃないのか?
>>529の例で言えば、
delete from aaa where pk_on_aaa = (select pk_on_aaa from aaa order by bbb limit 1);
とかさ。
533:nobodyさん
06/10/26 03:54:14 PySunuHV
>>532
ありがとうございます!解決しました。
副問い合わせの使い方が間違っていたのですね。
selectでは動くので、deleteではできないのかと思ってしまってました
結構googleでも検索したんですけど、見つかりませんでした(泣)
はまると、何にも進んでないのに2〜3日経っちゃいますねw
サブクエリで探して、以下のサイトを参考にしました。
もっと良いサイトもあるのでしょうけど、見つかりません^^;
URLリンク(www.istudy.ne.jp)
個人的には以下のサイトで見つけたいのですが。。
URLリンク(osb.sra.co.jp)
534:nobodyさん
06/10/26 16:41:56
>>533
なんかそれ以前の問題。
汎用的なSQL入門本でも買って読んだら。
2〜3日ありゃ十分読めるし、基礎だけでも
身に付けたほうが後々楽。
535:nobodyさん
06/10/27 09:56:45
>>533
自分も「それ以前の問題」だと思う。
君が見付けたいサイトでは
URLリンク(osb.sra.co.jp)
をよく読めば良い。
536:nobodyさん
06/10/27 13:03:00 C3DTFplx
>>534
>>535
ほんとありがとうございます^^
SQL入門書を買ってみることにしましたw
前にPHPの本を買ったんですが、
どうやらUNIXの本だったようで、間違ってました><
今回からはネットで調べて買おうと思ってます。
今は、以下に狙いを定めてたりしますw
URLリンク(www.amazon.co.jp)
537:nobodyさん
06/10/28 00:20:10 IIQMBUcS
Postgres の列制約で、後から unique を定義することは出来ますか?
538:nobodyさん
06/10/28 01:30:04
>>537
できる
539:nobodyさん
06/10/28 10:55:59
>>538
バージョンは8.1なんですけど、持ってるの古い本で
その中では出来ないとか書いてあって、ネットで調べても出来ないって
あったんですけど
なんかそのあたりを書いてあるページを教えていただけないでしょうか
540:nobodyさん
06/10/29 12:06:54
>>539
URLリンク(osb.sra.co.jp)
の5.5.3. 制約の追加に
もろに
ALTER TABLE products ADD CONSTRAINT some_name UNIQUE (product_no);
って〜のがあるんだが、
オマイはどこで
「列制約で、後から unique を定義することは出来ない」
って見たんだ?
マニュアルを先に読むクセつけな。
541:nobodyさん
06/10/29 22:53:31 N1q0Xlu3
ヒントだけでもお願いできたら嬉しいのですが、
id | day | number
----+---------------------+--------
1 | 2006-09-01 10:10:00 | 30
2 | 2006-09-15 10:10:00 | 30
の様なテーブルが有ってday+number(日)を足した結果が2006-10、つまり今月になるものだけを抽出指定のですがどうすればいいでしょうか。
よろしくお願い致します。。
542:nobodyさん
06/10/30 00:43:48
じゃ、ヒントだけ
template1=# SELECT '2006-09-01 10:10:00'::TIMESTAMP + '30 days'::INTERVAL;
?column?
---------------------
2006-10-01 10:10:00
(1 row)
543:539
06/11/03 00:27:31
>>540
ありがとうございました
おっしゃるとおりです、以後気をつけまする
助かりました
544:nobodyさん
06/11/03 16:57:01
541に便乗なんですが
insert | status
----------------------------+--------
2006-10-25 22:02:56.825435 | 2
2006-11-03 01:09:08.135099 | 1
なtableで
insertが当日のものだけとりたくて
SELECT insert,status from sns_message where insert < LOCALTIMESTAMP + '1 days'
SELECT insert,status from sns_message where insert < current_timestamp + '1 days'
等やってみたけれど、今日のレコードじゃなくてもSELECTできちゃうんですが…。
日付の大小見るときに不等号記号は有効ですよね?
545:nobodyさん
06/11/03 19:25:10
>>544
WHERE句で
TO_CHAR(insert,'yyyy/mm/dd') = TO_CHAR(current_timestamp,'yyyy/mm/dd')
すれば今日のデータだけ取れるだろ。
546:544
06/11/03 23:36:51
>>545
ごめんなさい、insertされてからX日以上たったレコードのstatusに操作を加えたいのです。
上記コードはその過程で「insert後一日以上たったレコード」をSELECTしています
547:nobodyさん
06/11/04 00:00:46
SELECT insert,status from sns_message where insert < current_timestamp + '1 day'
とか
SELECT insert,status from sns_message where insert < (select current_timestamp + '1 day')
とかは試してみた?
548:544
06/11/04 00:25:07
>>547
試しましたが何日前のレコードでもSELECTされてしまいました。
SQLは日付なんかも結構柔軟に扱えそうなんですがスキル不足で…。
とりあえずはこのまま全件とってきてスクリプト側(PHP使ってます)で判定するようにしてみます
ありがとうございました
549:nobodyさん
06/11/04 00:39:28
つーか、列名に insert はないだろ。
結局「今日」のデータがとりたいのか「X日以上経った」データをとりたいのかも分からん。
550:544
06/11/04 00:50:26
>>549
最初、予約語だからダメだろうと思ったんですが試しにCREATE TABLEで使ってみたら通ったのでそのままでした。
最終的にとりたいのは「X日以上経った」データですが、いきなりだと難しいそうなので
「今日中に」INSERTされたデータをSELECTしようとしてみたりしました。
551:nobodyさん
06/11/04 00:54:56
「テーブル作成 & テストデータ数個 INSERT」の SQL 書いてくれれば
試してみても良いけど
552:544
06/11/04 01:30:06
>>551
ありがとうございます、こんな感じです
--------------------
CREATE TABLE sns_message (
message_id int,
m_to int,
m_from int,
insert timestamp,
status smallint
)
INSERT INTO sns_message VALUES (1,111,555,'2006-11-4',1);
INSERT INTO sns_message VALUES (1,111,555,'2006-11-3',1);
INSERT INTO sns_message VALUES (2,111,444,'2006-09-11',1);
INSERT INTO sns_message VALUES (3,111,333,'2006-10-11',1);
---------------------
これで作成、やりたい事は
「insertされて3日たったてるレコードはstatusを9に」することです
Cronで一日一回実行するPHPで使う予定ですが"insertされて3日たったてるレコード"のSQLで詰まってます。
553:544
06/11/04 01:32:15
>>552
あうあー、2個目のINSERT文、IDが被っちまいました…
正しくは
----------
INSERT INTO sns_message VALUES (1,111,555,'2006-11-4',1);
INSERT INTO sns_message VALUES (2,111,555,'2006-11-3',1);
INSERT INTO sns_message VALUES (3,111,444,'2006-09-11',1);
INSERT INTO sns_message VALUES (4,111,333,'2006-10-11',1);
---------------------
です。
554:nobodyさん
06/11/04 01:45:34
>>552
「3日たったてる」の箇所が曖昧だが、さっき(11/04)試したら
test=# select * from sns_message;
message_id | m_to | m_from | insert | status
------------+------+--------+---------------------+--------
1 | 111 | 555 | 2006-11-04 00:00:00 | 1
2 | 111 | 555 | 2006-11-03 00:00:00 | 1
3 | 111 | 444 | 2006-09-11 00:00:00 | 1
4 | 111 | 333 | 2006-11-07 00:00:00 | 1
5 | 111 | 333 | 2006-11-08 00:00:00 | 1
(5 rows)
test=# select * from sns_message where insert > current_timestamp + '3 day';
message_id | m_to | m_from | insert | status
------------+------+--------+---------------------+--------
5 | 111 | 333 | 2006-11-08 00:00:00 | 1
(1 row)
となっていますが、何か問題あり?
次ページ最新レス表示スレッドの検索類似スレ一覧話題のニュースおまかせリスト▼オプションを表示暇つぶし2ch
5366日前に更新/193 KB
担当:undef