2ちゃんねる ■掲示板に戻る■ 全部 1- 最新50    

【緊急】腕に覚えのあるプログラマー来てくれ!!

1 :ひろゆき代理:2006/03/09(木) 18:59:22 ID:QGdZvsUO.net
>鯖まとめ
>旧鯖 http://info.2ch.net/webwerewolf/index.htm
>新鯖 http://info.2ch.net/jinro/index.php
>新新 http://info.2ch.net/jinro2/jinro_index.htm

本スレ
http://live22x.2ch.net/test/read.cgi/news/1141871872/

要約:
現在ひろゆきが人狼プロジェクトでCGI等のテストをしているわけだが
いろいろぐだぐだなわけだ
そこでこの板のみんなにいろいろ改造してほしいわけだ

2 :nobodyさん:2006/03/09(木) 19:01:07 ID:xa6y59HU.net
ごめんねν速民バカばっかりでごめんね(´・ω・`)

3 :nobodyさん:2006/03/09(木) 19:01:49 ID:C0OBrQez.net
age

4 :nobodyさん:2006/03/09(木) 19:01:53 ID:Ff1SNRQU.net ?#
2げっと

5 :nobodyさん:2006/03/09(木) 19:05:07 ID:QGdZvsUO.net
過疎板だなw

6 :nobodyさん:2006/03/09(木) 20:53:08 ID:???.net
久しぶり新しい話題のスレだね。

7 :ひろゆき:2006/03/09(木) 20:56:49 ID:bXqf7Oar.net ?#
http://f45.aaa.livedoor.jp/~netfilms/
ファイルはここですー

8 :nobodyさん:2006/03/09(木) 20:57:52 ID:r4Q+iI7I.net
狐にお願いしろよ

9 :nobodyさん:2006/03/09(木) 21:19:48 ID:???.net
お、みんなで弄るのか
モリタポとか絡むならひ(ryとその仲間の妖弧で弄るのかと思ってた
まあ、そっちだけ自力で弄ればいいのか、、、

10 :nobodyさん:2006/03/09(木) 21:33:04 ID:???.net
webprog板でやれよボケって書こうと思ったらここwebprog板だった

11 :nobodyさん:2006/03/09(木) 22:12:56 ID:fEiFeGWn.net
>>10
ワロウタ

12 : 【compose:32】 速い人:2006/03/09(木) 23:51:23 ID:???.net ?
たのむぜみんな

13 :nobodyさん:2006/03/10(金) 02:51:16 ID:???.net
▼ game_veiw.php
193:print("<a href=\"user_manager?room_no=$room_no\"><strong>[住民登録]</strong></a>");
↑は↓
  print("<a href=\"user_manager.php?room_no=$room_no\"><strong>[住民登録]</strong></a>");
でFA?

14 :nobodyさん:2006/03/10(金) 02:54:10 ID:TZTUU+9Q.net ?#
>>13
あいあい。必須です。

15 :nobodyさん:2006/03/10(金) 02:55:46 ID:TZTUU+9Q.net ?#
http://info.2ch.net/jinro/watch_log.txt
old_log.phpをちょこっと改造しただけですが、
過去ログみるやつです。


16 : 【compose:32】 速い人:2006/03/10(金) 03:37:07 ID:???.net ?
>>15
ひろゆきが名無しで発言はじめてみた

口癖の「あいあい。」とbeですぐわかったけど

17 :nobodyさん:2006/03/10(金) 04:39:45 ID:???.net
元ネタ知らないから、何をしたいのかさっぱりわかんない。

18 :nobodyさん:2006/03/10(金) 04:53:49 ID:???.net
>>14-15
ありがとです。
ところでところで、過去ログみるやつのSQLデータ
ちょこっとだけ恵んでほしいかも。。無理でしょか??

19 :ひろゆきのビジョン(私見で抜粋):2006/03/10(金) 04:55:35 ID:???.net
http://live22x.2ch.net/test/read.cgi/news/1141784985/351+373+385+393

351 名前:番組の途中ですが名無しです[] 投稿日:2006/03/08(水) 13:02:03.79 ID:expAqeMd0
人狼って別に新しいことでもないと思うんだけど、なんでひろゆきが始めたんだろ。

373 名前:ひろゆき[] 投稿日:2006/03/08(水) 13:09:20.35 ID:2Q5xWps60 ?#
>>351
勝者が賞金もらえたりランキングつけたりしたいなぁと。

ちょっとしたゲームのGMが職業になるってのもありだと思うんだけどなぁ。

ゴールデン街のバーテンさんなんで1日に10人ぐらいの相手してるだけで、
暮らしてたりするわけで。
MMOみたいに何万人を相手にするんじゃなくて、
ちょっとした人数でちょっと楽しいってものが、
乱立したほうが選択肢としては面白いと思うんだけどなぁ。

385 名前:番組の途中ですが名無しです[] 投稿日:2006/03/08(水) 13:12:30.31 ID:expAqeMd0
>>373
ちょっと面白そう。
TV番組のチーターとか昔のヘキサゴンを一般人が賞金付きでやれたらいいなあとか思ってたけど
そんな感じ?

393 名前:ひろゆき[] 投稿日:2006/03/08(水) 13:14:36.64 ID:2Q5xWps60 ?#
>>385
人狼はあくまで1例なんだけど、ちょっとしたゲームを数人とやりたい。
でも、yahooゲームとかだと、緊張感もないし、
すぐに切断されるので、ある程度緊張感があって、
ホスト役の人がいるところのほうが楽しい。

っていうプレイヤーと、ある程度ホスト役をするだけで、
生活の糧になるってのをマッチングさせると面白いかなぁと。

20 :現在までの経過(私見で抜粋):2006/03/10(金) 05:02:55 ID:???.net
http://live22x.2ch.net/test/read.cgi/news/1141871872/421+660+690+692+947

421 名前:ひろゆき[] 投稿日:2006/03/09(木) 17:44:21.72 ID:yUANQFXM0 ?#
いまのところ、3種類のスクリプトがあって、
3種類なりに一長一短で、各々の長所を調べた上で、
どれをベースにして長所を移行するかってのを考えてるですよ。

660 名前:ひろゆき[] 投稿日:2006/03/09(木) 22:05:09.01 ID:yUANQFXM0 ?#
perl版のはディレクトリロックだから、やっぱり負荷には向いてない予感。
690 名前:ひろゆき[] 投稿日:2006/03/09(木) 22:07:34.25 ID:yUANQFXM0 ?#
高負荷になる>ロックが頻繁になる>ロックの削除が間に合わなくなる。
>ますますリロードする>ますますロックが削除されない。

以下ループ

692 名前:ひろゆき[] 投稿日:2006/03/09(木) 22:07:57.20 ID:yUANQFXM0 ?#
ベースをphp版にしないとやっぱりだめっぽい。

947 名前:ひろゆき[] 投稿日:2006/03/10(金) 01:54:30.80 ID:jCCNow5z0 ?#
perlのほうは壊れるので、phpを使いやすくすることにしたおいらなのですよ。

21 :nobodyさん:2006/03/10(金) 05:05:55 ID:TupY/dMM.net ?#
特定のテーブルのdumpの仕方がわかってないおいらです。。

22 :現在までの経過(私見でまとめ):2006/03/10(金) 05:09:36 ID:8amhdBES.net
というわけでν速民に煽られながら↓を一人で弄ってる方がいらっしゃいます
これはとても危険な状況です、どなたか助けを、、、

【テスト中URL】
汝は人狼なりや?〜テスト〜
http://info.2ch.net/jinro/index.php

【使ってるファイル】
汝は人狼なりや?のPHP+MySQL移植版(from ふたば)
http://f45.aaa.livedoor.jp/~netfilms/

23 :nobodyさん:2006/03/10(金) 05:21:18 ID:???.net
phpはマルチバイト実行でこけるぐらい無知なんだけど、
DBにまるなげならロックうんぬん関係ないよね?違ってる?

24 :関連スレ・過去スレ:2006/03/10(金) 05:23:07 ID:8amhdBES.net
【ニュース速報板現行スレ】
【首都警】 人狼テスト中 その4 【セクト】
http://live22x.2ch.net/test/read.cgi/news/1141929220/

【ニュース速報板関連過去スレ】
人狼のテストをするので、暇な人よろしくよろしく。  (part1)
http://live22x.2ch.net/test/read.cgi/news/1141784985/
【紅い眼鏡】 人狼テスト中 【ケロちゃん】  (part2)
http://live22x.2ch.net/test/read.cgi/news/1141807114/
【首都警】 人狼テスト中 その3 【セクト】
http://live22x.2ch.net/test/read.cgi/news/1141871872/

ニュー速の現行スレはすぐ消化されてしまうと思われます
なんかわかりにくく、いろいろ漏れてると思いますが
とりあえず以上(>>19+20+22)がニュー速での流れっぽいものです
どなたかフォローよろしく

25 :nobodyさん:2006/03/10(金) 05:30:06 ID:TupY/dMM.net ?#
>>23
テーブルロックを使ってるみたいですが、
競合でデータ飛んだりってのはないです。

26 :nobodyさん:2006/03/10(金) 05:36:46 ID:???.net
システムは判ったけど、賞金つけるって無理じゃないかな。
アクセスが減る時間帯とかで、八百長が簡単にできそう。
ただの遊びでとどめるのが無難では?

27 :nobodyさん:2006/03/10(金) 05:42:57 ID:???.net
>>21
出力見つけてみました。↓

<?php
//▼ talkテーブルcsv出力
header("Content-Type: application/octet-stream");
header("Content-Disposition: attachment; filename=talk".date(ymd).".csv");
//サーバー名--localhost ユーザー名--root パスワード--pass
$dbHandle = mysql_connect("localhost","root","pass");
if ($dbHandle == False) {
print ("can not connect db\n");
exit;
}
//db名
$db = "jinro";
$sql = "select * from talk";
$rs = mysql_db_query($db,$sql);
$fields = mysql_num_fields($rs);
$rows = mysql_num_rows($rs);
for($i=0;$i<$rows;$i++){
for($j=0;$j < $fields;$j++){
print(mysql_result($rs,$i,$j));
if ($j < $fields - 1)
print(",");
}
print("\n");
}
?>

28 :nobodyさん:2006/03/10(金) 05:44:45 ID:???.net
↑つづき
ほしい度30%ぐらいなで、他のほにゃららややこしい理由でダメならぜんぜんOKです。

▼ インスパイア元
http://ns1.php.gr.jp/pipermail/php-users/2003-December/019800.html

29 :27-28:2006/03/10(金) 06:09:37 ID:???.net
今、すごいことに気づきました!
csv自分で作ってインポートすればイイっぽい。
ごめんなさい。お騒がせしました。。

30 :nobodyさん:2006/03/10(金) 06:21:39 ID:???.net
ただのdumpなら$ mysqldump [OPTIONS] データベース名 [テーブル名]だけど、
SQLコマンドでdumpってあったっけ?

31 :nobodyさん:2006/03/10(金) 06:35:34 ID:TupY/dMM.net ?#
mysqldumpでテーブル指定できたんすかぁ。

32 :nobodyさん:2006/03/10(金) 06:38:15 ID:TupY/dMM.net ?#
うは、なんか文字化けしまくりです。。

33 :nobodyさん:2006/03/10(金) 06:44:32 ID:???.net
出てくるデータはEUCっぽいから、クライアントに合わせてエンコしないと

34 :nobodyさん:2006/03/10(金) 06:55:20 ID:TupY/dMM.net ?#
mysqldumpでエンコード指定ってできますっけ?

35 :nobodyさん:2006/03/10(金) 07:05:42 ID:TupY/dMM.net ?#
フレームから呼び出すと時間表示が出るのですが、
「サーバとローカルPCの時間ズレ(ラグ含):210秒」
http://info.2ch.net/jinro/test/frame.html

ファイルを直接見ると、javascriptがうまく動かないようです。
http://info.2ch.net/jinro/test/game_play.htm

何が原因かわかりますでしょうかー?


36 :nobodyさん:2006/03/10(金) 07:17:25 ID:???.net
>>34
一度ファイルに書き出して、読むときに弄るぐらいしか。
でもそれなら、順番に読みだしながらエンコしていったほうが速いかも?
こちらWin機のみなので、シェルのコード指定できるかどうかは知らないです。

37 :nobodyさん:2006/03/10(金) 07:23:33 ID:???.net
>>35
1つめは保留で2つ目
コード内で沢山ある parent.frames['up'] これ。
フレーム名「up」を指定してあるから、
該当するフレーム名を持ったフレームがないとエラーになります。

38 :nobodyさん:2006/03/10(金) 07:37:46 ID:???.net
>>35の1つめ
function realtime_before_output()
{
php_now = new Date(2006,2,10,7,01,44);
local_now = new Date();
diff_sec = Math.floor( (local_now - php_now) / 1000);
document.realtime_form.realtime_output.value = "サーバとローカルPCの時間ズレ(ラグ含):" + diff_sec + "秒";
}
これ見る限りでは
local_now = new Date();  でローカルの時間
php_now = new Date(2006,2,10,7,01,44);  でCGIの出力した情報から計算した時間
で、時間は1/1000秒で返すので1000で割るんだけど、
これだけだとローカルが早いか鯖が遅いかぐらいしかわかりません。
phpがどのタイミングで時間を取っているかが問題かも。
出力を終えるギリギリで時間だしてるとは思うけど・・・

39 :nobodyさん:2006/03/10(金) 07:51:31 ID:???.net
ざっとコード追ってみたけど、わかる範囲では特におかしいところはないかと。

40 :nobodyさん:2006/03/10(金) 07:54:09 ID:???.net
perl版のwwwolfって、ファイルロック関連がアクセス多い時にダメになるらしいけど、
これを解決する方法ってのは無いのかね。

41 :nobodyさん:2006/03/10(金) 08:20:07 ID:???.net
perl版ってどこだろ・・

42 :nobodyさん:2006/03/10(金) 08:23:48 ID:???.net
ttp://park1.wakwak.com/~aa1/wwwolf/
ここからDLできるよ。

43 :nobodyさん:2006/03/10(金) 08:27:35 ID:???.net
見つけたけど、ファイルロック何もやってないよ?

44 :nobodyさん:2006/03/10(金) 08:29:59 ID:???.net
462 名前:ひろゆき[] 投稿日:2006/03/09(木) 17:57:26.49 ID:yUANQFXM0 ?#
こんな感じらしい。

>>442
元々、暴走癖があってちょいと無理して直したので、
データ消える可能性があるです。

463 名前:ひろゆき[] 投稿日:2006/03/09(木) 17:58:17.07 ID:yUANQFXM0 ?#
>>449
負荷が高いだけならいいんですが、
負荷が高いときに挙動が変になるのが1です。

470 名前:ひろゆき[] 投稿日:2006/03/09(木) 18:01:50.83 ID:yUANQFXM0 ?#
ディレクトリ生成でロックをしてるので、
ユーザーが1秒以内にアクセスし続けると永遠にロックしっぱなしみたいになったりするです。
ロック処理をするスクリプトというのは高負荷に絶えられるアルゴリズムでなかったりします。
あと、1のスクリプトだと、GMですら誰が投票してないかわからないのです。
3は投票してない人がわかるです。

45 :nobodyさん:2006/03/10(金) 08:31:44 ID:???.net
間違えてひろゆきの発言に「こんな感じらしい」って書いちゃったけどまあいいやw


46 :nobodyさん:2006/03/10(金) 08:41:34 ID:???.net
cgi実行開始しょっぱなからロックかけないといけないものなんですか?これ。
常にファイルに書き込む処理が存在するようには見えないけど。
他にもファイルをすぐ閉じる工夫とかしてないし、
ちゃんと整理してflockで十分なような・・・

47 :nobodyさん:2006/03/10(金) 08:45:58 ID:TupY/dMM.net ?#
とりあえず、upがついてる関数をはずしてみたらうまくいきました。
http://info.2ch.net/jinro/test/game_play2.htm

どうもですー。

48 :nobodyさん:2006/03/10(金) 08:47:20 ID:???.net
はーい

49 :nobodyさん:2006/03/10(金) 09:08:35 ID:???.net
>>46
perlかじった程度なのであまりわからないけど、sub disp_msgの辺りとか?
どうせ一気に出力するんだから、最初にまとめて全部読み込んでしまって、
1行ずつ抜き出して処理して吐き出すバッファに格納していく感じにすると、
ましになりそうって感じなのかな。

50 :nobodyさん:2006/03/10(金) 09:16:53 ID:???.net
ですね。
ゲーム系のCGIだと、メモリ犠牲にしてでも、ファイル解放させないと。
実際ファイルサイズがどれだけ膨らむか知りませんけど、

フェイズごとにファイル分けるとか、
データサイズ決めてアドレスへ直接読みにいくとか、
いくらでも軽量化の方法は・・・

51 :nobodyさん:2006/03/10(金) 09:54:58 ID:???.net
なるほどー。
ちょっと試してみた。
こんな感じの処理でいいのかな。
sub disp_msg{
〜ちょっとだけど省略〜

my @buffer;
my $logline;
open(IN, $file_log);
while (<IN>) { push(@buffer,$_); }
close(IN);
$log_line = @buffer;
while (@buffer) {
 $wk_msgwriteflg = 0;
 @wk_logdata = split(/\{\}/, shift(@buffer));
 〜以下略〜
}

52 :nobodyさん:2006/03/10(金) 10:15:08 ID:???.net
他に、ifの入れこが多すぎるので、
ifで分岐してからループまわした方が速い。
while () {
if () {
if () { ・・・よりも

if () {
while () {}
}
if () {
while () {}
}
・・・として
whileの中でnext連発してさっさとlastで抜けた方が速い。
でもって、展開するものがないならシングルクオートにするとちょびっと速い。
ダブルクオートの中で展開無しでエスケープ文字乱発では意味がない。

53 :nobodyさん:2006/03/10(金) 10:22:52 ID:???.net
なるへそー。
積み重ねで結構違ってくるって事ね。
という事はmyとかもどんどん設定してった方がいいか。
たしかlocalはmyとかグローバル変数より遅いって見た気がするから、その辺も要修正か。

負荷の面で結構いい勉強になりそうだな。

54 :nobodyさん:2006/03/10(金) 10:31:46 ID:???.net
使い捨ての変数はできるだけブロックの中で終わるようにする。
とりあえずuse strict;でも動くように心がける。
マッチしない条件が多いループをまわすとき、
パターンマッチする前に2度手間だけど先にindexで判断したほうが速いとか。

55 :nobodyさん:2006/03/10(金) 10:41:22 ID:???.net
use strict;はどの処理がどの名前空間にあるのかの把握が大変っぽそうなので
オレには厳しそうw
ただ、出来るだけmy使うように心がけるように気をつけねば。

>マッチしない条件が多いループをまわすとき〜
後で条件追加するとかの修正がわかりづらかったり面倒そうだけど、
そっちの方が負荷的にはかなり良さそうだね。
ただ、この辺まで弄ったらかなり大掛かりな改造になりそうな予感。
whileとforがたくさんあるから呼び出しをいかに減らすかでかなり変わってきそうだなぁ。

56 :594:2006/03/10(金) 11:33:40 ID:0Au2Ffzr.net
バグとコンパイルエラーの違いを教えて下さい。お願いします。

57 :nobodyさん:2006/03/10(金) 11:40:17 ID:TupY/dMM.net ?#
コンパイルの意味がわかってるのであれば、、、
バグでコンパイルができなくなるとコンパイルエラー。
バグが原因でコンパイルエラーは現象ですね。


58 :594:2006/03/10(金) 11:58:11 ID:0Au2Ffzr.net
>nobodyさん
ありがとうございます。
バグがある=コンパイルエラーって解釈でOKですか?

59 :nobodyさん:2006/03/10(金) 12:01:47 ID:???.net
ソースコードを機械語に翻訳できないのがコンパイルエラー
バグは想定していない挙動をすること。
バグっててもコンパイルは成功することもありますね。

60 :nobodyさん:2006/03/10(金) 12:02:58 ID:???.net
>>58 否

61 :nobodyさん:2006/03/10(金) 12:13:45 ID:TupY/dMM.net ?#
さらに言うと、コンパイルしない言語もあったりするので、、

62 :nobodyさん:2006/03/10(金) 12:18:48 ID:???.net
コンパイルできない原因はバグである。
コンパイル後実行できるが想定外の動きはバグである(仕様と言い張る場合もある)。
コンパイルしないインタプリタ言語(JavaScriptとかPerlとかPHPとか)で実行できない原因はバグである。
インタプリタ言語で想定外の動きはバグである(仕様と言い張る場合もある)

で、わかるかな・・・説明力無いや。

63 :みずき ◆WnmizUKIg6 :2006/03/10(金) 12:41:15 ID:Cff8UMLf.net ?
7 名前:あぼ〜ん[あぼ〜ん] 投稿日:2006/03/09(木) 20:56:49 ID:あぼ〜ん
あぼ〜ん

64 :nobodyさん:2006/03/10(金) 12:47:08 ID:???.net
BEのプロフで遠まわしに宣伝ですかそうですか。

65 :nobodyさん:2006/03/10(金) 14:07:35 ID:???.net
beのプロフでの宣伝は禁止されてないしー

66 :nobodyさん:2006/03/10(金) 15:24:27 ID:???.net
PHPならできるけどPerlは・・・ごめんなさい

67 :nobodyさん:2006/03/10(金) 16:44:21 ID:???.net
>>7
参照渡しはやめろといっぱい怒られた
でマニュアルでsscanfみたらちゃんと参照渡しにする必要があると書いてある

68 :nobodyさん:2006/03/10(金) 19:54:33 ID:Fu+U56m/.net
ニュー速現行スレ

【特機隊】 人狼テスト中 5村目 【プロテクトギア】
http://live22x.2ch.net/test/read.cgi/news/1141986358/

69 :nobodyさん:2006/03/10(金) 22:21:27 ID:???.net
コンパイルエラーは言語の文法的にあってるかどうか
バグは仕様と違う動きをするプログラム(文法としてはあってる)に潜むエラー
くらいの解釈で良いと思うです

70 :nobodyさん:2006/03/11(土) 03:31:36 ID:???.net
ttp://up.spawn.jp/file/up13517.jpg
誰かが作ってる?作品

71 :nobodyさん:2006/03/11(土) 21:22:12 ID:???.net
>>15
ゴールドの帯のところ消したのGJ!!
ブツ、わん、ひそ。で見えなくしてのどして?どして??

72 :nobodyさん:2006/03/11(土) 21:33:13 ID:???.net
日本語でおk

73 :nobodyさん:2006/03/12(日) 06:57:04 ID:LmfK++YC.net ?#
SELECT uname, handle_name, profile , user_id, count(*) from users group by user_id

こんな感じのsqlなのですが、同一のuser_idの中でprofileやunameがいろいろある場合には、
profileやunameに入る値を指定することは可能なんでしょうかー?




74 :nobodyさん:2006/03/12(日) 06:59:18 ID:???.net
>>73
なんだそのSQL

75 :nobodyさん:2006/03/12(日) 07:19:34 ID:LmfK++YC.net ?#
省略してますよ。

76 :nobodyさん:2006/03/12(日) 08:14:07 ID:???.net
>>73
INSERT INTO new_table1 ( uname, handle_name, profile, user_id, row_count, )
SELECT Max(uname), Max(handle_name), Max(profile), user_id, Count(*)
FROM users
GROUP BY user_id;

↑作ってみました。
でもでも、これだと(uname/handle_name/profile)文字列の最大値だけになっちゃう。。

77 :nobodyさん:2006/03/12(日) 08:20:55 ID:???.net
わ、row_count, の後ろの
, ←これいらないのです。。

78 :nobodyさん:2006/03/12(日) 09:16:12 ID:LmfK++YC.net ?#
おぉ、そこにも関数いれることができるんですね。

maxではなく、order by timeみたいに、最新のものを拾うようにするのは
難しいんでしょうか?

79 :nobodyさん:2006/03/12(日) 20:49:18 ID:???.net
自信なさげに、つ SELECT a.uname, a.handle_name, a.profile, a.user_id, MAX(b.f_time)
FROM t_users a INNER JOIN t_users b
ON a.f_time = b.f_time
GROUP BY b.user_id

80 :nobodyさん:2006/03/12(日) 21:05:50 ID:LmfK++YC.net ?#
うーん、やっぱりMAX(b.f_time) の数字だけ新しくなっちゃいますね。


81 :nobodyさん:2006/03/13(月) 06:11:24 ID:R9sGJ5J9.net ?#
諦めてwhileの中でもう一回SQLを呼ぶようにしてみました。


82 :nobodyさん:2006/03/13(月) 10:32:24 ID:???.net
>>80
何がしたいのかはっきり書けば、それに応じたSQLがだせるが、
後出しで仕様を追加すると相手にされなくなる。

83 :nobodyさん:2006/03/13(月) 12:10:01 ID:???.net
>82
ひろ(ryだし

>>81
常に最新の監視をしたいなら、監視専用ファイルに書き出す処理を増やせば楽になれるかも。
いちいちDB弄るより負荷へりそうだし。

84 :nobodyさん:2006/03/13(月) 12:38:32 ID:R9sGJ5J9.net ?#
>>82

win_lose ='w'の多い順にユーザーを並べたいのですね。
http://info.2ch.net/jinro/game_ranking.php


85 :nobodyさん:2006/03/13(月) 12:39:32 ID:R9sGJ5J9.net ?#
結果は最新のものじゃなくて、1時間に一回とかでも
いいといえば、いいんですが、
1回のSQLでやる方法があるんだったら、後学のために知りたいなぁ、と。
>>83


86 :nobodyさん:2006/03/13(月) 12:58:28 ID:???.net
>>84
order by [カラム名] descってことではなく?

87 :nobodyさん:2006/03/13(月) 18:25:44 ID:???.net
最新timeのuname(time8桁として)
SELECT SUBSTR(MAX(CONCAT(time,uname),9) AS uname,user_id, count(*) AS cnt
from users
group by user_id

88 :87:2006/03/13(月) 18:53:26 ID:???.net
まちがえっち
SELECT SUBSTRING(MAX(CONCAT(time,uname),9) AS uname,user_id, count(*) AS cnt
from users
group by user_id


89 :nobodyさん:2006/03/13(月) 18:58:44 ID:???.net
MySQLじゃ独自関数は作れないのか。

90 :nobodyさん:2006/03/13(月) 19:01:42 ID:???.net
ストアドのこと?

91 :nobodyさん:2006/03/13(月) 22:54:42 ID:???.net
機能追加して、つ SELECT a.uname, a.handle_name, a.profile, a.user_id, COUNT(*) AS f_win, MAX(b.f_time) AS time
FROM t_users a INNER JOIN t_users b
ON a.f_time = b.f_time
GROUP BY b.user_id
ORDER BY f_win DESC

92 :nobodyさん:2006/03/13(月) 23:40:27 ID:???.net
返事待たずに次々出しても意味ないっしょ

93 :nobodyさん:2006/03/14(火) 00:12:48 ID:???.net
次々?

94 :nobodyさん:2006/03/14(火) 00:15:17 ID:???.net
このスレの質問者はひ(ryだけ

95 :nobodyさん:2006/03/14(火) 00:24:18 ID:???.net
>>88>>89じゃないの?

96 :nobodyさん:2006/03/14(火) 03:26:54 ID:???.net
うわー、勘違いしてたみたい。。
>>88ごめんね、ごめんね。

97 :nobodyさん:2006/03/14(火) 11:10:24 ID:???.net
>>89
作れるよ。Stored ProcedureじゃなくてFunctionという機能。

98 :nobodyさん:2006/03/14(火) 12:36:06 ID:bajFWcox.net ?#
SUBSTR(MAX(CONCAT(time,uname),9)
おぉ、、こんな手があるんすかぁ。

99 :nobodyさん:2006/03/14(火) 13:00:34 ID:bajFWcox.net ?#
groupでまとめちゃうと、whereって使えなくなるんですよね。。

100 :nobodyさん:2006/03/14(火) 13:03:33 ID:???.net
havingは?

101 :nobodyさん:2006/03/14(火) 13:18:53 ID:bajFWcox.net ?#
havingの使い方がいまいちわかってません。
having win_lose ='w'とかやるとエラーでるですよ。


102 :nobodyさん:2006/03/14(火) 13:25:50 ID:???.net
何をgroupにしたの?

103 :nobodyさん:2006/03/14(火) 13:28:58 ID:???.net
と言うか、何がしたいの?

104 :nobodyさん:2006/03/14(火) 13:33:55 ID:bajFWcox.net ?#
>>84に書いたとおりで、win_lose ='w'の人をカウントしたいのですね。


105 :nobodyさん:2006/03/14(火) 13:40:45 ID:???.net
テーブル構造分からないけど

select user_id, count(user_id)
from users
where win_lose = 'w'
group by user_id
order by count(user_id) desc

な感じじゃダメなも?

106 :nobodyさん:2006/03/14(火) 14:05:18 ID:bajFWcox.net ?#
>>73-
に繋がるわけです。


107 :nobodyさん:2006/03/14(火) 16:49:48 ID:???.net
uniqueなkeyってどれなの?

108 :nobodyさん:2006/03/14(火) 16:51:26 ID:???.net
ごめん、primary keyの間違い

109 :nobodyさん:2006/03/14(火) 19:09:09 ID:???.net
>>106
だから >>73「同一のuser_idの中でprofileやunameがいろいろある場合には、
profileやunameに入る値を指定することは可能なんでしょうかー?」
の「指定」って言ってる条件はなんなん?

user_id,profile,uname,win_lose,time
1,aho,baka,w,2006-03-14 19:00:00
1,roli,hiroyu(ry,w,2006-03-14 16:00:00
1,hoge,piyo,w,2006-03-12 11:00:00
のどれがほしいのよ

110 :nobodyさん:2006/03/14(火) 20:14:08 ID:bajFWcox.net ?#
timeの最新のやつです。


111 :nobodyさん:2006/03/14(火) 20:25:15 ID:???.net
奈良、88でできるんじゃね?
SELECT
user_id,
SUBSTRING(MAX(CONCAT(time,profile),9) AS profile,
SUBSTRING(MAX(CONCAT(time,uname),9) AS uname,
MAX(time) AS time,
COUNT(*) AS cnt
FROM users
WHERE win_lose = 'w'
GROUP BY user_id

でどうよ。

112 :88:2006/03/14(火) 20:28:10 ID:???.net
>>111はtime8桁だった
DATETIMEだったら桁位置変えてね
ORDER BYも忘れてた^^;

113 :nobodyさん:2006/03/15(水) 01:36:59 ID:Xx3u1KAj.net ?#
それが、timeにあたる値が、1からのauto incrimentなので桁数が可変だったんですよ。。


114 :nobodyさん:2006/03/15(水) 02:13:00 ID:???.net
>>113
ちと考えればできるつーに
SUBSTRING( MAX( CONCAT(LPAD(time,10,'0'),uname) ), 11) AS uname,


115 :nobodyさん:2006/03/15(水) 03:16:20 ID:Xx3u1KAj.net ?#
おぉ、LPADなんて関数があるんすか。


116 :nobodyさん:2006/03/15(水) 03:29:52 ID:???.net
WebProgのお約束だから言っとくね



マニュアル嫁
http://dev.mysql.com/doc/refman/4.1/ja/string-functions.html

117 :nobodyさん:2006/03/15(水) 04:05:34 ID:Xx3u1KAj.net ?#
いやはや、どもども。

どうも最新の結果が出てないっぽいのですね。
SELECT max(room_no) ,SUBSTRING( MAX( CONCAT(LPAD(room_no,10,'0'),profile) ), 11) AS profile,
be_userid ,count(*) as winning , SUBSTRING( MAX( CONCAT(LPAD(room_no,10,'0'),uname) ), 11) AS uname
FROM `user_entry` where `win_lose` = "w" group by be_userid order by winning DESC LIMIT 20;

SUBSTRING( MAX( CONCAT(LPAD(room_no,10,'0'),profile) ), 11) AS profile
の部分のroom_noがMAXでないからかと思ったのですが、
エラーがでちゃうんですね。

SELECT max(room_no) ,SUBSTRING( MAX( CONCAT(LPAD(max(room_no),10,'0'),profile) ), 11) AS profile,
be_userid ,count(*) as winning , SUBSTRING( MAX( CONCAT(LPAD(room_no,10,'0'),uname) ), 11) AS uname
FROM `user_entry` where `win_lose` = "w" group by be_userid order by winning DESC LIMIT 20;
ERROR 1111 (HY000): Invalid use of group function



118 :nobodyさん:2006/03/15(水) 04:40:35 ID:???.net
元のコード読んでないけど、監視用のフラグかなんかを保存するカラム追加したらダメなの?

119 :nobodyさん:2006/03/15(水) 04:49:29 ID:???.net
>>117
MAX(room_no)だとGROUPされた中のMAXと不定なprofileがくっつくのでエラーでなくてもだめぽい
GROUPされた中の一番大きいroom_no+profileを取得してるんだけどね

>どうも最新の結果が出てないっぽいのですね。
先のやつでSUBSTRINGを取ってどのroom_noが取得されているか調べてみたらどう?てか調べてみた?

マニュアルにまんま例があった
http://dev.mysql.com/doc/refman/4.1/ja/example-maximum-column-group-row.html

120 :nobodyさん:2006/03/15(水) 05:19:22 ID:Xx3u1KAj.net ?#
監視用のフラグといいますと?

SUBSTRINGを取って原因を把握してみました。
whileループのときは、where `win_lose` = "w"をしてなかったんで、
wでもlでも最新のプロフィールを返していたようです。
というわけで、仕様としては上記でOKだったようです。

マニュアルにまったく同じことをやってる人がいたんですねぇ、、

「ただし、MAX と CONCAT を使用した、非効率的な手段を使用する必要があります。」
素直にテンポラリーテーブルを作るほうが効率がいいみたいですね。


121 :nobodyさん:2006/03/15(水) 05:39:23 ID:???.net
>>120
工エエェェ(´д`)ェェエエ工工
いっかいPHPくだ質でもいって質問の仕方覚えて恋

