PostgreSQL
レス数が900を超えています。1000を超えると表示できなくなるよ。
0001名無しさん@お腹いっぱい。
2001/05/09(水) 11:36ID:GHX.oCXo関連アプリケーション特有の話題は、以下のスレッドへ。
☆関連スレッド
[PHP + PostgreSQL]
http://corn.2ch.net/test/read.cgi?bbs=php&key=983128806
[PHP以外+PostgreSQL]
http://corn.2ch.net/test/read.cgi?bbs=php&key=988929199
[MySQL vs PostgreSQL]
http://corn.2ch.net/test/read.cgi?bbs=php&key=989341364
0838nobodyさん
03/01/17 15:04ID:O7wqB+4aIs the server running locally and accepting
connections on Unix domain socket "/tmp/.s.PGSQL.5432"?
createdb: database creation failed
というようなエラーが出てしまい、データベースを作成することができません。
postmaster は起動しているようです。
どうしたらいいのでしょうか?
0839vvv
03/01/17 15:15ID:RZuaWe8+★YAHOOOプロフィール★
0840nobodyさん
03/01/19 17:40ID:???man postmasterして-iオプションの項目を読め。
それでも分からなければ、どういう環境でどうやっらだめだったかを書け。
0842nobodyさん
03/01/20 17:54ID:Gy69YlCs遅レスすまそ。
レプリケーションは7.3で導入する予定だったんだけど間に合わず、
7.4に持ち越しになったんじゃなかったっけ?
というわけで、現行のレプリケーション用ミドルウェア?は
なくなるような気がする罠
0843nobodyさん
03/01/20 18:40ID:frlninEM0844nobodyさん
03/01/20 20:16ID:???レプリケーションは、アーキテクチャや実装、運用環境によって、
複数のソリューションが並立し得るので、
単一の実装に収斂していくということはないでしょう。
0845nobodyさん
03/01/21 21:43ID:k4hDw3acPostgres での負荷分散と分散トランザクションについての特集やってたよ。
かなり面白い。
0846nobodyさん
03/01/22 17:56ID:46vMCsSo端末は、主にwinから行っています。
SQLに関しては自信があまりありません。
SQLコマンドポチポチうって、テーブルの作成するの面倒でつ。
http://www.hi-ho.ne.jp/tsumiki/のCSEと言うツールを使っているのですが、
いまいちしっくり来ません。
webminのpostgresqlのツールは良いのですが、webmin自体
あまりインスコしたくありません。
なにか(・∀・)イイ!!ツールあったらおしえてください。
0847nobodyさん
03/01/22 18:23ID:aZrGkOwn0848hmk
03/01/22 18:45ID:skROudWDテキストエディタでテーブル定義のSQLを編集し、psql上にコピペしろ。
0849nobodyさん
03/01/22 18:59ID:???まぁテーブル定義のSQLは自分で書くわけだが。
0850nobodyさん
03/01/22 19:45ID:???psql -f table.sql でファイルを読ませればいいじゃん。
0851hmk
03/01/23 00:21ID:???0852nobodyさん
03/01/23 01:33ID:aJndFgwsを使って住所録を作ってます。
そこに「最初に登録した日付」と、「最終更新日」をいれようと
思ってるんです。
最終更新日をTIMESTAMPにすればいいというのは、
検索してわかったんですが、最初に登録した日付というのは
どういう設定をすればいいでしょうか。
0854ほげ
03/01/23 10:36ID:Vttepi7gdefault now,
ほげほげ。
0855nobodyさん
03/01/23 15:18ID:2Xl85Zl1"pg_relcheck" does not exist
になりました。pg_relcheckはなくなっちゃったんでしょうか。
0856nobodyさん
03/01/23 16:16ID:MK3OE1fp★こんなサイト見つけました★
0857nobodyさん
03/01/23 17:24ID:zqFajCIjこのページを pg_relcheck と pg_constraint でページ内検索してごらん。
http://osb.sra.co.jp/PostgreSQL/7.3/changes.html
0858nobodyさん
03/01/24 20:45ID:+YoyoLvT0859nobodyさん
03/01/27 23:38ID:qiTUaeBV$ psql -U username dbname < database/database.pgsql
と実行すると
\connect: FATAL: user "root" does not exist
となってしまいます。どの設定(環境変数?)を訂正すれば
よいのでしょうか。
0860nobodyさん
03/01/28 15:08ID:oYLjlQQn0862nobodyさん
03/01/29 20:04ID:TOlFKMtQ複数テーブルの特定の列の中から検索したいんです
下記のようにテーブルを必要なところだけ結合して
そのあと検索文字をいれればいいと思ってたんですが
SELECT A.m,B.n FROM A,B WHERE A.o = B.o
このあとに検索したい文字をいれてもだめなんですよね?
0863nobodyさん
03/01/29 21:11ID:???SELECT A.m,B.n FROM A,B WHERE A.o = B.o AND A.m LIKE '検索言葉%'
はできましたが、
A.m,B.nに対して同じ検索言葉で検索をかけたいんですが
どうすればいいでしょうか・・・
0864nobodyさん
03/01/29 22:03ID:???WHERE ( a.a = b.a OR c.c = d.c) AND (e.e = f.f)
とかそういう単純な話ですか?
SQLはどこで(あるいはどの本で)勉強してます?
0865nobodyさん
03/01/31 18:45ID:9q8lNi9S0866nobodyさん
03/02/03 00:09ID:NaYZglLl最近のWin版ポスグレは、どうなのん?
http://download.desk.ne.jp/win/2/00026/4991.html
http://www.nonsensecorner.com/pgsql/
0867nobodyさん
03/02/03 01:05ID:???一年半ぐらい前に入れたときは自分でcompileしたんだが今のはcygwinのインストール時にインストールできる。
性能はどうだろうなぁ。普段使ってるLinux鯖はCPUパワーも違うのでよく分かんないや。
Win用apache、PostgreSQL@cygwin、php@winでちょっと遊んでみたけど、
ローカルで実験するには問題ないみたい。
ついでにFireBird、MySQLも入れてみたが、どれも正常に動いた。
0868nobodyさん
03/02/03 01:18ID:lZTOrefbアクセス権限付けれん?
grantだとテーブルごとじゃんか
0869nobodyさん
03/02/03 02:12ID:???せめて個人用途向けにはFreeで出して欲しかったよ。
Native版pgsqlの作者もPowerGresの開発に携わっていたみたいだが、
7.3.1用psqlは作っていたからその後も継続すると思うんだが。
0870nobodyさん
03/02/03 10:57ID:avIlzK7i0871nobodyさん
03/02/03 16:28ID:KAKRkF84WinならFirebirdだろやっぱり。
0872nobodyさん
03/02/03 20:46ID:UWLHra2gまだベータなのでしかたないのかもしれないけど。
CREATE TABLE test (
code VARCHAR(64) NOT NULL,
field001 VARCHAR(64) NOT NULL,
〜
field032 VARCHAR(64) NOT NULL,
PRIMARY KEY (code)
)
(本当はfieldをもっと増やしたかったけど、firebirdの制限に引っかかるため)
これに3万レコードINSERTして、
SELECT * FROM test ORDER BY code;を発行すると、
MySQL-MyISAMが00:13:79
MySQL-InnoDBが00:09:413
Firebirdが00:14:010
PwerGresが13:06:851
ちなみにテストして思ったけど、FirebirdのJDBCドライバってリークしてない?
0873nobodyさん
03/02/04 01:18ID:1kJ2WuvK0874nobodyさん
03/02/04 01:48ID:???元になってるInterBaseは実績あるよ。
続けるならスレ違いになりそうだから、プログラム板にどうぞ。
てか、最近そっちにスレがあることに気付いた(w
0875873
03/02/04 11:18ID:1kJ2WuvKThx!!
0876nobodyさん
03/02/04 13:12ID:P8TNJ8CdPowerGresに期待したいのだが、こっちも微妙だ。
0877nobodyさん
03/02/04 13:56ID:1kJ2WuvK0878nobodyさん
03/02/04 14:00ID:P8TNJ8Cd0879nobodyさん
03/02/04 18:54ID:ECWcc/cR5.0で実装されるらしいけど。
サーバーサイドでFirebirdを使った場合、
同時アクセス200以上に耐えうるかも疑問。
SQLServerだと200くらいから性能が落ちてくるみたいだし。
http://www.eweek.com/article2/0,3959,293,00.asp
0880nobodyさん
03/02/04 19:48ID:Ogsd33ZD0883nobodyさん
03/02/05 16:40ID:WE3fnQsD「SQL-Serverはダメだ」
米セキュリティ企業大手も、SQL鯖には落第の"F"をつけたらしいじゃん。
0884nobodyさん
03/02/05 17:00ID:???あるいはパッチの副作用が大きくて管理者に敬遠される、という点から見ても
「SQL Serverはダメ」という結論になるわけで。
0885nobodyさん
03/02/05 17:48ID:???管理者といってもDB管理だけの場合もあるし、ネットワーク全体を押さえてる場合もあるわけだが。
やらなくちゃいけない仕事(分野)が多いのも一因かもね。
0886nobodyさん
03/02/05 20:20ID:???0887nobodyさん
03/02/06 11:38ID:???0889nobodyさん
03/02/07 01:27ID:oK4qVqpT> てかDBへ接続できるポートを外部に開いてる時点で、その管理者が終ってる気がするな。
PostgreSQLやOracleのSSLサポートはイントラでのセキュリティー用かな?
0890nobodyさん
03/02/07 06:23ID:???0891nobodyさん
03/02/07 16:55ID:mSK6L1IK0892nobodyさん
03/02/07 17:19ID:mSK6L1IK0893nobodyさん
03/02/07 17:26ID:mSK6L1IK0897nobodyさん
03/02/08 13:29ID:???unicodeを受け取ったサーバがconversionかましてeuc-jpで保存するって話。
0899nobodyさん
03/02/08 21:55ID:WzdldZAx漏れも試した。
PowerGres萎え。
50クライアント制限萎え。
0900nobodyさん
03/02/09 22:03ID:???0901nobodyさん
03/02/10 18:38ID:zGVQOlgyhttp://osb.sra.co.jp/PowerGres/pre_sales.php
特別価格の3万8000円(税別)らしいが、
買う予定の香具師いる?
0902nobodyさん
03/02/10 19:52ID:???0904nobodyさん
03/02/11 14:19ID:???とりだせるように検索条件に指定することって可能なのでしょうか?
0907905
03/02/11 14:39ID:???ash さんのページの URL きぼーん。
ぐぐったら以下のような有様。
http://www.google.com/search?num=50&lr=lang_ja&ie=euc-jp&q=%61%73%68%A4%B5%A4%F3%A4%CE%A5%DA%A1%BC%A5%B8
あ、これか。PostgreSQL・Tips集
http://ash.or.jp/db/pg_tips.htm
質問して解決したらなるべく情報源とか貼ってね。後の人の役にも立つから。
0908nobodyさん
03/02/12 17:00ID:???emailという、カラムで重複を抽出するには?
0909nobodyさん
03/02/12 17:36ID:???SQL辞典買うよろし。オレも欲しい。
0910nobodyさん
03/02/13 00:27ID:???0913nobodyさん
03/02/13 22:43ID:???FROM users
GROUP BY email
HAVING count(*) > 1
email name
-------------------
aaa@bbb.com aaa
aaa@bbb.com bbb
…
こんな感じかな?
0914nobodyさん
03/02/13 22:50ID:???"PowerGresとは"より
「UNIX/Linux で定評のある オープンソースデータベース PostgreSQL が身近になりました。」
値段のお陰で縁遠になっている悪寒。
0915nobodyさん
03/02/14 11:08ID:???それだとnameがグループに入ってないと怒られるのですけど。
実際にuniqid,name,emailとあるのに…。なぜでしょう?
WHERE EXISTS(
SELECT email FROM users Y WHERE Y.uniqid = X.uniqid
GROUP BY email HAVING count(*) > 1
)
0918913
03/02/15 00:02ID:???usersテーブル(uniqid,email,name)
VIPテーブル (uniqid,users_id,name)
だとして、「usersの中で、users.uniqidがVIPのusers_idに含まれている人」
を探す為に
SELECT *
FROM users
WHERE EXISTS(
SELECT *
FROM VIP
WHERE users.uniq_id = VIP.users_table_id
)
って使うもんだと思うんだけど、、
usersテーブルのuniqidと同一のテーブルをEXISTSの中に書く意図は何?
それに、EXISTSの中のSELECT文にGROUP BYって書いたこと無いから
挙動がいまいちつかめません…。
とりあえず、EXISTSの中はリファレンス本の例とかにあるような単純な
使い方が無難かと。。
ちなみにリファレンス本は、技術評論社の「SQLポケットリファレンス」が
使いやすくてオススメ。
2000円位で、技術系書籍として安いし。
Postgres対応ではないからLIMITとかは載ってないけど、大方これで済む。
0919913
03/02/15 00:11ID:???SELECT email, name
FROM users
GROUP BY email
HAVING count(*) > 1
これだめ(w
SELECT email, name
FROM users
GROUP BY email
HAVING count(email) > 1
か
SELECT email, name
FROM users
GROUP BY email, name
HAVING count(*) > 1
のどっちかで動くよ…多分。
#以前仕事でPostgres使ったことあるからついカキコしてしまったけど、
#今は職業プログラマじゃ無いし、自分のLinuxにPostgres入れてないから
#実験もできん(w
#無責任でスマソ
0920913
03/02/15 00:21ID:???SELECT email, name
FROM users
GROUP BY email
HAVING count(name) > 1
こうかも…。
GROUP BY〜HAVING SUM(〜)とかCOUNT(〜)とかは
よく考えないとエラーになりがちなんだけど、
自分が思った以上にSQLに対する感覚が鈍ってる(w
(使う目的ないけど)リハビリ目的でPostgresインスコしようかなぁ…。
つか誰かうまく説明できる人ににバトンタッチしたひ。
0921nobodyさん
03/02/15 02:13ID:S3poV9Xb0922nobodyさん
03/02/15 17:58ID:/trbWmidno SERIAL, -- 自動で連番
name text,
tel text,
fax text
);
INSERT INTO tbl(name) VALUES('tanaka');
たとえば上記のように、SERISALのあるテーブルに
データをINSERTした場合に、noにどの番号が割り当て
られたか、知る方法は無いのでしょうか?
nameは重複する可能性があるのでINSERT後に、
SELECT no FROM tbl WHERE name='tanaka';
とやっても、ダメです。
現在は下記のようにして調べていますが、
いまいち自信がありません。
BEGIN;
SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;
INSERT INTO tbl(name) VALUES('tanaka');
SELECT max(no) FROM tbl;
COMMIT
0923nobodyさん
03/02/15 18:57ID:GmQVtn+rINSERT と同じトランザクションブロックにあるなら、
currval('シーケンス名'); で割り当てられた値を取得できるよ。
ちなみに、次の値は nextval だったかな。
0925名無しさん@XEmacs
03/02/15 23:12ID:???oid使え。
hoge=# insert into a (b) values ('memo');
INSERT 28675 1
hoge=# select * from a where oid=28675;
a | b
---+------
1 | memo
(1 row)
0926nobodyさん
03/02/15 23:18ID:vyjm8srSINSERT されたレコードを特定するという目的ならこれもいいね。
ただ、割り当てられた OID ってどうやって取得するの? 目視?
0927tantei
03/02/15 23:37ID:???●浮気素行調査
彼氏、彼女、妻、夫の浮気を調査致します!!
●盗聴器盗撮機発見
あなたの部屋に誰かが仕掛けているかも!!
●行方調査
行方不明になっている家族の消息を調査致します!!
●電話番号から住所割り出し
一般電話、携帯から住所を割り出し致します!!
●ストーカー対策
社会問題ともなっているストーカーを撃退致します!!
その他人生相談からどんなお悩みでも解決いたします!!
24時間受付 090−8505−3086
URL http://www.h5.dion.ne.jp/~grobal/
メール hentaimtt@k9.dion.ne.jp
グローバル探偵事務局
0929nobodyさん
03/02/17 12:16ID:???CREATE OR REPLACE FUNCTION f(date) RETURNS SETOF record AS '
DECLARE r record;
BEGIN
FOR r IN
SELECT sore,kore FROM t WHERE $1 <= sore and sore < $1+''1month''::interval
LOOP
RETURN NEXT r;
END LOOP;
RETURN;
END;' LANGUAGE 'plpgsql';
結果セットのカラムと型をExcelの中にぐじゃぐじゃ書かなくてはなりません
Selection.QueryTable.Sql = "SELECT * FROM f('2003-2-17') AS q(s date, k numeric);"
実際はもっとカラム数が多いのでタイヘンです。できれば、
Selection.QueryTable.Sql = "SELECT * FROM f('2003-2-17');"
だけで済ませたいのですが、いい方法はあるでしょうか? verは7.3.1です
0930nobodyさん
03/02/18 00:43ID:IIRaGRbN返したい列名を定義したテーブルかビューを作っておいて
RETRUNS SETOF テーブル名 AS
ってしてやりゃ、期待通りの動作をするよ。
PostgreSQLは、テーブルやビューはClass(=型)定義として使える。
それを応用するってこった。
0931nobodyさん
03/02/18 12:06ID:???>返したい列名を定義したテーブルかビューを作っておいて
ビューを作ってうまく行きました。有り難うございます。
CREATE OR REPLACE VIEW v AS
SELECT sore, kore FROM t WHERE false;
CREATE OR REPLACE FUNCTION f(date) RETURNS SETOF v AS '
SELECT sore,kore FROM t WHERE $1 <= sore and sore < $1+''1month''::interval
' LANGUAGE 'sql';
0932
03/02/19 15:56ID:ce+34SG0を取得する方法を教えてください?
0933nobodyさん
03/02/19 16:44ID:???0934nobodyさん
03/02/19 16:45ID:???そもそも更新日時を取りたいという発想自体が間違いだと思うが。
0935nobodyさん
03/02/19 17:38ID:???とりあえずそれ用のフィールドを作って、更新時のトリガーで時間を設定。
重要なテーブルに関してはログと証拠を残すという意味で
そういう手段をほどこしたほうがいいんじゃないかな。
まぁ、物理的にログを残す動作をしておかなければわからないということかな。
0936nobodyさん
03/02/20 13:04ID:???こう言うこと?
create table hoge (i integer, t timestamp default current_timestamp);
hoge=# insert into hoge (i) values (12);
hoge=# select * from hoge;
i | t
----+-------------------------------
12 | 2003-02-20 13:01:45.227974-05
(1 row)
で更新時にtimestamp入れればいいんでないかと?
hoge=# update hoge set i=23, t=current_timestamp where i=12;
UPDATE 1
hoge=# select * from hoge;
i | t
----+-------------------------------
23 | 2003-02-20 13:07:11.440763-05
(1 row)
0937932
03/02/21 15:20ID:???>>934 >>936
やっぱり、テーブルのフィールドにタイムスタンプを設けて
置くしか手は無いんですよね、、、いや、
「あれ?知らない間にデータが変わってる・・・
いついじったんだろ?これ・・・・時間帯がわかれば
誰がやったか想像つくなぁ・・・」
ってことがありまして、、、それで、知りたいなって
思ったんです。今後、こういうことが起きてもいいように、
timestamp型のフィールドを設けて
更新時にはカレントを突っ込むようにします。
ありがとうございました。
レス数が900を超えています。1000を超えると表示できなくなるよ。