嗨,我是编程新手,但我尝试提供自己的服务
我正在使用cloud9 Ide,rails和sqlite3上的ruby
无论如何,我将解析字典的数据,并且我将像这样设计数据库(例如)
[col-1] [col-2] [col-3]
[row-1] fruit apple [a,p,p,l,e]
[row-2] fruit kiwi [k,i,w,i]
...
[row-50] flower lily [l,i,l,y]
[row-51] flower rose [r,o,s,e]
...
3列和数千行
为了给您提供更多详细信息,当用户在文本区域中键入“水果”时,我想显示从“苹果”到“猕猴桃”的单词列表!
我了解了如何存储只有用户这样提交的“字符串”
class CreateFans < ActiveRecord::Migration
def change
create_table :fans do |t|
t.string :username
t.timestamps null: false
end
end
end
但是我真的不知道如何存储自己的数据,
我想知道如何添加列和行以及存储本地数据,而不是用户输入!
实际上,我昨天研究了读取.xlsx文件并通过gem'roo'在ruby上显示红宝石,但是我不知道如何在数据库中正确使用它。我想知道还有其他选择...
感谢您阅读我的问题,如果您能给我一些建议,我也非常感谢:)
您可以通过迁移将列添加到数据库。
列不必仅来自用户输入。
例如您可以进行迁移...
class CreateMyWord < ActiveRecord::Migration
def change
create_table :my_words do |t|
t.string :genre
t.string :word
t.string :letters
t.timestamps null: false
end
end
end
定义模型时,您可以指定该属性letters
实际上是一个数组...
class MyWord < ActiveRecord::Base
serialize :letters
end
serialize
将在存储记录时自动将数组转换为字符串表示形式,并在检索记录时自动将其转换回字符串形式。
然后seeds.db
,您可以自己在文件中填充表,然后可以使用以下命令执行该表rake db:seed
种子数据库可能看起来像...
my_initial_words = [
['fruit', 'apple', ['a','p','p','l','e'],
['fruit', 'kiwi', ['k','i', 'w', 'i'],
...
]
my_iniital_words.each do |word_data|
MyWord.create(genre: word_data[0], word: word_data[1], letters: word_data[2])
end
请注意,如果单词的字母始终与单词匹配,则您实际上并不需要letters
数据库中的列,只需在模型中有一个方法即可在需要时为您创建字母数组。
class MyWord < ActiveRecord::Base
def letters
word.split('')
end
end
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句