テンポラリがいいか非効率でも関数ですませるかは元のテーブルの件数やインデックス
なんかにもよると思うよ
メモリーにでもテンポラリが作れればいいのかもしれないが

122 :nobodyさん:2006/03/15(水) 05:58:29 ID:???.net
文字列をゴリゴリ処理するなら、多少面倒でもPerlで組んだ方が楽なんだよなぁ・・・速いし・・・

123 :nobodyさん:2006/03/15(水) 06:15:58 ID:???.net
>>117
ノシ
select a.uname, a.handle_name, a.profile, a.be_userid, a.win_lose, count(a.win_lose) as w_kazu, max(b.room_no) as new_room
from user_entry a inner join user_entry b on a.room_no = b.room_no
group by b.be_userid having a.win_lose='w' order by w_kazu desc

124 :参加者募集中!:2006/03/15(水) 23:15:48 ID:cWKpq76B.net
株式@2ch
★★★自動売買ソフトを作ろうぜ★★★ Part3
http://live19.2ch.net/test/read.cgi/stock/1141718486/l50


125 :nobodyさん:2006/03/15(水) 23:17:57 ID:???.net
>124
金のないヒキに無縁の話です

126 :nobodyさん:2006/03/15(水) 23:19:50 ID:cWKpq76B.net
>>125
システム完成させてPC働かせて金持ちになろうぜ!

