doumao6212 2015-09-15 08:40
浏览 36

MySQL中单个表中的多个表

I've downloaded the Worlds-Country-State-and-City-Mysql-Database project from GitHub, it gives a database of countries, states, and cities.

Normally such databases are found in three tables for country, state, and city, but here it is only a single table, and it has all three pieces of data. It works fine but I can't understand how it works.

Here is snapshot of that table. enter image description here

enter image description here

Somebody please explain this

  • 写回答

1条回答 默认 最新

  • dpp66953 2015-09-15 08:53
    关注

    What you have here is a parent-child relationship. The parent_ID column designates if a location belongs to another(is the child of another) Location_id.

    For example to get the direct children (states) of Aruba, you would do a self join as such:

    select * from mytable A
    left join mytable B -- join same table
    on b.parent_id=a.location_id -- with parent of the secondary being equal to the ID of the primary.
    where a.location_id='Aruba'
    

    If you want to get the children of the states(cities) , you would need one more self-join

    评论

报告相同问题?

悬赏问题

  • ¥20 测距传感器数据手册i2c
  • ¥15 RPA正常跑,cmd输入cookies跑不出来
  • ¥15 求帮我调试一下freefem代码
  • ¥15 matlab代码解决,怎么运行
  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗
  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法