Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
张重言
rails
提交
c2e7f36f
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,发现更多精彩内容 >>
提交
c2e7f36f
编写于
4月 29, 2011
作者:
S
Shane Emmons
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
replace 'LIMIT n' with 'FETCH FIRST n ROWS ONLY' when using ibm_db
上级
90953804
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
41 addition
and
0 deletion
+41
-0
lib/arel/visitors.rb
lib/arel/visitors.rb
+2
-0
lib/arel/visitors/ibm_db.rb
lib/arel/visitors/ibm_db.rb
+12
-0
test/visitors/test_ibm_db.rb
test/visitors/test_ibm_db.rb
+27
-0
未找到文件。
lib/arel/visitors.rb
浏览文件 @
c2e7f36f
...
...
@@ -10,6 +10,7 @@
require
'arel/visitors/where_sql'
require
'arel/visitors/order_clauses'
require
'arel/visitors/dot'
require
'arel/visitors/ibm_db'
module
Arel
module
Visitors
...
...
@@ -22,6 +23,7 @@ module Visitors
'oracle_enhanced'
=>
Arel
::
Visitors
::
Oracle
,
'sqlite'
=>
Arel
::
Visitors
::
SQLite
,
'sqlite3'
=>
Arel
::
Visitors
::
SQLite
,
'ibm_db'
=>
Arel
::
Visitors
::
IBM_DB
,
}
ENGINE_VISITORS
=
Hash
.
new
do
|
hash
,
engine
|
...
...
lib/arel/visitors/ibm_db.rb
0 → 100644
浏览文件 @
c2e7f36f
module
Arel
module
Visitors
class
IBM_DB
<
Arel
::
Visitors
::
ToSql
private
def
visit_Arel_Nodes_Limit
o
"FETCH FIRST
#{
visit
o
.
expr
}
ROWS ONLY"
end
end
end
end
test/visitors/test_ibm_db.rb
0 → 100644
浏览文件 @
c2e7f36f
require
'helper'
module
Arel
module
Visitors
describe
'the ibm_db visitor'
do
before
do
@visitor
=
IBM_DB
.
new
Table
.
engine
end
it
'uses FETCH FIRST n ROWS to limit results'
do
stmt
=
Nodes
::
SelectStatement
.
new
stmt
.
limit
=
Nodes
::
Limit
.
new
(
1
)
sql
=
@visitor
.
accept
(
stmt
)
sql
.
must_be_like
"SELECT FETCH FIRST 1 ROWS ONLY"
end
it
'uses FETCH FIRST n ROWS in updates with a limit'
do
stmt
=
Nodes
::
UpdateStatement
.
new
stmt
.
limit
=
Nodes
::
Limit
.
new
(
1
)
stmt
.
key
=
'id'
sql
=
@visitor
.
accept
(
stmt
)
sql
.
must_be_like
"UPDATE NULL WHERE 'id' IN (SELECT 'id' FETCH FIRST 1 ROWS ONLY)"
end
end
end
end
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录