我有两个表来包含国家的州(state_table)和城市(city_table)
city 表具有 state_id 以将其与 state_table 相关联
这两个表都已经有数据了。
现在的问题
City 表包含一个州内一个城市的多个条目。其他城市可能有也可能没有相同的城市名称
例如:cityone 将在 city 表中与 stateone 出现 5 次,在 statetwo 中出现 2 次
那么我将如何编写一个查询来为每个州保留一个城市并删除其余的?
架构如下
CREATE TABLE IF NOT EXISTS `city_table` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`state_id` int(11) NOT NULL,
`city` varchar(25) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
CREATE TABLE IF NOT EXISTS `state_table` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`state` varchar(15) NOT NULL,
`country_id` smallint(5) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
这是样本数据
id state_id city
1 1 city_one
2 1 city_two
3 1 city_one
4 1 city_two
5 2 city_one
6 3 city_three
7 3 city_one
8 3 city_three
9 4 city_four
10 4 city_five
原始表有 152,451 行