★★★自動売買ソフトを作ろうぜ★★★ Part3
http://live19.2ch.net/test/read.cgi/stock/1141718486/l50

127 :nobodyさん:2006/03/15(水) 23:26:25 ID:???.net
金より仕事が欲しい。
仕事を認めてくれる上司が欲しい。

128 :nobodyさん:2006/03/16(木) 03:45:36 ID:???.net
>>1
いちいち覚えてなんかねーよw

129 :nobodyさん:2006/03/16(木) 06:14:41 ID:I7rM2pBX.net ?#
どうもですー>123さん

130 :nobodyさん:2006/03/17(金) 07:27:14 ID:???.net
ひろゆきが真面目に動いてて嬉しいんだが、とりあえず鯖の時計を合わせてほしい…

131 :nobodyさん:2006/03/17(金) 07:51:26 ID:???.net
ニワンゴどうなったのやら

132 :nobodyさん:2006/03/24(金) 09:32:57 ID:???.net
人狼テスト中
http://live22x.2ch.net/test/read.cgi/news/1143048269/

133 :nobodyさん:2006/03/26(日) 01:11:47 ID:???.net
ひろゆきどんひろゆきどん
同一IPが同時に1つの村に存在しないようにしてほしい、要するに多重禁止
あと村の上限数を設定して欲しい、乱立すると困る

