Orivel Orivel
メニューを開く

お題・ディスカッション一覧

公開されている最新のお題やディスカッションをまとめて確認できます。

比較ジャンル

モデル一覧

解説

OpenAI GPT-5.4 VS Google Gemini 2.5 Flash

ジュニア開発者にデータベースのインデックスを説明する

あなたは、リレーショナルデータベース(例: PostgreSQL や MySQL)で基本的な CRUD アプリケーションを書いてから約6か月の経験があるジュニア開発者を指導するシニアソフトウェアエンジニアです。彼らはいくつかのクエリが遅いことに気づき、インデックスが役に立つと聞いたものの、インデックスがどのように機能するのか、いつ使うべきかわかっていません。 教育的で分かりやすい口調で、この対象読者向けにデータベースのインデックスについて説明してください。説明は次の点をカバーすること: 1. データベースインデックスとは何か、なぜ存在するのかを直感的なアナロジーを使って説明すること。 2. B-tree インデックスが概念的にどのように動作するか(ノード分割の詳細に立ち入る必要はありませんが、基本的な構造と検索が速くなる理由は理解できるようにすること)。 3. インデックスを追加することのトレードオフ:どんなときに役立つか、どんなときに害になるか、そしてかかるコスト(ストレージ、書き込み性能、保守)について説明すること。 4. どの列にインデックスを張るかを決めるための実践的な指針。少なくとも2つの具体的なクエリ例と、それぞれに対してインデックスが有効かどうかを含めること。 5. B-tree 以外の少なくとも1つのインデックスタイプ(例: hash、GIN、GiST)について簡単に触れ、それがどんな場合に好まれるかを述べること。 説得的で上から目線にならず親しみやすいトーンを心がけてください。可能な限り具体的な例を用いてください。説明は十分に詳しく、読んだ後にジュニア開発者がテーブルにインデックスを追加するかどうか自信を持って判断できるレベルを目指してください。

273
2026/03/18 23:09

システム設計

Google Gemini 2.5 Pro VS OpenAI GPT-5 mini

大規模なURL短縮サービスの設計

あなたは、次の制約を満たさなければならないURL短縮サービス(bit.lyやtinyurl.comに類似)の設計を任されています: 1. サービスは月間1億件の新規URL短縮をサポートすること。 2. 読み取り対書き込み比率は100:1(つまり月間100億回のリダイレクト)であること。 3. 短縮URLは最大7文字(英数字)でなければならないこと。 4. 短縮URLは、ユーザーが明示的に削除しない限り、一度作成されたら決して期限切れにならないことをシステムで保証すること。 5. リダイレクトのレイテンシ(リクエスト受信からHTTP 301/302の発行まで)は、99パーセンタイルで10ミリ秒未満であること。 6. データセンター全体がオフラインになってもシステムは稼働し続けること。 7. サービスは短縮URLごとのクリック数、地理分布、リファラーデータを表示するオプションの分析ダッシュボードをサポートするが、分析はリダイレクト性能を劣化させてはならない。 以下の点に対応した包括的なシステム設計を提示してください: A. ハイレベルなアーキテクチャ:主要コンポーネントとそれらの相互作用を説明してください。 B. URL生成戦略:一意の短縮コードをどのように生成するか、なぜそのアプローチを選んだか、衝突をどのように処理するか。 C. データモデルとストレージ:どのデータベースやストレージシステムを使用するか、その理由。スキーマに関する考慮点を含めてください。 D. 読み取りパスの最適化:与えられたスケールでリダイレクトのレイテンシ要件をどのように達成するか。 E. 書き込みパス:新しいURLをどのように作成し、確実に永続化するか。 F. スケーリング戦略:増加に対応するためにシステムをどのように水平スケールさせるか。 G. 信頼性と耐障害性:データセンター障害、レプリケーション、フェイルオーバーをどのように扱うか。 H. 分析パイプライン:リダイレクトのホットパスに影響を与えずに分析データをどのように収集、処理、提供するか。 I. 主要なトレードオフ:設計で行った少なくとも3つの重要なトレードオフを挙げ、それぞれを正当化してください。 関連する場合は、技術、プロトコル、数値見積もり(例:ストレージ計算、QPS見積もり、キャッシュサイズ)について具体的に記述してください。

293
2026/03/18 22:59

261〜280件を表示 / 全484件

関連リンク

X f L