SQL実装 LeetCode (176. 2番目に高い給与)

SQL実装 LeetCode (176. 2番目に高い給与)

[LeetCode] 176. 2番目に高い給与

従業員テーブルから 2 番目に高い給与を取得する SQL クエリを記述します。

+----+--------+
| ID | 給与 |
+----+--------+
| 1 | 100 |
| 2 | 200 |
| 3 | 300 |
+----+--------+

たとえば、上記の従業員テーブルの場合、2 番目に高い給与は 200 です。2 番目に高い給与がない場合、クエリは null を返します。

この問題は、テーブルの列で 2 番目に大きい数字を見つけるように求めています。この問題を解く方法はたくさんあります。まず、2 つのキーワード Limit と Offset を使用したソリューションを見てみましょう。MySQL の Limit の後の数字は、返されるデータの数を制限し、Offset はオフセットです。したがって、2 番目に高い給与を検索する場合は、まず給与を降順で並べ替え、次に Offset を 1 に設定します。これは、2 番目、つまり 2 番目に高い給与から開始することを意味します。次に、Limit を 1 に設定します。これは、2 番目に高い給与のみを取り出すことを意味します。Limit を 2 に設定すると、2 番目と 3 番目に高い給与の両方が取り出されます。

解決策1:

従業員から給与を選択 給与でグループ化
UNION ALL (給与としてNULLを選択)
ORDER BY 給与 DESC LIMIT 1 OFFSET 1;

最大値を返す Max 関数を使用することもできます。ロジックは、最大値を含まない数値の最大値、つまり 2 番目に大きい値を取り出すというものです。

解決策2:

従業員からMAX(給与)を選択 
給与が支払われない場所
(従業員からMAX(給与)を選択);

次の方法は基本的に上記と同じですが、Not in キーワードの代わりに小なり記号 < が使用され、効果は同じです。

解決策3:

従業員からMAX(給与)を選択
給与 <
(従業員からMAX(給与)を選択);

最後に、N 番目に高い給料を見つけるために拡張できる方法を見てみましょう。次の文の 1 を N-1 に変更するだけです。N-1 を代入すると、2 番目に高い給料は 1 になります。次の文のロジックは、2 番目に高い給料を見つけたい場合は、最大値の 1 つが存在することを許可し、残りの数字の中で最大の値、つまり全体の 2 番目に大きい値を見つけるというものです。

解決策4:

従業員E1からMAX(給与)を選択
ここで 1 =
(SELECT COUNT(DISTINCT(E2.Salary)) FROM 従業員E2
ここで、E2.Salary > E1.Salary);

参考文献:

https://leetcode.com/discuss/47041/非常に非常にシンプルなソリューション

https://leetcode.com/discuss/42849/general-solution-not-using-max

https://leetcode.com/discuss/21751/simple-query-which-handles-the-null-situation

これで、LeetCode (176. 給与2位) のSQL実装に関するこの記事は終了です。給与2位のSQL実装に関するより関連性の高いコンテンツについては、123WORDPRESS.COMの以前の記事を検索するか、以下の関連記事を引き続き閲覧してください。今後とも123WORDPRESS.COMを応援していただければ幸いです。

以下もご興味があるかもしれません:
  • LeetCode の SQL 実装 (184. 部門内で最も高い給与)
  • LeetCode の SQL 実装 (183. 注文をしたことがない顧客)
  • LeetCode の SQL 実装 (182. 重複するメールボックス)
  • LeetCode の SQL 実装 (181. 従業員は管理職よりも収入が高い)
  • SQLはLeetCodeを実装します(180.連続した数字)
  • LeetCode の SQL 実装 (178. スコアランキング)
  • LeetCode の SQL 実装 (177. 給与が N 番目に高い)
  • SQL 実装 LeetCode (185. 部門内で最も給与の高い上位 3 名)

<<:  フレックスボックスレイアウトの最終行の左揃えの実装アイデア

>>:  Vueはシンプルな計算機能を実装します

推薦する

Linux での MySQL 8.0 インストール チュートリアル

この記事では、LinuxでMySQL 8.0をインストールする方法を紹介します。具体的な内容は次のと...

Nest.js 認証検証方法の例

目次0x0 はじめに0x1 RBAC 実装0x2 クレームベースの承認0x3 統合 CASL 0x4...

サーバー同時実行数の推定式と計算方法

最近、サーバーのストレステストを再度行う必要が出てきました。ここでは、最近学んだ見積もりスキームと見...

Linux でのルーティングと仮想マシン ネットワークの設定に関する詳細なグラフィック説明

ルーティングとは何ですか?ルーティングとは、相互接続されたネットワークを介して送信元ステーションから...

インターネット接続なしでLinux Centos7にアプリケーションをインストールする方法の詳細な説明

1. 前の章では、プログラムを yum リポジトリに直接インストールできることを学びましたが、そのた...

MySQL 5.6 のインストール手順(画像とテキスト付き)

MySQL はオープンソースの小規模リレーショナル データベース管理システムです。現在、MySQL...

XHTML の IE 条件付きコメント

<br />条件付きコメントはIEシリーズ製品上でXHTMLコード処理を分離して行うこと...

CSS で要素フローティングとクリアフローティングを実装する方法

フローティングの基礎標準ドキュメント フローでは、要素は塊級元素と行內元素の 2 種類に分けられます...

Vue Nativeを使用したモバイルアプリケーションの構築プロセスの完全な記録

目次序文Vue Nativeの機能宣言的レンダリング双方向バインディングVue.js エコシステムの...

MySQL マスタースレーブレプリケーションの原理と実践の詳細な説明

目次導入効果原理形状練習するこの記事では、例を使用して、MySQL マスター/スレーブ レプリケーシ...

MySQLエラー10061を解決する方法

この記事では、「'localhost' (10061) の MySQL サーバーに接...

LeetCode の SQL 実装 (197. 気温上昇)

[LeetCode] 197.気温上昇Weather テーブルが指定されている場合、前の日付 (昨...

ウェブデザインを改善するための 8 つの CSS ツールを共有する

ウェブサイトのデザインを編集または変更する必要がある場合、CSS が重要な役割を果たします。 CSS...

Docker のインストールと構成コマンドのコード例

Dockerのインストール依存パッケージをインストールする sudo yum install -y ...

開発効率の向上に役立つ 56 個の実用的な JavaScript ツール関数

目次1. デジタルオペレーション(1)指定された範囲内で乱数を生成する2. 配列操作(1)配列の順序...