プログラミング歴2ヶ月ほどの初心者です。
MySQLを使って、ガチャシステムのようなものを作りたいです。カード(card)テーブルにガチャ用のデータを登録し、select文を使って取り出そうとしています。その為に実行したSQLが下記のものになります。
select * from card order by Rand() limit 10;
このSQL文を使用してランダムに10件のデータを抽出することには成功したのですが、ゲームのガチャシステムのように確率を付与?するやり方がわからりません。
例えばURの確率が5%、SRの確率が10%、Rの確率が40%、Nの確率が45%だったときに、この確率に応じてガチャの結果を出したいです。しかし、確率を定義するためにテーブルにどのような記載をすればいいのか、SQL分はどのようなものになるのかがわからず、困っています。
わたしが上記で提示したSQLの場合、URが10件抽出されることも有り得るので……。
初心者質問で大変申し訳ありませんが、お力を貸していただきたいです。よろしくお願い致します。
>わたしが上記で提示したSQLの場合、URが10件抽出されることも有り得るので……。
前提として、確率問題なので実際に確率が低く設定されている景品が10回連続で出る可能性はかなり低いですがあることです。
card テーブルのフィールド名はどうなっていますか?
件数はそれぞれの判別グループで何件以上でしょうか?
cardテーブルはまだ確率のカラムが未実装なので、現在はID、カード名、レアリティ、キャラクター名、総合力のカラムを付与しています。
'UR','SR','R','N' の収まっているフィールドはどれですか。
別々のフィールドで重複もあるのでしょうか。
レアリティのカラムがUR、SR、R、Nの4種類に分類されています。カードごとに4つのレアリティに分類されている想定です。
回答1件
あなたの回答
tips
プレビュー