134 :nobodyさん:2006/03/29(水) 09:19:35 ID:???.net
人狼テスト中 inニー速(pink)
http://sakura03.bbspink.com/test/read.cgi/neet4pink/1142306048/

135 :nobodyさん:2006/04/05(水) 02:25:10 ID:???.net
無念
友達
法則発動


この辺の文字が文字化けするんだけどなんでよ?

136 :nobodyさん:2006/04/06(木) 04:32:59 ID:???.net
>>135
どういう文章で出てきたかの方が気になってしかたないです。友達はともかく。

137 :nobodyさん:2006/12/15(金) 18:45:25 ID:???.net
>>135
別に化けてないですけど

138 :nobodyさん:2007/02/11(日) 17:18:01 ID:UqZVZIaT.net
エラーが出て入れねえ

139 :nobodyさん:2007/02/16(金) 05:06:18 ID:masZTrFY.net
FORTRAN77できる人いませんか?
お願いがあります。。

140 :nobodyさん:2007/02/16(金) 13:57:03 ID:7eoa/RCZ.net
いた違いだろ >>139

141 :nobodyさん:2007/02/20(火) 05:25:25 ID:VMSdVaF4.net
【ネット】ドワンゴ、2chねらーから人材募集 専用スレで求人広告
http://news22.2ch.net/test/read.cgi/newsplus/1171874937/

