这几天来回出差忙着项目上的事,终于今天可以继续写写了。在以前的文章中,我曾经提到过数据类型、怎么创建一个合适的用户表。今天我就以实际的例子来与大家讨论讨论这个问题。很多面试者都没有给出我想要的答案。
进入正题,我就以用户表的建立抛砖引玉。
首先来看看我在项目中设计的用户表的样子(当然可以把账号与用户资料分表存储)。
看出了什么呢?(以上为EasyCoderX易码者平台的库表操作界面)
在这个表中,涉及到了一个架构问题,你需要具数据库、前端、后台等多方面的技术能力。接下来我阐述一下我认为关键的点。
一、账号的设计:问了很多人,如果我们的账号是手机号码,你怎么设置,答案:varchar,My GOD怎么这样子,你这不是表明自己简直连数据类型的基础都没有入门嘛。
真正看你是不是一个基础扎实的开发者了,或者叫DBA,或者是架构师吧。
在我们这里账号的设计是bigint,why?
1、字符串与数值的存储空间(为什么不用varchar、int而要用bigint,你们自己想想吧);
2、数值类型查询速度快于字符串;
二、密码:必须必须是密文啊(不用我多说吧),如果你还不知道为什么(简直是天杀的了、祸害一千年啊。。。。),长度32、记住是32位定长(你可以说,可以用char啊,当然可