佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > 簡單介紹Ruby on Rails對PostgreSQL數(shù)組類型的支持

簡單介紹Ruby on Rails對PostgreSQL數(shù)組類型的支持

熱門標(biāo)簽:語音系統(tǒng) 企業(yè)做大做強(qiáng) 百度AI接口 Win7旗艦版 電話運(yùn)營中心 硅谷的囚徒呼叫中心 客戶服務(wù) 呼叫中心市場需求

 我非常高興在宣布Rails 4.0 現(xiàn)在支持 PostgreSQL 數(shù)組類型. 你可以方便的在migration通過 :array => true里創(chuàng)建數(shù)組類型的字段. 創(chuàng)建數(shù)組類型的字段的時(shí)候還可以添加其它的選項(xiàng)(length,default,等等)
 

create_table :table_with_arrays do |t|
 t.integer :int_array, :array => true
 # integer[]
 t.integer :int_array, :array => true, :length => 2
 # smallint[]
 t.string :string_array, :array => true, :length => 30
 # char varying(30)[]
end

需要注意在是對數(shù)組類型的字段設(shè)置默認(rèn)值的時(shí)候,你應(yīng)該用Postgresql里的寫法({value,another value}), 如果你想設(shè)置數(shù)組類型的字段默認(rèn)值為空數(shù)組的時(shí)候,你應(yīng)該使用:default => '{}'
 

create_table :table_with_arrays do |t|
 t.integer :int_array, :array => true, :default => '{}'
 # integer[], default == []
 t.integer :int_array, :array => true, :length => 2, :default => '{1}'
 # smallint[], default == [1]
end


在Model里使用Postgresql數(shù)組的例子

我們現(xiàn)在有個(gè)包含first_name, last_name, nickname的user model, 其中nickname字段是數(shù)組類型. 下面的migration代碼會(huì)創(chuàng)建相應(yīng)的表:
 

create_table :users do |t|
 t.string :first_name
 t.string :last_name
 t.string :nicknames, :array => true
end

并且對于這個(gè)表,我們有個(gè)簡單的model
 

class User  ActiveRecord::Base
 attr_accessible :first_name, :last_name, :nicknames
end

我們沒有對字段使用默認(rèn)值,如果我們實(shí)例一個(gè)User 對象,代碼是這樣的.
 

john = User.create(:first_name => 'John', :last_name => 'Doe')

如果,我們調(diào)用john.nickname, 結(jié)果會(huì)返回nil, 并且在postgreSQL 里存儲(chǔ)的是NULL值.

我們通過下面的代碼可以在創(chuàng)建時(shí),設(shè)置nickname屬性值 
 

john = User.create(:first_name => 'John', :last_name => 'Doe',
 :nicknames => ['Jack', 'Johnny'])

如果我們從數(shù)據(jù)庫獲取記錄,那么nick_name字段會(huì)轉(zhuǎn)變成一個(gè)數(shù)組,而不是返回字符串{Jack, Johnny}!。Rails 4.0擁有一個(gè)純Ruby數(shù)組轉(zhuǎn)換器,但是如果你想讓轉(zhuǎn)換過程加速,那么就可以使用之前提到的 pg_array_parser gem。PgArrayParser 擁有一個(gè)基于C的擴(kuò)展,還有一個(gè)JRuby的Java的實(shí)現(xiàn)(即使這個(gè)gem現(xiàn)在在JRuby上存在些問題,我正在嘗試去解決這個(gè)問題。)

有一個(gè)重點(diǎn)需要注意的,就是當(dāng)在一個(gè)model中和數(shù)組(或者其他可變數(shù)值)交互的時(shí)候。ActiveRecord現(xiàn)在并沒有跟蹤"destructive",或者更改發(fā)生的地方。這包括數(shù)組的push和pop操作。如果你需要使用"destructive"更新,你必須使用call屬性>_will_change!這樣可以讓ActiveRecord知道你需要更改屬性的值。對于我們的這個(gè)User model,如果你想在nickname后面追加元素,你可以這樣做:
 

john = User.first
 
john.nicknames += ['Jackie boy']
# 或者
john.nicknames = john.nicknames.push('Jackie boy')
# 任何時(shí)候,屬性通過"="賦值,ActiveRecord會(huì)跟蹤這個(gè)更改
john.save
 
john.reload
john.nicknames
#=> ['Jack', 'Johnny', 'Jackie Boy']
 
john.nicknames.pop
john.nicknames_will_change!
# '#pop'操作會(huì)改變數(shù)組的值,所以我們需要告訴ActiveRecord它將會(huì)發(fā)生更改
john.save

 

最后一項(xiàng)在Postgresql中使用數(shù)組要注意的事情是: 數(shù)組沒有元素?cái)?shù)量限制,可以是多維數(shù)組,但是在使用多維數(shù)組時(shí), 子數(shù)組元素個(gè)數(shù)必須是一樣的.

 

[[1,2,3], [2,3,4], [4,5,nil]]
# 在PostgreSQL 可用,每個(gè)子數(shù)組元素個(gè)數(shù)一樣
 
[1,2,[3,4]]
# 不可用的數(shù)組

您可能感興趣的文章:
  • PostgreSQL中使用數(shù)組改進(jìn)性能實(shí)例代碼
  • Mybatis調(diào)用PostgreSQL存儲(chǔ)過程實(shí)現(xiàn)數(shù)組入?yún)鬟f
  • 在PostgreSQL中使用數(shù)組時(shí)值得注意的一些地方
  • PostgreSQL 對數(shù)組的遍歷操作

標(biāo)簽:崇左 山西 濟(jì)南 喀什 山西 安康 海南 長沙

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《簡單介紹Ruby on Rails對PostgreSQL數(shù)組類型的支持》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    峨边| 义马市| 沾化县| 高平市| 鄱阳县| 青海省| 瑞金市| 昌乐县| 衡东县| 彰化县| 中江县| 泾阳县| 南和县| 左权县| 西乡县| 即墨市| 延寿县| 湖州市| 铜山县| 南华县| 长泰县| 南京市| 礼泉县| 堆龙德庆县| 孝昌县| 屯留县| 石城县| 新民市| 荔波县| 军事| 阿合奇县| 齐齐哈尔市| 江山市| 上饶县| 徐水县| 武冈市| 花莲市| 双辽市| 无锡市| 清徐县| 安仁县|