SQL implementation of LeetCode (175. Joining two tables)

SQL implementation of LeetCode (175. Joining two tables)

[LeetCode] 175.Combine Two Tables

Table: Person

+-------------+---------+
| Column Name | Type |
+-------------+---------+
| PersonId | int |
| FirstName | varchar |
| LastName | varchar |
+-------------+---------+
PersonId is the primary key column for this table.

Table: Address

+-------------+---------+
| Column Name | Type |
+-------------+---------+
| AddressId | int |
| PersonId | int |
| City | varchar |
| State | varchar |
+-------------+---------+
AddressId is the primary key column for this table.

Write a SQL query for a report that provides the following information for each person in the Person table, regardless if there is an address for each of those people:

FirstName, LastName, City, State

LeetCode also has a question about database. Let's do it. This is the first question. It is relatively simple. It is a question of joint search between two tables. We need to use Join operation. For some Join operations, you can read my previous blog SQL Left Join, Right Join, Inner Join, and Natural Join. The most direct way is to use Left Join to join the two tables according to PersonId:

Solution 1:

SELECT Person.FirstName, Person.LastName, Address.City, Address.State FROM Person LEFT JOIN Address ON Person.PersonId = Address.PersonId;

When using Left Join, we can also use the Using keyword to declare which column name we want to use for the join:

Solution 2:

SELECT Person.FirstName, Person.LastName, Address.City, Address.State FROM Person LEFT JOIN Address USING(PersonId);

Or we can add the Natural keyword so that we don't have to declare specific columns and MySQL can search for the same columns by itself:

Solution 3:

SELECT Person.FirstName, Person.LastName, Address.City, Address.State FROM Person NATURAL LEFT JOIN Address;

References:

https://leetcode.com/discuss/21216/its-a-simple-question-of-left-join-my-solution-attached

https://leetcode.com/discuss/53001/comparative-solution-between-left-using-natural-left-join

This is the end of this article about SQL implementation of LeetCode (175. Join two tables). For more relevant SQL implementation of joining two tables, please search 123WORDPRESS.COM's previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • SQL implementation of LeetCode (183. Customers who have never placed an order)
  • SQL implementation of LeetCode (182. Duplicate mailboxes)
  • SQL implementation of LeetCode (181. Employees earn more than managers)
  • SQL implements LeetCode (180. Continuous numbers)
  • SQL implementation of LeetCode (178. Score ranking)
  • SQL implementation of LeetCode (177. Nth highest salary)
  • SQL implementation LeetCode (176. Second highest salary)
  • SQL implementation of LeetCode (184. The highest salary in the department)

<<:  Specific use of Node.js package manager npm

>>:  HTML background color gradient achieved through CSS

Recommend

How to pass W3C validation?

In addition to setting regulations for various ta...

Vue3.0 handwritten carousel effect

This article shares the specific code of Vue3.0 h...

Vue implements 3 ways to switch tabs and switch to maintain data status

3 ways to implement tab switching in Vue 1. v-sho...

MySQL trigger principle and usage example analysis

This article uses examples to explain the princip...

Website front-end performance optimization: JavaScript and CSS

I have read an article written by the Yahoo team ...

The process of using vxe-table to make editable tables in vue

There is a table in the project that needs to be ...

Analysis of the principle of centering elements with CSS

It is a very common requirement to set the horizo...

Linux file systems explained: ext4 and beyond

Today I will take you through the history of ext4...

How to force vertical screen on mobile pages

I recently wrote a mobile page at work, which was...

js+canvas realizes code rain effect

This article shares the specific code of js+canva...

How to use Docker to build a tomcat cluster using nginx (with pictures and text)

First, create a tomcat folder. To facilitate the ...

TypeScript Mapping Type Details

Table of contents 1. Mapped Types 2. Mapping Modi...

Markup language - CSS layout

Click here to return to the 123WORDPRESS.COM HTML ...