[表示 : 全て 最新50 1-99 101- 201- 301- 401- 501- 601- 2chのread.cgiへ]
Update time : 05/09 11:31 / Filesize : 193 KB / Number-of Response : 651
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

PostgreSQL 2テーブル目



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

前スレ
[PostgreSQL]
pc2.2ch.net/test/read.cgi/php/989375812/

☆関連スレッド
[PHP + PostgreSQL]
pc2.2ch.net/test/read.cgi/php/983128806/
[PerlでPostgreSQL]
pc2.2ch.net/test/read.cgi/php/999249463/
[MySQL vs PostgreSQL]
pc2.2ch.net/test/read.cgi/php/989341364/



451 名前:nobodyさん mailto:sage [2005/06/08(水) 13:03:23 ID:???]
JNDIから取得したDataSourceでコネクションプーリングする方法を
教えてください。


452 名前:nobodyさん mailto:sage [2005/06/08(水) 15:36:20 ID:???]
コネクションプーリングの実装は難しいから、自分でくまない方がいいとおもうけど。
JNDIからプーリングしてもらったコネクションを取得するようにしたほうがいいと思われ。

453 名前:nobodyさん mailto:sage [2005/06/08(水) 21:49:29 ID:???]
普通にJNDIルックアップして取得したDataSourceって
ConnectionPool実装してないよね?

InitialContext ctx = new InitialContext();
DataSource ds = (DataSource)ctx.lookup("DataSourceName");

Connection conn = ds.getConnection();

ってな具合に普通にコネクション取ってるだけど
Jdbc3PoolingDataSourceとかでキャストすると落ちるし。

そもそもJNDIで定義してるDataSourceのクラスってどこ変更すりゃいいの?
ってか猛烈にスレ違いだなー

454 名前:nobodyさん mailto:sage [2005/06/08(水) 22:33:26 ID:???]
普通にって、そりゃどこでどういう風にJNDIに登録してるかだろ。
コネクションプーリングしたコネクションをJNDIに登録して、それとってくればコネクションプーリングされてるだろ。

455 名前:nobodyさん mailto:sage [2005/06/08(水) 23:15:34 ID:???]
DataSourceをJNDIに登録する時に、ドライバークラスはもちろん指定できるんですが
データソースのクラスまで指定する事ってできるんでしょうか?

指定しないで登録すると、デフォルトのjava.sql.DataSourceで登録しますよね。



456 名前:nobodyさん mailto:sage [2005/06/08(水) 23:40:26 ID:???]
しらんよ、あんたの実装のことなんか。

457 名前:nobodyさん mailto:sage [2005/06/08(水) 23:52:27 ID:???]
>>456
ですよね。
もうちょっと調べてみます。



458 名前:nobodyさん mailto:sage [2005/06/09(木) 00:04:51 ID:???]
結局なにがしたいのか謎だったな。
WebならTomcatにまかせとけばいいし、気にすることないからなぁ。

459 名前:nobodyさん mailto:sage [2005/06/09(木) 00:16:30 ID:???]
結局、JBoss使ってるんですけど、
DataSourceのJNDI定義するXMLをそのままデプロイすると
java.sql.DataSourceで登録されちゃうんでなんとかならないかなと思ってたんです。

この定義するXMLの中にDataSourceクラスを定義する
ディレクティブが無いんですよね。




460 名前:nobodyさん mailto:sage [2005/06/09(木) 01:38:08 ID:???]
で、それはコネクションプーリングしてくれてないの?

461 名前:nobodyさん mailto:sage [2005/06/09(木) 02:13:55 ID:???]
くれないです。

java.sql.DataSourceは、ConnectionPooling実装してないんで使い捨てですね。
してくれたら、このクラス、仕様どおりに動いて無い事になるので逆に困りますw

Factoryから自作してやろうかと思ったんですが危ないし、
その筋の人間の作ったJDBCドライバーかデータソースに完全に任せたいです。