142 :nobodyさん:2007/02/20(火) 07:03:15 ID:???.net
【心の】旦那には絶対言えない過去4【奥に】既婚女性板
http://human6.2ch.net/test/read.cgi/ms/1168957905/

48 名前:可愛い奥様[sage] 投稿日:2007/02/04(日) 19:39:27 ID:b/0RSFnH0
結婚前に子供を2回オロシタことがあるのと、煙草をやめていないこと
お腹の赤が旦那の子かどうか微妙なこと

今の旦那と結婚して2年目、現在妊娠中(8ヶ月)
子供ができたってわかってからは何しても耐えるし、家事もしなくてよくなった。
一度、どこまで言ったら怒るのか試したけど、旦那・旦那の実家・仕事
生い立ち・SEX・趣味・お腹の赤、いろいろ文句言ってみたけど意地になって
耐えてた。でも目つきが悪かったから、その目つきで赤が死んだり障害が
あったりしたらお前のせいだ!って言ったら土下座してた。

旦那の財布を見たら心療内科の診察券があったから、どうやら薬で耐えてる
みたい。それもムカついたからやめさしたけど。
これで、私が子供をオロシタ経験者なんて知ったらどうなるんだろう?
ついでにお腹の赤の顔がまったく似てなかったらどうしよう。
殴っても耐えるし…ばれる前に離婚したいって言葉を引き出さないとマジでやばい。

