php – MySQL从另一个表插入国家iso或国家ID
发布时间:2020-12-13 22:49:25 所属栏目:PHP教程 来源:网络整理
导读:我想在我的数据库中插入每个访问者的国家/地区. Maxmind返回我可以存储在VARCHAR(2)中的2个字母的国家ISO,它将使用2个字节,或者,我可以使用将使用1个字节的UNSIGNED TINYINT,并且将是来自所有表的id那些国家. 然而我碰到了一个凹凸;我需要MyISAM引擎进行快速
我想在我的数据库中插入每个访问者的国家/地区. Maxmind返回我可以存储在VARCHAR(2)中的2个字母的国家ISO,它将使用2个字节,或者,我可以使用将使用1个字节的UNSIGNED TINYINT,并且将是来自所有表的id那些国家.
然而我碰到了一个凹凸;我需要MyISAM引擎进行快速插入,但MyISAM不支持FOREIGN KEYS,所以我想对于每次插入,我都必须在countries表中进行选择以检索国家ID. 我不知道什么是最好的选择,我绝对需要使用MyISAM,因为会有很多插入,但我不想经常使用SELECT来检索国家ID. 解决方法
如果您只需要2个字母的ISO国家/地区代码(而不是国家/地区名称,语言或其他信息),那么我会说将其存储为没有外部表的CHAR(2)将比存储它更少资源.因为SMALLINT(TINYINT不足以涵盖所有国家/地区),所以查找其他表格.
注意:在这种情况下不需要VARCHAR(2),CHAR(2)会更有效. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |