我是SQL新手,在编写以下查询时遇到困难。从两个表中选择位置
方案
用户有两个地址,家庭住址(App\User
),上市地址(App\Listing
)。当访问者搜索郊区或邮政编码或州的列表时,如果用户的列表地址不匹配 - 但是如果家庭地址匹配 - 他们也将位于搜索结果中。
例如:如果访问者搜索Melbourne
,我想要包含Melbourne
的列表以及Melbourne
中的地址的用户列表。
预期输出:
user_id first_name email suburb postcode state
1 Mathew [email protected] Melbourne 3000 VIC
2 Zammy [email protected] Melbourne 3000 VIC
表
用户:
id first_name email
1 Mathew [email protected]
2 Zammy [email protected]
3 Tammy [email protected]
4 Foo [email protected]
5 Bar [email protected]
列表:
id user_id hourly_rate description
1 1 30 ABC
2 2 40 CBD
3 3 50 XYZ
4 4 49 EFG
5 5 10 Efd
个
地址:
id addressable_id addressable_type post_code suburb state latitude longitude
3584 1 App\\User 2155 Rouse Hill NSW -33.6918372 150.9007221
3585 2 App\\User 3000 Melbourne VIC -33.6918372 150.9007221
3586 3 App\\User 2000 Sydney NSW -33.883123 151.245969
3587 4 App\\User 2008 Chippendale NSW -33.8876392 151.2011224
3588 5 App\\User 2205 Wolli Creek NSW -33.935259 151.156301
3591 1 App\\Listing 3000 Melbourne VIC -37.773923 145.12385
3592 2 App\\Listing 2030 Vaucluse NSW -33.858935 151.2784079
3597 3 App\\Listing 4000 Brisbane QLD -27.4709331 153.0235024
3599 4 App\\Listing 2000 Sydney NSW -33.91741 151.231307
3608 5 App\\Listing 2155 Rouse Hill NSW -33.863464 151.271504
您可以使用连接或联合。看看是否有帮助:http://www.techrepublic.com/article/sql-basics-query-multiple-tables/ – mtrueblood
你也可以发布你想要的输出,它会更容易理解 –