59 名前:可愛い奥様[] 投稿日:2007/02/04(日) 22:00:10 ID:3Z4niqV20
息子は旦那の父親(銀行家)の子供

83 名前:可愛い奥様[] 投稿日:2007/02/06(火) 07:46:34 ID:rlNYiksj0
結婚してから、旦那以外で10人以上の男性と浮気したこと。

92 名前:可愛い奥様[] 投稿日:2007/02/09(金) 23:46:04 ID:QRXcETQYO
セクキャバでバイト経験あり。援交しまくり時代もあり。ヤッた数は100人くらい。
私バツイチで今の旦那には元夫の浮気が原因で離婚したの。とか言ったけどほんとは逆。
好きな人できて夫捨ててのりかえた。浮気しまくりだった。

143 :電脳プリオン:2011/11/11(金) 21:18:08.54 ID:???.net ?2BP(1960)
人狼プロジェクトって今どうなってるの?

144 :nobodyさん:2013/04/13(土) 12:45:45.17 ID:Uz9Yz0J4.net
さあ?

145 :nobodyさん:2013/04/14(日) 00:12:39.81 ID:n+jRC3Rs.net
◎じゃあのさん来た◎

230:以下、名無しにかわりましてVIPがお送りします[]
2013/04/13(土) 23:42:55.05 ID:DLhfuF/M0
じゃあ、俺がおもしろショー代わりに開いてやんよwww
これから神奈川の九条の会の賛同者たちを順番に晒してこうと思うんだwww
名案だろお?www

--- 以下スレ情報 ---
高岡さんがフジ韓流ゴリ押し批判したら干されたのでウジテレビ凸
http://hayabusa.2ch.net/test/read.cgi/news4vip/1365850484/

146 :エシュロンなど:2013/06/01(土) 01:12:33.55 ID:???.net
長年、嫌がらせをされています。
工作員 エージェント ネイサン シークレット・ガバメント 最上位首謀者 で検索。

147 :nobodyさん:2013/08/10(土) NY:AN:NY.AN ID:ymd4PZ+n.net
ミニブログサイト『Croudia』がレートリミット無制限のAPIを公開
http://croudia.co.jp/NR20130731.html

148 :nobodyさん:2017/12/30(土) 13:50:10.91 ID:YhlYw6jg.net
誰でも簡単にネットで稼げる方法など
参考までに、
⇒ 『半藤のブブイウイウレレ』 というサイトで見ることができます。

グーグル検索⇒『半藤のブブイウイウレレ』

GJMFZG6TPG

149 :nobodyさん:2023/07/29(土) 19:23:33.70 ID:/3bmqrNwH
(入れてはならない政党5大税金泥棒政策)
観光促進‥温室効果カ゛スに騒音にコ□ナにとまき散らして気候変動災害連発させて國土破壞して人を殺して儲ける強盗殺人推進腐敗テ口国家な
軍備拡張‥ウクライナは軍事費GDP比4%超て゛脅威視されて攻撃されたわけが,白々しく挑発して軍拡利権を獲得したい岸田異次元増税文雄
金融緩和…資本家階級資産倍増.もはやひとりて゛資産1兆円超、末代まで揺らぐことのない圧倒的格差社会優越的地位濫用促進政策な
孑供給付‥全國航空騷音まみれで勉強まて゛妨害しなか゛ら.貧乏人に不幸な子を産み落とさせて遺棄を推進する国家犯罪地球破壊人殺し政策な
     正しい孑供政策とは、ひとり産むこ゛とに5千万課税,払える見込みか゛なければ日当5千円て゛塀の中から子に送金させることだろ
原発稼働‥クソポリへリ含むクソ航空機ハ゛ンバン飛ばしまくって莫大な石油を無駄に燃やしまくって威力業務妨害による知的産業壞滅によって
     システ厶障害まみれのポンコツ腐敗後進國か゛笑わせよる。テ口リスト自民公明か゛第二のフクシマ利権確保したいだけなのか゛ハ゛レハ゛レ

創価学会員は、何百萬人も殺傷して損害を与えて私腹を肥やし続けて逮捕者まで出てる世界最悪の殺人腐敗組織公明党を
池田センセ―か゛囗をきけて容認するとか本氣で思ってるとしたら侮辱にもほと゛があるぞ!
htTPs://i、imgur.соm/hnli1ga.jpeg

39 KB
新着レスの表示

掲示板に戻る 全部 前100 次100 最新50
名前: E-mail (省略可) :

read.cgi ver 2014.07.20.01.SC 2014/07/20 D ★