bli*_*ini 5 database ruby-on-rails foreign-keys associations primary-key
我正在尝试将桌面应用程序迁移到rails(也处理相当老式的现有数据库).问题是我在一列中没有唯一的ID,但它是表的三列,保证了记录的唯一性.
鉴于我有三个表:
authors
author_name,
author_letter,
author_nr1,
author_nr2
...
titles
titel_nr,
titel_name,
...
author_titles
titel_nr,
author_letter,
author_nr1,
author_nr2
Run Code Online (Sandbox Code Playgroud)
作者的"主键"包括author_letter,author_nr1,author_nr2 here.
那么我需要一种多列主键来使rails关联工作吗?或者我在这里走向错误的方向?
Tim*_*mer 10
不可以.主键是(与rails默认)记录的ID.
此外,您可以设置唯一的密钥
add_index :users, [:merchant_id, :email], unique: true
add_index :users, [:merchant_id, :login], unique: true
Run Code Online (Sandbox Code Playgroud)
这会影响您的数据库.要捕获Rails中的唯一性,您需要写入您的模型:
validates_uniqueness_of :email, scope: :merchant_id
validates_uniqueness_of :login, scope: :merchant_id
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6505 次 |
| 最近记录: |