Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Dapper
提交
0e4785ed
D
Dapper
项目概览
int
/
Dapper
11 个月 前同步成功
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
Dapper
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
0e4785ed
编写于
4月 28, 2011
作者:
S
Sam Saffron
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
multimap was not buffered properly
上级
6bd0e24c
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
19 addition
and
10 deletion
+19
-10
Dapper/SqlMapper.cs
Dapper/SqlMapper.cs
+16
-9
Tests/Tests.cs
Tests/Tests.cs
+3
-1
未找到文件。
Dapper/SqlMapper.cs
浏览文件 @
0e4785ed
...
...
@@ -163,7 +163,7 @@ public static IEnumerable<dynamic> Query(this IDbConnection cnn, string sql, dyn
public
static
IEnumerable
<
T
>
Query
<
T
>(
this
IDbConnection
cnn
,
string
sql
,
dynamic
param
=
null
,
IDbTransaction
transaction
=
null
,
bool
buffered
=
true
,
int
?
commandTimeout
=
null
)
{
var
data
=
QueryInternal
<
T
>(
cnn
,
sql
,
param
as
object
,
transaction
,
commandTimeout
);
return
(
buffered
)
?
data
.
ToList
()
:
data
;
return
buffered
?
data
.
ToList
()
:
data
;
}
/// <summary>
...
...
@@ -231,7 +231,13 @@ private static IEnumerable<T> QueryInternal<T>(this IDbConnection cnn, string sq
class
DontMap
{}
static
IEnumerable
<
T
>
MultiMap
<
T
,
U
,
V
,
Z
,
X
>(
this
IDbConnection
cnn
,
string
sql
,
object
map
,
object
param
=
null
,
IDbTransaction
transaction
=
null
,
bool
buffered
=
true
,
string
splitOn
=
"Id"
,
int
?
commandTimeout
=
null
)
{
var
identity
=
new
Identity
(
sql
,
cnn
,
typeof
(
T
),
param
==
null
?
null
:
param
.
GetType
(),
otherTypes
:
new
[]
{
typeof
(
T
),
typeof
(
U
),
typeof
(
V
),
typeof
(
Z
),
typeof
(
X
)
});
var
results
=
MultiMapImpl
<
T
,
U
,
V
,
Z
,
X
>(
cnn
,
sql
,
map
,
param
,
transaction
,
splitOn
,
commandTimeout
);
return
buffered
?
results
.
ToList
()
:
results
;
}
static
IEnumerable
<
T
>
MultiMapImpl
<
T
,
U
,
V
,
Z
,
X
>(
this
IDbConnection
cnn
,
string
sql
,
object
map
,
object
param
=
null
,
IDbTransaction
transaction
=
null
,
string
splitOn
=
"Id"
,
int
?
commandTimeout
=
null
)
{
var
identity
=
new
Identity
(
sql
,
cnn
,
typeof
(
T
),
param
==
null
?
null
:
param
.
GetType
(),
otherTypes
:
new
[]
{
typeof
(
T
),
typeof
(
U
),
typeof
(
V
),
typeof
(
Z
),
typeof
(
X
)
});
var
info
=
GetCacheInfo
(
param
,
identity
);
using
(
var
cmd
=
SetupCommand
(
cnn
,
transaction
,
sql
,
info
.
ParamReader
,
param
,
commandTimeout
))
...
...
@@ -249,7 +255,7 @@ class DontMap {}
for
(
pos
=
current
+
1
;
pos
<
reader
.
FieldCount
;
pos
++)
{
// some people like ID some id ... assuming case insensitive splits for now
if
(
string
.
Equals
(
reader
.
GetName
(
pos
),
splitOn
,
StringComparison
.
InvariantCultureIgnoreCase
))
if
(
string
.
Equals
(
reader
.
GetName
(
pos
),
splitOn
,
StringComparison
.
InvariantCultureIgnoreCase
))
{
break
;
}
...
...
@@ -259,10 +265,10 @@ class DontMap {}
};
var
otherDeserializer
=
new
List
<
object
>();
split
=
nextSplit
();
split
=
nextSplit
();
info
.
Deserializer
=
GetDeserializer
<
T
>(
identity
,
reader
,
0
,
split
);
if
(
typeof
(
U
)
!=
typeof
(
DontMap
))
{
var
next
=
nextSplit
();
...
...
@@ -296,7 +302,7 @@ class DontMap {}
var
deserializer2
=
(
Func
<
IDataReader
,
U
>)
info
.
OtherDeserializers
[
0
];
Func
<
IDataReader
,
T
>
mapIt
=
null
;
Func
<
IDataReader
,
T
>
mapIt
=
null
;
if
(
info
.
OtherDeserializers
.
Length
==
1
)
{
...
...
@@ -347,15 +353,16 @@ class DontMap {}
}
}
if
(
mapIt
!=
null
)
if
(
mapIt
!=
null
)
while
(
reader
.
Read
())
{
yield
return
mapIt
(
reader
);
}
}
}
}
}
private
static
CacheInfo
GetCacheInfo
(
object
param
,
Identity
identity
)
{
CacheInfo
info
;
...
...
Tests/Tests.cs
浏览文件 @
0e4785ed
...
...
@@ -432,7 +432,8 @@ public void MultiRSSqlCE()
cnn
.
Close
();
}
}
/* TODO:
*
public void TestMagicParam()
{
// magic params allow you to pass in single params without using an anon class
...
...
@@ -441,6 +442,7 @@ public void TestMagicParam()
var first = connection.Query("select @a as a", 1).First();
Assert.IsEqualTo(first.a, 1);
}
* */
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录