我正在使用Rails制作一个新的web应用程序,想知道字符串和文本之间的区别是什么?什么时候分别使用?
当前回答
如上所述,不只是db数据类型,它也会影响将生成的视图,如果你是脚手架。 String将生成一个text_field text将生成一个text_area
其他回答
如果大小固定且较小,则为字符串;如果大小可变且较大,则为文本。 这很重要,因为文本比字符串大得多。它包含更多的千字节。
所以对于小字段总是使用string(varchar)。字段。First_name,登录名,电子邮件,(文章或帖子的)主题 文本的例子:一篇文章或文章的内容或主体。段落等字段
字符串大小从1到255(默认值为255)
文本大小1到4294967296(默认值为65536
如果你正在使用oracle…STRING将被创建为VARCHAR(255)列,TEXT将被创建为CLOB。
NATIVE_DATABASE_TYPES = {
primary_key: "NUMBER(38) NOT NULL PRIMARY KEY",
string: { name: "VARCHAR2", limit: 255 },
text: { name: "CLOB" },
ntext: { name: "NCLOB" },
integer: { name: "NUMBER", limit: 38 },
float: { name: "BINARY_FLOAT" },
decimal: { name: "DECIMAL" },
datetime: { name: "TIMESTAMP" },
timestamp: { name: "TIMESTAMP" },
timestamptz: { name: "TIMESTAMP WITH TIME ZONE" },
timestampltz: { name: "TIMESTAMP WITH LOCAL TIME ZONE" },
time: { name: "TIMESTAMP" },
date: { name: "DATE" },
binary: { name: "BLOB" },
boolean: { name: "NUMBER", limit: 1 },
raw: { name: "RAW", limit: 2000 },
bigint: { name: "NUMBER", limit: 19 }
}
https://github.com/rsim/oracle-enhanced/blob/master/lib/active_record/connection_adapters/oracle_enhanced_adapter.rb
如上所述,不只是db数据类型,它也会影响将生成的视图,如果你是脚手架。 String将生成一个text_field text将生成一个text_area
如果属性在form中匹配f.text_field,则使用string,如果匹配f.text_area,则使用text。
区别在于如何将符号转换为查询语言中相应的列类型。
用MySQL:字符串映射到VARCHAR https://edgeguides.rubyonrails.org/active_record_migrations.html
:string | VARCHAR | :limit => 1 to 255 (default = 255)
:text | TINYTEXT, TEXT, MEDIUMTEXT, or LONGTEXT2 | :limit => 1 to 4294967296 (default = 65536)
参考:
https://hub.packtpub.com/working-rails-activerecord-migrations-models-scaffolding-and-database-completion/
什么时候分别使用?
一般的经验法则是,使用:string作为短文本输入(用户名、电子邮件、密码、标题等),使用:text作为较长的预期输入,如描述、评论内容等。
推荐文章
- Ruby:包含的反义词是什么?Ruby数组?
- 想要在Rails中找到没有关联记录的记录
- helper和helper_method做什么?
- 如何回滚只是一个步骤使用耙db:迁移
- 如何传递参数到一个Rake任务与环境在Rails?
- 如何在Rails中计算相对时间?
- 如何在Rails迁移中将可空列更改为不可空列?
- Ruby on Rails -从CSV文件导入数据
- Ruby/Rails:将Date转换为UNIX时间戳
- 如何从URL下载文件并保存在Rails中?
- Rails:缺少要链接的主机!请提供:host参数或设置default_url_options[:host]
- Rails。env vs RAILS_ENV
- 如何从Ruby数组中创建平均值?
- 我能在视图中得到当前控制器的名称吗?
- Paperclip::Errors::MissingRequiredValidatorError with Rails