如果使用 RedBean ORM,是否需要向数据库中的每个表添加名为“id”的主键?

在我的数据库中,我有一些表具有2或3个字段的主键对,或者其他名称不是“id”的主键(是的,我可以将名称更改为“id”,但它不会真正反映出现实,因为他们不是ID)

例:

table1 – 存储帖子:

id           INTEGER      PRIMARY KEY AUTOINCREMENT,name         TEXT,title        TEXT,content      TEXT,

table2 – 为帖子存储元数据:

post         INTEGER      DEFAULT 0,# <- references "id" from "posts"
  name         TEXT,value        TEXT,PRIMARY KEY(name,post),CONSTRAINT posts_Meta FOREIGN KEY(post)
    REFERENCES posts(id) ON DELETE CASCADE ON UPDATE RESTRICT

RedBean会使用这种数据库结构吗?

不幸的是,对于当前的表结构,您无法使用RedBean.每个表都需要有一个自动增量主键.略有下降,因为它使现有产品的集成更加困难.

由于这种约束而未能使用RedBean的几个线程,以及作者Gabor De Mooij的回复:

http://groups.google.com/group/redbeanorm/browse_thread/thread/6d5582275326744f?pli=1

http://groups.google.com/group/redbeanorm/browse_thread/thread/4fa7b29b453dcdb8

但是,RedBean不要求将主键字段简单地命名为“id”.您可以使用formatBeanID()方法根据自己的喜好格式化主键列的名称,如下面的示例所示,它有条件地将表名前缀为“id”.例如,表用户的主键是users_id.使用该格式,您可以根据需要获取ID名称的详细信息.

http://redbeanphp.com/community/wiki/index.php/Prefixes

希望这种限制将在未来解除,因为它确实妨碍了与现有产品的整合.

编辑:作为一个替代ORM,我听说过Doctrine:http://www.doctrine-project.org/.我没有亲自使用它,但它似乎是许多使用PHP的标准.

编辑2:感谢Jason提请注意一种将RedBean集成到现有项目中的新方法,在该项目中可能没有为其设置数据库.我想更新我的答案,以防人们仍然提到这个问题. Gabor建议制作映射到表的视图,您可以在其中设置视图以获得RedBean所需的正确结构.我没有亲自测试过,但它得到了一些用户的积极反馈.它在更改表时增加了一些额外的开销和维护,但似乎是迄今为止这个问题的最佳和最完整的答案.
http://www.redbeanphp.com/faq#beanformatter

php – RedBean是否需要“id”主键?的更多相关文章

  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# – ADO.NET DataTable约束如何影响性能?

    对DataTable的约束是否使得选择效率与sqlServer中的相同?或者他们唯一的目的是对数据实施规则?在通过UniqueID或UserID查找DataTable中的数据时,这些示例是否可能具有更好的性能?

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

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

随机推荐

  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之组件的注册与创建的实现方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下

返回
顶部