[表示 : 全て 最新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/



47 名前:nobodyさん mailto:sage [03/03/22 01:01 ID:???]
まともなsql文が書けたらし質問しない罠

48 名前:nobodyさん mailto:sage [03/03/22 01:08 ID:???]
>>47
何気に問題箇所は「sql文」だと>>46は切り分けてるからなあ

49 名前:nobodyさん [03/03/22 01:23 ID:lQb2nQAC]
>>42はboardというテーブルの
何て列に入ってるのかということに
実は気付いていないという罠(w

50 名前:nobodyさん mailto:sage [03/03/22 01:37 ID:???]
結局みんななんだかんだ言って暗に教えてあげてるからやさすぃねw

51 名前:nobodyさん mailto:sage [03/03/23 00:43 ID:???]
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 ID:T5828xOT]
>>51
バージョンはどうなってる?

53 名前:51 mailto:sage [03/03/23 02:27 ID:???]
>>52
7.3.2です。


54 名前:名無しさん@Emacs mailto:sage [03/03/23 03:47 ID:???]
7.2.3だと出ないなぁ。


55 名前:nobodyさん mailto:sage [03/03/23 19:17 ID:???]
>>51
それって odbc 経由で Windows からつないでる?
psql からやっても同じエラーでるの?



56 名前:nobodyさん [03/03/24 15:05 ID: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さん mailto:sage [03/03/25 10:48 ID:???]
>>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さん mailto:sage [03/03/25 17:13 ID:???]
>>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 mailto:sage [03/03/25 17:46 ID:???]
結合順序コントロールするにはサブクエリにするしかないかも。

select 名前
,replace(join_str(好物),' ','@') as 好物
from (select * from 好物 order by 好物) as k
group by 名前;

既に全然スマートじゃないという罠。


60 名前:nobodyさん mailto:sage [03/03/25 22:02 ID:???]
>>59
すごいでつね。正規化したのはいいけれど、動的配列を繋げて一行で取り出すのって一苦労。
集約関数は奥が深い深い。勉強になります。
うちはまだ、好物1,好物2, ...., 好物25 をくっつけてますよ。

61 名前:56 mailto:sage [03/03/26 11:32 ID:???]
>>57-59
なるほどー。すごく勉強になりました。ありがとう。

ちなみに、7.2.1 では replace() が使えませんでした。
7.3.2 では使えました。

同じマシンに異なるバージョンの Postgres をインストールするのって、
簡単にできるんですねえ。

62 名前:nobodyさん mailto:sage [03/03/27 17:09 ID:???]
> 火災と申します
プロジェクトに「火がついた」か。

63 名前:nobodyさん mailto:sage [03/03/27 17:12 ID:???]
>>62
はやっ! (w


64 名前:nobodyさん mailto:sage [03/03/28 01:24 ID:???]
7.2.2で日付計算をやっています。

test=# select CURRENT_DATE - '2001-12-01'::DATE > '2 month'::INTERVAL;
?column?
----------
f
(1 row)

となるのが・・・なんでだろ〜(´Д`;)
DATE型じゃなくてTIMESTAMP型にすると
ちゃんとtrueで帰ってくるのですが……

65 名前:nobodyさん mailto:sage [03/03/28 01:38 ID:???]
>>64
# SELECT (CURRENT_DATE - '2001-12-01'::DATE);
?column?
----------
482

どうも返り値がinteger型のようだ。



66 名前:64 mailto:sage [03/03/28 13:45 ID:???]
>>65
integer型のようですね(´Д`;)

結局
# select CURRENT_DATE - '2 month'::INTERVAL >= '2001-12-01'::DATE;
?column?
----------
t
(1 row)

としたら動きました。うーむ謎〜。
#よくわかってないだけかも。

67 名前:nobodyさん mailto:sage [03/03/28 17:21 ID:???]
データの作成って、みなさんはどんな方法を採ってます?
MicrosoftのAccess で入力フォームを作って、それをテキストにexport、
文字コード等を適当なものに変換、最後にcopy コマンドでpostgres に
持ってくる、という煩雑なことをしているのですが、もうちょっとなんとか
ならないのかな??と悩んでまして。。。

68 名前:nobodyさん mailto:sage [03/03/28 19:11 ID:???]
>>66
DATE型 - TIMESTAMP型 = INTERVAL型 で
DATE型 - DATE型 = INTEGER型 なんだよな。
仕様なのかバグなのかMLで聞いてみれば。
いc氏あたりが答えてくれるかも。


69 名前:nobodyさん mailto:sage [03/03/29 02:18 ID:???]
>>67
なんか省略してないか。

とりあえずAccess使うならODBCでPostgreSQKに接続すればいいだけだが。

70 名前:nobodyさん [03/03/30 15:36 ID:/7/BL2Cw]
[pgsql-jp: 29501] DELETEコマンドの使い方について。
釣り日和でつ。
                       ,
                      ,/ヽ
                     ,/   ヽ
            ∧_∧  ,/      ヽ
           ( ´∀`),/          ヽ
           (  つつ@            ヽ
        __  | | |                ヽ
      |――| (__)_)                ヽ
 ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄|                ヽ
/⌒\/⌒\/⌒\/⌒\|彡~゚ ゜~ ~。゜ ~ ~ ~ ~~ ~ ~~ ~ ~~ ~~ ~~
⌒\/⌒\/⌒\/⌒\/⌒\彡 〜 〜〜 〜〜 〜〜 〜 〜


71 名前:nobodyさん [03/03/30 15:50 ID:dniM4gxK]
PostgreSQLをWindowsでcygwinを介さないで使うことはできませんか?

72 名前:nobodyさん mailto:sage [03/03/30 16:41 ID:???]
>>71
PowerGres (PostgreSQL on Windows)
〜オープンソースデータベースのスタンダード "PostgreSQL" を Windows で〜
osb.sra.co.jp/PowerGres/introduction.php

73 名前:71 mailto:sage [03/03/30 17:29 ID:???]
>>72
へぇ〜できるんですね。ありがとうございます。
欲を言えば、PostgreSQLの開発元がなんとかして欲しいものです。

74 名前:nobodyさん mailto:sage [03/03/30 17:48 ID:???]
>>72
有償なのはいいとしても、ソース公開じゃないから、単なる
「Windowsで動作するPostgreSQL互換RDBMS」にしか
過ぎなくなっちゃったんだよね。

石井さんはPostgreSQLがオープンソースであるメリットを
熱く語っていたけど...。

75 名前:nobodyさん mailto:sage [03/03/30 18:27 ID:???]
>>74
商売としてはしかたないと思うんだけど、SRAはPostgreSQLがWindowsで動く道を閉ざしてしまった気がする。



76 名前:nobodyさん mailto:sage [03/03/30 23:07 ID:???]
>>74
BSD ライセンスのオープンソースだからこそ、
こういった派生品でのビジネスもできる。

そして、オープンソースは、関わる人間の多さが成功の要。
たとえ派生品でも、ベースとなる製品についての知識を有する人が
一人でも増えるのは喜ばしいことだよ。

増えたうちの一人がほんの少しでも本家にコミットしてくれるなら、
最終的に本家の利益にもつながる。

>>75
メールの本文はほとんど読まずに、Subject しか読んでないから全然詳しくないんだけど、
本家の postgres-hackers ML では MS Windows 版の話とか出てるよね。
7.4 でネイティブサポートするとか書いてあったような。

77 名前:nobodyさん mailto:sage [03/03/30 23:24 ID:???]
>>76
ttp://hp.vector.co.jp/authors/VA023283/PostgreSQL.html
ttp://hp.vector.co.jp/authors/VA023283/PowerGres.html

本家はプロセスモデルでPowerGresはスレッドモデルってことでいいかな。


78 名前:nobodyさん mailto:sage [03/03/31 07:13 ID:???]
>>76
SRAはPowerGresを本家にフィードバックするんだろうかね?

79 名前:nobodyさん mailto:sage [03/03/31 13:53 ID:???]
現場は、フィードバックすると言っているがね。
ただ、(WindowsのスレッドモデルをUNIXに持ってくることに)
どの程度意味があるかは分からん。

S○Aも、UNIXでいくならUNIX一本でもっと機能拡張とかすればいいのに。
中途半端にUNIXもWindowsも手を染めてどうすんだか。


80 名前:質問です。 [03/04/01 17:16 ID:0gCa7Sb2]
ポスグレって
Windows版 ってないのですか?

81 名前:nobodyさん mailto:sage [03/04/01 17:19 ID:???]
                       ,
                      ,/ヽ
                     ,/   ヽ
            ∧_∧  ,/      ヽ
           ( ´∀`),/          ヽ
           (  つつ@            ヽ
        __  | | |                ヽ
      |――| (__)_)                ヽ
 ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄|                ヽ
/⌒\/⌒\/⌒\/⌒\|彡~゚ ゜~ ~。゜ ~ ~ ~ ~~ ~ ~~ ~ ~~ ~~ ~~
⌒\/⌒\/⌒\/⌒\/⌒\彡 〜 〜〜 〜〜 〜〜 〜 〜

82 名前:nobodyさん mailto:sage [03/04/02 01:19 ID:???]
[pgsql-jp: 29545] 削除依頼
祭りか徹底無視か?

83 名前:nobodyさん mailto:sage [03/04/02 01:37 ID:???]
あら、意外とすんなり収束したね。

84 名前:nobodyさん mailto:sage [03/04/02 17:32 ID:???]
>>83
時間が時間だけに。
オマケはついたが。

85 名前:nobodyさん [03/04/04 06:06 ID: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さん mailto:sage [03/04/05 00:01 ID:???]
うーんなんでだろ。
select * from pg_convertion (だったかな)
とかはヨサゲ?

87 名前:nobodyさん mailto:sage [03/04/05 05:05 ID:???]
insert や delete に Left join を使うとエラーがでるのですが、
ポスグレではselect文だけにしか使えないのでしょうか?

だとしたら2つのテーブルを比較して足りないモノだけを
1方のテーブルに追加していく、なんてことはできないのでしょうか?

やれるとしたらどんな手段があるか、参考になるサイトがあれば教えてください。


88 名前:nobodyさん [03/04/06 17:10 ID:iXfPNuQP]
既存のディスクが一杯になってきたので、ディスクを追加して、
今後は「今までのディスク+追加したディスク」を使いたいのだが可能なの?

やっぱり、一つのデータベースが複数のディスクにまたがるのは無理なのかなぁ


89 名前:nobodyさん mailto:sage [03/04/06 18:13 ID:???]
>>87
普通にできましたが。
バージョンは?
どんなsqlでエラーになったの?
どんなエラーが出たの?
オレは釣られたの?

90 名前:nobodyさん mailto:天然でしょ [03/04/06 22:20 ID:???]
>>89
メール欄

91 名前:nobodyさん mailto:sage [03/04/07 00:49 ID:???]
cygwinでPostgreSQL動かしてJavaのJDBC+ODBCでアクセス
してみたら、読み込みはうまくいったけど書き込みは
文字化けしてテーブルに書き込まれてしまった。
文字コード調べてみたらSJIS->EUC-JPのような変換が
行われ、そのEUC-JPのコードをSJISで見たときの文字化け
のままテーブルに書かれてしまった感じ。
解決策があったら教えてください。

92 名前:91 mailto:sage [03/04/08 00:41 ID:???]
自己解決。
jdbc:postgresql:test?charSet=SJIS
デコードの指定を付けたらすべてうまくいきました。

93 名前:nobodyさん [03/04/09 03:20 ID:Ub7v47GH]
ところで、PowerGres、どうよ?
PostgreSQLでできること、全部できる?

94 名前:あぼーん mailto:あぼーん [あぼーん]
あぼーん

95 名前:nobodyさん mailto:sage [03/04/09 06:30 ID:???]
>93
誰も買ってない悪寒。だから言ったのに・・・。




96 名前:nobodyさん [03/04/09 19:01 ID:xm6OICY+]
>93
Ver7.4のWindowsネイティブ対応っぷり次第だな。
それまで待てれば待ったほうがいい。

97 名前:nobodyさん mailto:sage [03/04/10 11:21 ID:???]
ひょっとしてPostgreSQLのパターンマッチングって同じ文字の連続(aaa、あああ など)って検出できない?

98 名前:nobodyさん mailto:sage [03/04/10 11:50 ID:???]
>>97
はぁ?
おまえができないだけでしょ。

99 名前:nobodyさん mailto:sage [03/04/10 12:29 ID:???]
w)

100 名前:nobodyさん mailto:sage [03/04/10 15:51 ID:???]
>>98
うそだ!

select * from table where string ~ '(.)\1\1';

とかできなかったぞ!できるというなら例を見せてみれ!

101 名前:nobodyさん [03/04/10 18:42 ID:Gvrywi5t]
特定のフィールドを指定してセレクトするのではなく、
逆に、「あるフィールド以外すべてセレクト」というふうなクエリーはかけないのでしょうか?

102 名前:nobodyさん mailto:sage [03/04/10 20:08 ID:???]
>>100
where string ~ 'a{3}';

103 名前:102 mailto:sage [03/04/10 20:27 ID:???]
ん? 勘違いしてた。


104 名前:nobodyさん mailto:sage [03/04/10 22:07 ID:???]
>>103
だよね。できないよね?

105 名前:nobodyさん mailto:sage [03/04/10 22:22 ID:???]
>>101
WHERE foo <> 'ある条件';



106 名前:nobodyさん mailto:sage [03/04/11 01:37 ID:???]
>>101
105は間違い。

SELECT ~hogehoge WHERE ...

チルダをつければいい

107 名前:nobodyさん [03/04/11 01:46 ID:nN51pMH3]
>106
そっか!ありがと。試してみます。

108 名前:nobodyさん mailto:sage [03/04/12 16:38 ID:???]
>>106おいおい(w

109 名前:nobodyさん [03/04/12 19:46 ID:UOkuI+UD]
気づくの遅すぎ(藁

110 名前:nobodyさん mailto:sage [03/04/13 15:52 ID:???]
>>107騙されるな
SELECT ^hogehoge
だぞ

111 名前:nobodyさん mailto:sage [03/04/13 20:29 ID:???]
>>107
昔は
SELECT !hogehoge
と書いたもんだ

112 名前:nobodyさん mailto:sage [03/04/15 14:02 ID:???]
>>111 あんたかなりのベテランだな
一部のDBでは
SELECT `hogehoge
だったころもあるね

113 名前:nobodyさん [03/04/16 13:29 ID:sI0EuNRH]
つーか
SELECTしたい列名なんて明示的に書くのが王道だろ
それとも
テーブル設計をコロコロ変えやがるのかと小一時間...

114 名前:山崎渉 mailto:(^^) [03/04/17 12:01 ID:???]
(^^)

115 名前:33 mailto:sage [03/04/17 13:09 ID:???]
>>35
n 日前のバックアップファイルを削除する、という機能が欲しくなったので付けてみた。
find と xargs コマンドが必要。
find ${BACKUPDIR} -type f -daystart -mtime +${EXPIRE_DAY} |xargs /bin/rm -f

全文は長いので >>116 に張ります。必要ないって? そんなこと言わないで・・・。



116 名前:33 mailto:sage [03/04/17 13:09 ID:???]
#/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 名前:山崎渉 mailto:(^^)sage [03/04/20 06:27 ID:???]
   ∧_∧
  (  ^^ )< ぬるぽ(^^)

118 名前:nobodyさん [03/04/23 02:29 ID:b3QZu4Pm]
PostgreSQL のデータベースを UTF8 で作ったとき、日本語の入ったカラムに
ORDER BY かけると JIS 漢字順ではなくなるのかな?

119 名前:nobodyさん mailto:sage [03/04/23 23:03 ID:???]
linさんのコメントにどんな意図があるかは知らないけど
サイトのJavaScriptでしばらく楽しんでしまった。。。

120 名前:あぼーん mailto:あぼーん [あぼーん]
あぼーん

121 名前:nobodyさん [03/04/24 19:29 ID:Q1w3nY2w]
質問です。

複数のカラムを対象に、selectしたいのですが、どう書けばよろしいでしょうか?
mysqlだとFull Text Searchとあると思うのですが、Postgresでできますでしょうか?

122 名前:nobodyさん mailto:sage [03/04/25 11:28 ID:???]
管理ツールDbVisualizerってどうよ?
www.minq.se/products/dbvis/index.html
Javaアプリだけど、個人的には好感触。

123 名前:nobodyさん mailto:sage [03/04/25 12:18 ID:???]
>>122
psqlで十分。
エディタもviでいい。
巡回ダウソもwgetでいい。

なんてなぁ、新しいのを覚えられないだけ。
CSE入れてみたけど起動してみて、




               さ ぁ ど う し た も の か と 小 一 時 間 ...

124 名前:nobodyさん mailto:sage [03/04/27 05:21 ID:???]
>>121
意味わかんね。
select * from table
ってやれば複数のカラム対象にselectできてるし。

125 名前:nobodyさん mailto:sage [03/04/27 12:54 ID:???]
>>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 ID:RGglVdIs]
psqlからのcopyコマンドで"\N"という文字列がテーブルに入れれない・・・(WITH NULL AS指定はなしで )
"\b"、"\n"、"\."は
"\\b"、"\\n"、"\\."に変換すれば入るのに・・・

"\N"は"\\N"に変換してもだめ・・・

"\N"という文字列はだめなんでしょうか?

127 名前:nobodyさん [03/04/27 21:51 ID:ClMbC1OP]
>>121
第一正規化、って知っていますか?

128 名前:121 [03/04/27 21:52 ID:u/4ug4s4]
>> 124
失礼しました。whereで複数カラムを指定するという意味です。

>> 125
全文検索というと、確かにNamazuとかそういう方向いっちゃいますね。
単純に複数カラムを検索条件にかけたいだけです。

where andでつなぐと遅くなるので、(レコード数が230万件あるので)
mysqlのFull Text Searchつかったらと先方にいわれ、いまさら乗り換える
のはややこしいので、Postgresでもそういう機能がないかと探しておりま
した。

設計ミスか余計な機能ではとありますが、検索対象の列が5つあって、
最初はそれぞれにかければいいという仕様でしたが、5つのどれかに
ヒットするようにしなさいと仕様が変更されたのです。

他に方法あるでしょうか? って自分で考えろという感じですが、
いろいろと調べてはいるのですが、思いつきません。。

129 名前:nobodyさん mailto:sage [03/04/27 22:21 ID:???]
>>128
ふつうにorすればいいのでは。。。

130 名前:121 [03/04/27 22:41 ID:u/4ug4s4]
> 129

すいません、where andではなく、where or で、遅くなるという意味です。

131 名前:nobodyさん mailto:sage [03/04/27 23:03 ID:???]
>>128
>設計ミスか余計な機能ではとありますが、検索対象の列が5つあって、
>最初はそれぞれにかければいいという仕様でしたが、5つのどれかに
>ヒットするようにしなさいと仕様が変更されたのです。

そんなの、仕様変更されるのが当たり前だな。
仕様変更に対応できるようにしてなかった設計ミス。

ところで、230万件×5の全文検索ってMySQLなら速くできるのかな?

132 名前:nobodyさん mailto:sage [03/04/27 23:07 ID:???]
>>130
検索対象のカラムにindexは張ってあるの?


133 名前:122 mailto:sage [03/04/27 23:32 ID:???]
>>123
psqlで充分ってか。ある意味うらやますぃ。
個人的には使っていこうと考えているけど、確かにpsqlで充分かもね。


134 名前:nobodyさん mailto:sage [03/04/28 01:11 ID:???]
>>132
index張ってあっても、like '%語句%'で検索するなら意味ないと思われ。

135 名前:132 mailto:sage [03/04/28 02:16 ID:???]
>>134
あー、likeで%から始まる奴は駄目だね。
ホントに全文検索っぽくやってるとしたら、like '%語句%'ってやってる
可能性は高いか。

121にもうちょっと情報を出してホスィところだなぁ。



136 名前:nobodyさん mailto:sage [03/04/28 11:27 ID:???]
where coalesce(列1,'') || coalesce(列2,'') || coalesce(列3,'') like '%検索ワード%'explain してみたら、costは同じだけどrowsは or より少ないよ

137 名前:121 [03/04/28 13:42 ID:carn+S7w]
>> 134,135
ご指摘の通り、like '%語句%'とやっております。

実は今からでもテーブルの設計は変更可能なのですが、
どのように変更したらよろしいでしょうか。

今はID,NAME,AA,BB,CC,DD,EEというカラム構成で、
AA,BB,CC,DD,EEの中で、どれかに検索キーワードがあればヒットする
というようにしたいです。

>> 136
こちらありがとうございます。
coalesceってこういう時に使うのですね。習ってはいたのですが、
いつ使うんだろと思っていました。勉強になります。

138 名前:nobodyさん mailto:sage [03/04/28 15:37 ID:???]
>>121
>>127

139 名前:nobodyさん mailto:sage [03/04/29 11:45 ID:???]
textの部分一致は、例えば「abcdefg」という文字列があったとして、
like '%cd%' とすると遅くなるから、

abcdefg
bcdefg
cdefg
defg
efg
fg
g

というテーブルを別に作って、like 'cd%' すると速くなるよ、と
言われたことがある。もちろん、インデックス作って。

実際自分でやってみたことはないが。



140 名前:121 [03/04/29 18:01 ID:JKdqeuMi]
>> 127
正規化については、こちらを読みました。
www.rfs.jp/sitebuilder/sql/01/06.html

今回のケースとは特に関係ないかと思うのですが、私の洞察力不足でしょうか。

>> 139
ありがとうございます。
そこまでやると複雑になるので、おとなしくMySQLに移行するかと思って
しまいます。。

141 名前:nobodyさん [03/04/29 19:13 ID:8zWvKIjl]
my.vector.co.jp/servlet/System.FileDownload/download/ftp/0/281853/pack/win95/game/table/pachinko/SUTING.LZH

142 名前:あぼーん mailto:あぼーん [あぼーん]
あぼーん

143 名前:しろ mailto:sage [03/04/30 09:50 ID:???]
>140
> 正規化については、こちらを読みました。
> www.rfs.jp/sitebuilder/sql/01/06.html
> 今回のケースとは特に関係ないかと思うのですが、私の洞察力不足でしょうか。

今回のケースと関係あるかないかどうかは「ID,NAME,AA,BB,CC,DD,EE」では判りません。
NAME,AA,BB,CC・・・が、名前、住所、電話番号、メールアドレス・・・などだったら
この部分に関しての正規化の必要はないかもしれません。

しかし、NAME,AA,BB,CC・・・が、担当者、商品名A、商品名B、商品名C・・・などだったら
必要ありますね。

とうわけで、あなたの洞察力不足かどうかは、構造がわからないので
なんともいえないです。

144 名前:nobodyさん mailto:sage [03/04/30 14:44 ID:???]
正規化汁!と言ったひとの早とちりでしょう。

145 名前:121 [03/04/30 22:31 ID:0656yZRu]
>> 143

NAME,AA,BB,CC・・・は、担当者、商品名A、商品名B、商品名C・・・という
構造です。特にカラムが一緒ではないので、正規化は関係ないかと思うのですが、、、
ちがいます?




146 名前:nobodyさん mailto:sage [03/04/30 22:44 ID:???]
>>145
それって、担当者「NAME」が最近扱った商品A、B、C、Dとか…?
そういうパターンだったら正規化の対象だと思ふ。

147 名前:146 mailto:sage [03/04/30 23:01 ID:???]
(担当者テーブル: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
というカラムにならないといけない状況があまり想像つきませぬ。。







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

前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