462 名前:nobodyさん mailto:sage [2005/06/09(木) 05:10:57 ID:???]
java.sql.DataSourceなんてないと思うのだが。
javax.sql.DataSourceはインターフェイスだからConnectionPooling実装してるとかしてないとか、関係ないと思うが。
というか、ConnectionPoolingって、インターフェイス?

463 名前:nobodyさん mailto:sage [2005/06/09(木) 17:25:42 ID:???]
>>462
ですね。DataSourceはインターフェースです。
ConnectionPoolingっていうのは、仕組みなのでクラスでもインターフェースでもないです。

ちょっと検証できそうなものを見つけました。
ttp://www2b.biglobe.ne.jp/~caco/pgpool/

464 名前:nobodyさん mailto:sage [2005/06/09(木) 17:47:39 ID:???]
キッチリ解決しました。
MySQLの資料ですが、まんまいけるハズです。

ttp://kamakura.cool.ne.jp/oppama/swjd/jndidatasource.html


465 名前:nobodyさん mailto:sage [2005/06/09(木) 22:11:26 ID:???]
つうか、JBossがわざわざJNDIに登録してるものが、コネクションプーリングしてないとは思えんのだが。

466 名前:nobodyさん mailto:age [2005/06/16(木) 02:31:27 ID:???]
質問させてください。
現在レン鯖の「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さん mailto:sage [2005/06/16(木) 02:39:31 ID:???]
>>466
設定を変えたときPostgreSQLの再起動をした?
って言うか、貸鯖で設定ファイルを弄らしてくれるのかよ...

それよりもtcp/ipによる接続の必要性が無いのなら
UnixDomainSocketでいいんじゃね。
$pgsql_conn = pg_connect("dbname=DB名 user=名前 password=パス");

468 名前:nobodyさん mailto:age [2005/06/16(木) 02:42:30 ID:???]
>>467 こんばんわ
再起動は/etc/rc.d/initdからしました
なんかvps?とかで似非root権限があるそうです。
$pgsql_conn = pg_connect("dbname=DB名 user=名前 password=パス");
↑host=localhostでソケット通信かとおもてた、ちょっと試してきます

469 名前:nobodyさん mailto:sage [2005/06/16(木) 02:50:33 ID:???]
>>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さん mailto:sage [2005/06/16(木) 02:59:33 ID:???]
>>469
う〜ん。とりあえず、エラー表示が一切無いのも気になる。
スクリプトの先頭で
error_reporting(E_ALL);
ってすれば何かエラーでないか?

471 名前:nobodyさん mailto:sage [2005/06/16(木) 14:44:13 ID:???]
>>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さん mailto:sage [2005/06/16(木) 17:18:41 ID:???]
>>471
そのエラー表示だと、DBそのものはローカルで動いていると思われ。
dbnameがおかしいんじゃね。

473 名前:nobodyさん mailto:sage [2005/06/30(木) 04:40:53 ID:???]
どもです。はじめまして。
phpPdAdminの質問なのですが、特権一覧と言うところに「102」という
ユーザーがいるんですが、これは自動的に追加される何らかのユーザー
なのでしょうか??
SQLを直で覗いてユーザー一覧を見たのですが、
このユーザーはいませんでした。
phpPgAdminからしか認識できません。
どなたか知っている人がいましたら、アドバス願います。

474 名前:nobodyさん [2005/06/30(木) 20:13:04 ID:cHU+f8gL]
アドバス願います。

475 名前:nobodyさん [2005/07/23(土) 07:34:11 ID:WyqF/aD4]
RDBMS背負ったWebアプリを開発必要があり、
Perl、DBI、PostgreSQLの勉強を進めています。
要件がなかなかFIXしないため暫定的にスタートしなくては
ならない状態なのですが、運用途中でテーブルの「列」を増減させる事は
可能なのでしょうか。
あるいは新たな構造のテーブルを作り、データを移す、とかの方法になりますか?


