加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

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)会更有效.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读