Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
8d33a606
R
rails
项目概览
张重言
/
rails
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
rails
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
8d33a606
编写于
2月 24, 2014
作者:
Y
Yves Senn
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
pg guide, advanced features [ci skip]
上级
7ca75f37
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
46 addition
and
18 deletion
+46
-18
guides/source/active_record_postgresql.md
guides/source/active_record_postgresql.md
+46
-18
未找到文件。
guides/source/active_record_postgresql.md
浏览文件 @
8d33a606
...
...
@@ -250,24 +250,6 @@ revision = Revision.first
revision
.
identifier
# => "a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a11"
```
#### as primary key
```
ruby
# db/migrate/20131220144913_create_devices.rb
enable_extension
'uuid-ossp'
unless
extension_enabled?
(
'uuid-ossp'
)
create_table
:devices
,
id: :uuid
,
default:
'uuid_generate_v4()'
do
|
t
|
t
.
string
:kind
end
# app/models/device.rb
class
Device
<
ActiveRecord
::
Base
end
# Usage
device
=
Device
.
create
device
.
id
# => "814865cd-5a1d-4771-9306-4268f188fe9e"
```
### Bit String Types
*
[
type definition
](
http://www.postgresql.org/docs/9.3/static/datatype-bit.html
)
...
...
@@ -305,5 +287,51 @@ The types `inet` and `cidr` are mapped to Ruby [`IPAddr`]() objects. The
All geometric types are mapped to normal text.
UUID Primary Keys
-----------------
NOTE: you need to enable the
`uuid-ossp`
extension to generate UUIDs.
```
ruby
# db/migrate/20131220144913_create_devices.rb
enable_extension
'uuid-ossp'
unless
extension_enabled?
(
'uuid-ossp'
)
create_table
:devices
,
id: :uuid
,
default:
'uuid_generate_v4()'
do
|
t
|
t
.
string
:kind
end
# app/models/device.rb
class
Device
<
ActiveRecord
::
Base
end
# Usage
device
=
Device
.
create
device
.
id
# => "814865cd-5a1d-4771-9306-4268f188fe9e"
```
Full Text Search
----------------
```
ruby
# db/migrate/20131220144913_create_documents.rb
create_table
:documents
do
|
t
|
t
.
string
'title'
t
.
string
'body'
end
execute
"CREATE INDEX documents_idx ON documents USING gin(to_tsvector('english', title || ' ' || body));"
# app/models/document.rb
class
Document
<
ActiveRecord
::
Base
end
# Usage
Document
.
create
(
title:
"Cats and Dogs"
,
body:
"are nice!"
)
## all documents matching 'cat & dog'
Document
.
where
(
"to_tsvector('english', title || ' ' || body) @@ to_tsquery(?)"
,
"cat & dog"
)
```
Views
-----
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录