476 名前:nobodyさん mailto:sage [2005/07/23(土) 08:02:53 ID:???]
>>475
ALTER TABLE ADD COLUMN で可。
www.postgresql.jp/document/pg803doc/html/sql-altertable.html

477 名前:nobodyさん mailto:sage [2005/07/23(土) 18:38:51 ID:???]
>>476
どうもありがとうございます。
このドキュメント、いいですね。
7.4.7なので近いバージョンのをじっくり読んでみようと思います。

478 名前:nobodyさん [2005/07/29(金) 13:20:03 ID: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さん [2005/10/25(火) 18:12:46 ID:2GYRQ0/r]
PostgreSQL8.0.3 を使ってWebアプリをJavaで構築してます。
ユーザーが入力した情報がtext型に入ってて、このカラムに対してキーワード検索をしたい、という
要件が入ってます。
普通にlike文で検索すれば良いと思うのですが、実際、レコード件数が最大で億を超えることが予想されるようです。
text型ですけど、1万文字の文字数チェックを入れる予定です。
この場合,like文ですとインデックスが当然きかないのでかなりの時間がかかる処理になってしまうと思います。

一般的にこのような場合はDBに頼らず別の仕組みをつかっているんでしょうか??
良くある会員サイトで使われている検索はlike文で頑張っているんでしょうかね?

まだシステム仕様変更をするための時間があるのでアドバイスいただけるとありがたいです。




480 名前:nobodyさん mailto:sage [2005/10/25(火) 18:28:23 ID:???]
>>479
普通は「全文検索」モジュールなんかを使うんじゃないのか?
つ ttps://www.oss.ecl.ntt.co.jp/tsearch2j/index.html


481 名前:nobodyさん mailto:sage [2005/10/25(火) 19:38:24 ID:???]
pg_rast, pg_senna あたりを勧めたいところだけど
>レコード件数が最大で億を超えることが予想されるようです。
ということなら Rast や Senna ではキツいですね。
Hyper Estraier は件数が増えても性能劣化しないように作られているけど
pgestraier は PostgreSQL のカラムに対するインデックス作成ができないので使えないわけで。

8.1 で導入されるテーブル・パーティショニングを使ってカテゴリごとにテーブルを分けるとかすれば
pg_rast や pg_senna でもいけるかな?

482 名前:479 [2005/10/25(火) 21:21:40 ID:sIrMsQ6K]
ありがとうございます。全文検索ですか。はじめて扱いますがドキドキですw

>>480で紹介されているTsearch2 はオープンソースとのことですが、
先に述べたレコード数ですとパフォーマンス劣化は大丈夫でしょうか。

>>481さんの内容ですと、Hyper Estraier というのがBestという感じでしょうかね…。

ともあれ、ありがとうございました。

483 名前:nobodyさん mailto:sage [2005/10/25(火) 21:46:04 ID:???]
>>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 [2005/10/25(火) 22:38:46 ID:sIrMsQ6K]
>>483
さらに詳しい説明、感謝致します。
詳しくはHyper Estraieを調査すればわかるとおもいますが、一つだけ。
「インデックスへの登録」という部分は、たとえばText型に入る内容を
Hyper Estraierに対して投げる、という感じでしょうか。その属性にpkyを付加すると。
であれば、Hyper Estraierが持つであろうインデックスファイルなどは結構な量になると
思われますが、正しい認識でしょうか。データ量が多くになると、RDBMSとは別に
全文検索用のサーバーを用意するという運用体型になるって感じでしょうか。
なかなか楽しい世界ですね。ありがとうございます。

485 名前:479 mailto:sage [2005/10/26(水) 10:41:49 ID:???]
>>484 の補足というか。Hyper Estraierについて簡単に調べました。
要求に十分こたえられる仕様だと思っています。
紹介してくださってありがとうございました。

486 名前:nobodyさん mailto:sage [2006/02/13(月) 18:56:37 ID:???]
OIDについて質問です。
あるテーブルでの一意性を保証したいのですが、
単純に該当テーブルのOIDに対してUNIQUEを指定してしまえばいいということなんでしょうか...?
PostgreSQL7.4を想定しています。


www.postgresql.jp/document/pg732doc/user/datatype-oid.html
OID は 32 ビット長であり、クラスタ全体で 1 つのカウンタから割り当てられます。
巨大な、または、長期間運用しているデータベースでは、カウンタが一周する可能性があります。
従って、OID が一意であることを前提とすることは、OID を一意にすることを保証する手段を講じていない限り非現実的です。
OID を使用して行の識別を行う推奨方法は、その OID が使用される各テーブルの OID 列に一意性制約を作成することです。


宜しくお願い致しますm(_ _)m

487 名前:nobodyさん mailto:sage [2006/03/07(火) 20:45:26 ID:???]
>>486
serialでも使えば?

488 名前:nobodyさん mailto:sage [2006/04/29(土) 23:20:03 ID:???]
DB板での書き込みを再掲させて戴きます。レスがつかなかったもので…orz

PostgreSQLを使って、下記のような処理を作ろうと考えています。
現在「特定テーブルのCSV出力」に何を使うかで悩んでいます。
ストアドプロシージャか、PHPを使うかの二択から選んでくれと言われたのですが、
クライアントアプリがこれらをキックすることを考えるとどちらが簡単でしょうか。

----------
クライアント:Windows(.NETで開発)
サーバ:RedHat Linux + PostgreSQL

やりたいこと。
1.通信はhttpのみ。
2.クライアントはサーバにアクセスして、
 「特定テーブルのCSV出力」を命令する。<--------------(・ω・)
3.クライアントは処理の終了を待つ。
4.クライアントは出力されたCSVファイルをダウンロードする。

489 名前:nobodyさん mailto:sage [2006/04/29(土) 23:29:08 ID:???]
>>488
.NETからストアドたたけるんだろうから、ストアドでやれば?
と思ったけど、httpのみかよ。
http通信で直接ストアドなんて呼べるのか?
結局phpでラップすることになるんではないかな。





490 名前:nobodyさん mailto:sage [2006/04/30(日) 00:06:46 ID:???]
>>489
レスありがとうございます。
ADO.NETを使っていいものなら話は簡単なんですけどね…。
「セキュリティの観点」からダメだと言われてしまいました。

ちなみにPHPをキックすること自体は簡単にできるものでしょうか?

491 名前:nobodyさん mailto:sage [2006/04/30(日) 00:21:53 ID:???]
>>488
なんの言語でやるのかしらんが、たとえばPHPでやるとして

*.csvファイルをPHPで処理するように関連付けて
*.csvファイルの中にcsv出力する[プログラム書いて
ヘッダーをtext出力にすればOk。

492 名前:nobodyさん mailto:sage [2006/04/30(日) 04:22:25 ID:???]
>>490
> ちなみにPHPをキックすること自体は簡単にできるものでしょうか?

> 1.通信はhttpのみ。
なんだから、単純にphpのファイルにhttpアクセスするしかないのでは?


493 名前:nobodyさん mailto:sage [2006/05/08(月) 08:53:52 ID:???]
>>491-492
了解しました。いかにも素人の質問に答えてくださってありがとうございます。


494 名前:good [2006/05/11(木) 15:23:40 ID:UxCS1jwo]
PostgreSqlでdate型は、文字として認識されるようですが
仕様でしょうか?
たまに数値型で、抽出できたりするんですが、どうしてでしょう?
WK_SQL = WK_SQL & "(F1_RINYUYMD BETWEEN " & WK_DOU1 & " AND " & WK_DOU2 & ")
F1_RINYUYMD date型

495 名前:nobodyさん [2006/05/17(水) 22:06:30 ID:/QUzYdtQ]
あるテーブルのint型の変数にNULLを代入しようとすると、
エラーではじかれてしまうのですが、
何がいけないのでしょうか?
charでは問題ありませんし、特にNULLがダメというわけでもないように思っているのですが、
そういうケースがあるんでしょうか?

496 名前:nobodyさん mailto:sage [2006/05/17(水) 22:35:27 ID:???]
'NULL'ってやってるとか?
queryをダンプして貼ったらレスも付き易いかと。

497 名前:nobodyさん mailto:sage [2006/05/17(水) 22:46:12 ID:???]
すみません、あまり経験も乏しいので説明が要領を得ないかもしれませんが、
insert into test(param) values('');
という感じです。(test というテーブルの param に代入)
実際には、COPYコマンドでファイルから代入しようとして蹴られます。
a,b,,,,c,,d, というようなデータ列で、','を区切り文字としています。
,, の部分がNULLとして扱われると思うんですが、
varchar(20)などでは問題ないのに、intのところでエラーが出ます。
それでコマンドラインでも試してみたところ、やはり同じエラーが出ました。

マニュアルなどでデータ型を見た限りだと、NULLでも問題なさそうに思うのですが、
何か操作上の間違いがあるのでしょうか。
あと、言い忘れていましたが、試しているのは Windows の psql です。

498 名前:nobodyさん mailto:sage [2006/05/18(木) 00:46:59 ID:???]
>a,b,,,,c,,d, というようなデータ列で、','を区切り文字としています。

ここを
a,b,NULL, NULL, NULL,c, NULL,d,
みたいだとどうだろ(試してないけど

499 名前:nobodyさん mailto:sage [2006/05/18(木) 01:27:13 ID:???]
>>497
COPY じゃ無くて \COPY を使っているとか?
COPYは ,, をNULLとして扱うようだけど、
\COPYは ,, を ""(空白文字列) として扱っている。

\COPY table FROM filename NULL ''
でいけるんじゃね?

> insert into test(param) values('');
''とNULLは別もんだよ。



500 名前:497 mailto:sage [2006/05/18(木) 02:19:43 ID:???]
>>499
うげ、そうだったんですか。
明日早速やってみます。

>>498
そういうのもありなんですか。
ただ、今やってるのは、他の人が用意したcsvをそのまま利用しているので、
そういうやり方だと何かしらのコンバートが必要になりますよね。

いずれにせよ、アドバイスありがとうございます。

501 名前:nobodyさん mailto:age [2006/05/18(木) 21:20:56 ID:???]
先週まで正常に動いていた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 mailto:sage [2006/05/18(木) 22:12:42 ID:???]
今日やってみたところ、期待通りの動作をしました。
とても助かりました。
どこのどなたか存じませんが、ありがとうございました。

503 名前:nobodyさん [2006/05/19(金) 10:16:13 ID:S+/mH4DM]
8.1ってiモードの絵文字(外字領域)使えますか?
DBはEUC_JPで構築しています。


504 名前:nobodyさん [2006/07/19(水) 22:01:12 ID:6lmDHlcw]
バイナリ本体は/usr/local/pgsqlに置いて、DBを/home/pgsql/varに置くようにコンパイルってどうすればできますか?

505 名前:nobodyさん mailto:sage [2006/07/19(水) 22:17:41 ID:???]
>>504
initdb & PGDATA

506 名前:504 mailto:sage [2006/07/20(木) 23:55:57 ID:???]
なんだ、コンパイルのオプションと違ったんだ。
ありがと。

507 名前:nobodyさん [2006/07/22(土) 00:36:09 ID:TflzrAiN]
pgfoundry.org/frs/?group_id=1000125&release_id=546
ここからダウンロードしたODBCだと文字化けするんだけど、何かご存じないですか?

鯖が7.4で、EUC-JP
クライアントはAccessとCSEで確認して化けらったです。

SET CLIENT ENCODINGはためしてみました。

以前に片岡さんのほうのドライバいれてました。

バージョンアップしてみたのは、numeric型を認識してくれないのと、
ADOでトランザクションの発行がうまくいかなかったからです。(´・ω・`)

508 名前:nobodyさん mailto:sage [2006/07/22(土) 00:37:57 ID:???]
>>507
www.geocities.jp/inocchichichi/psqlodbc/indexj.html
を使いましょう

509 名前:nobodyさん mailto:sage [2006/07/22(土) 07:31:10 ID:???]
○○日間アクセスしてないユーザを削除する、という処理をさせたいんですが
Postgresだけでこれを実現する機能があれば教えてください
(OSの方で定期的にスクリプトを実行するのが普通なんでしょうか?)



510 名前:nobodyさん mailto:sage [2006/07/22(土) 17:56:12 ID:???]
cronかアクセスがあるごとに削除クエリ実行するしかないだろう

511 名前:509 mailto:sage [2006/07/22(土) 18:14:09 ID:???]
やっぱりそうですよね。。。ありがとうございました

512 名前:nobodyさん mailto:sage [2006/08/01(火) 18:36:35 ID:???]
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さん mailto:sage [2006/08/01(火) 18:45:57 ID:???]
自己レスですorz
接続した直後に set client_encoding to 'EUC_JP' をすればいいだけでした。
お騒がせしました。


514 名前:nobodyさん [2006/08/02(水) 12:41:10 ID:IBuG4Wqs]
2GBくらいある巨大テーブルがあって、
けっこう複雑なクエリを、いろんな方向からかけるので、
どうしてもseqが走ってしまって、遅くなって困ってます。。

8.1のテーブルパーティショニングを試してもみたんですが、
オプティマイザがバカになって使えないし。。。

殆どがディスクI/O待ちなのですが、こういうときどういった対策があるでしょうか。
どなたか助けて下さい(´・ω・`)

515 名前:nobodyさん mailto:sage [2006/08/02(水) 14:08:15 ID:???]
>>514
explainやったの?

516 名前:514 [2006/08/02(水) 14:47:09 ID:IBuG4Wqs]
はい。そのへんの対策はだいたい。

517 名前:nobodyさん mailto:sage [2006/08/02(水) 18:06:07 ID:???]
>>516
なんでそれで修正できないんだ?
explainでseqになってるところにindexはるなり、テーブル分割するなり
したら基本的に全部なくせるはずだけど?

518 名前:514 [2006/08/04(金) 12:12:04 ID:dYxM1faY]
>>517
集計関数が多いことが、大きな理由だと思います。
様々な角度で切り込まないといけないので、
中間テーブルを作るとなると膨大な量になってしまって。。。

519 名前:nobodyさん mailto:sage [2006/08/04(金) 12:24:10 ID:???]
>>518
で、結局君は何を求めてここに書いているわけ?
どんなテーブル構造になってるかも分からない、seq になる SQL も分からない。
それで、何をどうアドバイスしろ、と。
一言で言うと、「知らんがな」



520 名前:nobodyさん mailto:age [2006/08/22(火) 09:04:21 ID:???]
以下を実行したいのですが, centosに最初に入っているPostgreSQLの
データベースクラスタがあるために、うまくinitdbできません。
(template0と1がSQL_ASCII固定のまま)

initdb --encoding=UNICODE --no-locale

どうすればデータベースクラスタを完全に削除できるのでしょうか?

UNICODEについては, createdb -E UNICODEでもできるのですが,
やはりinitdbで設定したいです.
PostgreSQLを終了させて, ./dataを削除したりしましたが,
キャッシュ?されているらしく完全削除ができない状況です....

521 名前:nobodyさん mailto:sage [2006/08/22(火) 14:03:02 ID:???]
make install

522 名前:nobodyさん mailto:age [2006/10/21(土) 02:59:30 ID:???]
こんばんわ
www.postgresql.jp/document/pg74doc/html/sql-altertable.html
にある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さん mailto:sage [2006/10/21(土) 03:53:49 ID:???]
current_timestamp のことではなくて?

524 名前:nobodyさん mailto:age [2006/10/21(土) 03:59:12 ID:???]
>>523

タイプミスしないように¥dで表示されるTypeの項目から拾ってきちゃってた…
せめて"そんなデフォルトは指定できません"的なエラー吐いてくれれば…
ありがとうございました

525 名前:nobodyさん mailto:age [2006/10/23(月) 04:52:02 ID:???]
先輩が書いたコードを読んでたら
SELECT * from xxtablexx where xxcomunxx 〜 '^[ま-も]' ;
というqueryが書いてあったんですが、〜 '^[ま-も]'の【〜】の意味が分かりません、マニュアル等に載ってますでしょうか?

526 名前:nobodyさん mailto:sage [2006/10/23(月) 09:04:41 ID:???]
>>525
POSIX正規表現なんじゃないの?


527 名前:nobodyさん mailto:sage [2006/10/23(月) 18:03:17 ID:???]
hogeテーブルに各種データとtimestamp型でInsertされた日付が格納されているんだけど
日付=todayのように日付でみるんじゃなく、「何時間以内」という様な指定でデータを取得することは可能ですか?

@7.4です

528 名前:nobodyさん mailto:sage [2006/10/23(月) 22:26:23 ID:???]
>527
intervalでマニュアルを検索しる。

529 名前:nobodyさん [2006/10/25(水) 09:54:38 ID: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さん mailto:sage [2006/10/25(水) 12:03:50 ID:???]
>>529
根本的にSQLが間違ってる、って思わない訳?


531 名前:nobodyさん [2006/10/26(木) 00:18:23 ID:PySunuHV]
やはりそうですか。。
答えが見当たらなかった為、
今はselectで取得したキーを使って、
変数に格納してから、deleteを発行しなおしてます。
動作が遅くなりそうな気もしますが。。。

532 名前:nobodyさん mailto:sage [2006/10/26(木) 00:38:43 ID:???]
>>531
つか、普通はサブクエリを利用してDELETEするにしても、
ちゃんと削除対象のテーブルをFROMに指定するもんじゃないのか?

>>529の例で言えば、
delete from aaa where pk_on_aaa = (select pk_on_aaa from aaa order by bbb limit 1);
とかさ。


533 名前:nobodyさん [2006/10/26(木) 03:54:14 ID:PySunuHV]
>>532
ありがとうございます!解決しました。
副問い合わせの使い方が間違っていたのですね。
selectでは動くので、deleteではできないのかと思ってしまってました
結構googleでも検索したんですけど、見つかりませんでした(泣)
はまると、何にも進んでないのに2〜3日経っちゃいますねw
サブクエリで探して、以下のサイトを参考にしました。
もっと良いサイトもあるのでしょうけど、見つかりません^^;
www.istudy.ne.jp/ilnews/vol286/sql.asp
個人的には以下のサイトで見つけたいのですが。。
osb.sra.co.jp/PostgreSQL/Manual/PostgreSQL-8.1-ja/

534 名前:nobodyさん mailto:sage [2006/10/26(木) 16:41:56 ID:???]
>>533
なんかそれ以前の問題。
汎用的なSQL入門本でも買って読んだら。
2〜3日ありゃ十分読めるし、基礎だけでも
身に付けたほうが後々楽。

535 名前:nobodyさん mailto:sage [2006/10/27(金) 09:56:45 ID:???]
>>533
自分も「それ以前の問題」だと思う。
君が見付けたいサイトでは
osb.sra.co.jp/PostgreSQL/Manual/PostgreSQL-8.1-ja/sql-delete.html
をよく読めば良い。

536 名前:nobodyさん [2006/10/27(金) 13:03:00 ID:C3DTFplx]
>>534
>>535
ほんとありがとうございます^^
SQL入門書を買ってみることにしましたw
前にPHPの本を買ったんですが、
どうやらUNIXの本だったようで、間違ってました><
今回からはネットで調べて買おうと思ってます。
今は、以下に狙いを定めてたりしますw
www.amazon.co.jp/exec/obidos/ASIN/4798109576

537 名前:nobodyさん [2006/10/28(土) 00:20:10 ID:IIQMBUcS]
Postgres の列制約で、後から unique を定義することは出来ますか?

538 名前:nobodyさん mailto:sage [2006/10/28(土) 01:30:04 ID:???]
>>537
できる

539 名前:nobodyさん mailto:sage [2006/10/28(土) 10:55:59 ID:???]
>>538
バージョンは8.1なんですけど、持ってるの古い本で
その中では出来ないとか書いてあって、ネットで調べても出来ないって
あったんですけど

なんかそのあたりを書いてあるページを教えていただけないでしょうか



540 名前:nobodyさん mailto:sage [2006/10/29(日) 12:06:54 ID:???]
>>539
osb.sra.co.jp/PostgreSQL/Manual/PostgreSQL-8.1-ja/ddl-alter.html#AEN2253
の5.5.3. 制約の追加に
もろに
ALTER TABLE products ADD CONSTRAINT some_name UNIQUE (product_no);
って〜のがあるんだが、
オマイはどこで
「列制約で、後から unique を定義することは出来ない」
って見たんだ?

マニュアルを先に読むクセつけな。

541 名前:nobodyさん [2006/10/29(日) 22:53:31 ID: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さん mailto:sage [2006/10/30(月) 00:43:48 ID:???]
じゃ、ヒントだけ

template1=# SELECT '2006-09-01 10:10:00'::TIMESTAMP + '30 days'::INTERVAL;
      ?column?
---------------------
 2006-10-01 10:10:00
(1 row)


543 名前:539 mailto:sage [2006/11/03(金) 00:27:31 ID:???]
>>540
ありがとうございました
おっしゃるとおりです、以後気をつけまする
助かりました

544 名前:nobodyさん mailto:age [2006/11/03(金) 16:57:01 ID:???]
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さん mailto:sage [2006/11/03(金) 19:25:10 ID:???]
>>544
WHERE句で
TO_CHAR(insert,'yyyy/mm/dd') = TO_CHAR(current_timestamp,'yyyy/mm/dd')
すれば今日のデータだけ取れるだろ。


546 名前:544 mailto:sage [2006/11/03(金) 23:36:51 ID:???]
>>545

ごめんなさい、insertされてからX日以上たったレコードのstatusに操作を加えたいのです。
上記コードはその過程で「insert後一日以上たったレコード」をSELECTしています

547 名前:nobodyさん mailto:sage [2006/11/04(土) 00:00:46 ID:???]
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 mailto:sage [2006/11/04(土) 00:25:07 ID:???]
>>547

試しましたが何日前のレコードでもSELECTされてしまいました。
SQLは日付なんかも結構柔軟に扱えそうなんですがスキル不足で…。
とりあえずはこのまま全件とってきてスクリプト側(PHP使ってます)で判定するようにしてみます

ありがとうございました

549 名前:nobodyさん mailto:sage [2006/11/04(土) 00:39:28 ID:???]
つーか、列名に insert はないだろ。
結局「今日」のデータがとりたいのか「X日以上経った」データをとりたいのかも分からん。



550 名前:544 mailto:sage [2006/11/04(土) 00:50:26 ID:???]
>>549
最初、予約語だからダメだろうと思ったんですが試しにCREATE TABLEで使ってみたら通ったのでそのままでした。
最終的にとりたいのは「X日以上経った」データですが、いきなりだと難しいそうなので
「今日中に」INSERTされたデータをSELECTしようとしてみたりしました。

551 名前:nobodyさん mailto:sage [2006/11/04(土) 00:54:56 ID:???]
「テーブル作成 & テストデータ数個 INSERT」の SQL 書いてくれれば
試してみても良いけど






[ 続きを読む ] / [ 携帯版 ]

前100 次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧]( ´∀`)<193KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef