我正在尝试创建一个用户可以注册并创建配置文件的站点,因此我在数据库中使用两个 MySQL表,例如users和user_profile.

users表有一个名为user_id的自动增量主键.

user_profile表具有相同的主键user_id,但它不是自动增量.

*请参阅说明为什么我有多个表格.

当用户注册时,将来自注册表单的数据插入用户,然后将last_insert_id()输入到user_profile表的user_id字段中.我使用事务来确保始终发生这种情况.

我的问题是,这是不好的做法吗?

我是否应该为user_profile表提供唯一的自动增量主键,即使一个用户只能拥有一个配置文件?

也许创建像这样的数据库有其他缺点?

我很感激,如果有人能解释为什么这是一个问题,或者它是好的,我想确保我的数据库尽可能高效.

注意:我正在为user和user_profile使用单独的表,因为user_profile包含可能为null的字段,并且由于数据显示在公共配置文件中,因此将比用户表请求更多.

也许这也是不好的做法,他们应该被归为一张桌子?

我发现这是一个很好的方法,如果你使用外键关系我会给予奖励积分,并且当从用户表中删除用户时最好级联.

将一个表中的核心用户数据和另一个表中的选项配置文件数据分开 – 很好的工作.没有什么比这更加令人烦恼的50场空龙值90%空值.

php – 相同的主键是不好的做法?的更多相关文章

  1. ios – 避免将重复对象添加到领域

    我查询Parse.com中的数据并将其保存在本地的Realm数据库中.每个对象都有一个唯一的属性,但也有一个可能是一样的属性.避免将具有相同属性B的对象添加到领域数据库中最有效的方法是什么?

  2. HTML5中indexedDB 数据库的使用实例

    本篇文章主要介绍了HTML5中indexedDB 数据库的使用实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  3. php – RedBean是否需要“id”主键?

    如果使用RedBeanORM,是否需要向数据库中的每个表添加名为“id”的主键?在我的数据库中,我有一些表具有2或3个字段的主键对,或者其他名称不是“id”的主键例:table1–存储帖子:table2–为帖子存储元数据:RedBean会使用这种数据库结构吗?

  4. php – 相同的主键是不好的做法?

    我很感激,如果有人能解释为什么这是一个问题,或者它是好的,我想确保我的数据库尽可能高效.注意:我正在为user和user_profile使用单独的表,因为user_profile包含可能为null的字段,并且由于数据显示在公共配置文件中,因此将比用户表请求更多.也许这也是不好的做法,他们应该被归为一张桌子?

  5. php – mysql无限主键自动增量

    或者是否有可能使主键自动增量无限制?您可以使用BIGINT.严格来说,这并不是无限制的,但是这个范围是非常巨大的,即使你真的很努力,你也无法使用所有的价值.

  6. 钟表维修管理系统技术解析(六) 数据统计

    钟表维修管理系统技术解析(六)数据统计通过统计维修单据,销售单据,采购单据的金额数据,对每年,每月,每日的金额进行统计,以图表的形式显示出来2.6.1图(1)2.6.1图(2)营业额统计查询界面用到的控件有:控件名称说明文本控件(inputtype=”text”)第一要设置每个控件的id,第二设置大小不设置也有默认,第三(data-options)是数据操作:可以设置控件的一些属性和事件按钮(ea

  7. ajax相关的一些笔记

    特别是在使用插件时一定要注意,因为很能插件里面的ajax导致整体无法使用2.如果数据添加不上去,也可能是因为数据库里面的数据字段设置了主键,而你没有添加该主键

  8. c# – 在主表中创建与重命名字段和非主键的实体关系

    以下是我试图定义外键关系的两个部分表.}除了这个例子的相关信息,领域,导航等外,我已经消除了所有这些;希望不要太多我们有一个表格,PatGUID的FK到具有字段PatGUID的Patient表.Patient表有一个PatIDintKEY字段.我们有要求我们的代码第一实体模型重命名我们的字段;此示例中需要更改的相关字段将PatGUID更改为PatientGUID.我遇到的困难是试图用注释或流利来定

  9. c# – 使用byte作为主键数据类型

    我正在使用实体框架代码优先.我有一个表不会超过100行,我想使用数据类型字节作为主键.这是我到目前为止:问题是当EntityFramework创建数据库时,它没有设置允许行在插入时自动递增的标识规范属性.如果我将数据类型更改为Int16,一切都很完美.有没有办法告诉实体框架设置自动增量属性,还是一个字节不能用作实体框架代码优先的主键?)不是必需的,但它是一个字节.我通过测试得出结论,但无法在任何地方找到正式记录.

  10. Django多列外键

    是否可以在另一个模型中定义引用多列的外键?

随机推荐

  1. PHP个人网站架设连环讲(一)

    先下一个OmnihttpdProffesinalV2.06,装上就有PHP4beta3可以用了。PHP4给我们带来一个简单的方法,就是使用SESSION(会话)级变量。但是如果不是PHP4又该怎么办?我们可以假设某人在15分钟以内对你的网页的请求都不属于一个新的人次,这样你可以做个计数的过程存在INC里,在每一个页面引用,访客第一次进入时将访问时间送到cookie里。以后每个页面被访问时都检查cookie上次访问时间值。

  2. PHP函数学习之PHP函数点评

    PHP函数使用说明,应用举例,精简点评,希望对您学习php有所帮助

  3. ecshop2.7.3 在php5.4下的各种错误问题处理

    将方法内的函数,分拆为2个部分。这个和gd库没有一点关系,是ecshop程序的问题。会出现这种问题,不外乎就是当前会员的session或者程序对cookie的处理存在漏洞。进过本地测试,includes\modules\integrates\ecshop.php这个整合自身会员的类中没有重写integrate.php中的check_cookie()方法导致,验证cookie时返回的username为空,丢失了登录状态,在ecshop.php中重写了此方法就可以了。把他加到ecshop.php的最后面去就可

  4. NT IIS下用ODBC连接数据库

    $connection=intodbc_connect建立数据库连接,$query_string="查询记录的条件"如:$query_string="select*fromtable"用$cur=intodbc_exec检索数据库,将记录集放入$cur变量中。再用while{$var1=odbc_result;$var2=odbc_result;...}读取odbc_exec()返回的数据集$cur。最后是odbc_close关闭数据库的连接。odbc_result()函数是取当前记录的指定字段值。

  5. PHP使用JpGraph绘制折线图操作示例【附源码下载】

    这篇文章主要介绍了PHP使用JpGraph绘制折线图操作,结合实例形式分析了php使用JpGraph的相关操作技巧与注意事项,并附带源码供读者下载参考,需要的朋友可以参考下

  6. zen_cart实现支付前生成订单的方法

    这篇文章主要介绍了zen_cart实现支付前生成订单的方法,结合实例形式详细分析了zen_cart支付前生成订单的具体步骤与相关实现技巧,需要的朋友可以参考下

  7. Thinkphp5框架实现获取数据库数据到视图的方法

    这篇文章主要介绍了Thinkphp5框架实现获取数据库数据到视图的方法,涉及thinkPHP5数据库配置、读取、模型操作及视图调用相关操作技巧,需要的朋友可以参考下

  8. PHP+jquery+CSS制作头像登录窗(仿QQ登陆)

    本篇文章介绍了PHP结合jQ和CSS制作头像登录窗(仿QQ登陆),实现了类似QQ的登陆界面,很有参考价值,有需要的朋友可以了解一下。

  9. 基于win2003虚拟机中apache服务器的访问

    下面小编就为大家带来一篇基于win2003虚拟机中apache服务器的访问。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  10. Yii2中组件的注册与创建方法

    这篇文章主要介绍了Yii2之组件的注册与创建的实现方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下

返回
顶部