Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
int
Dapper
提交
7a1840b9
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,发现更多精彩内容 >>
提交
7a1840b9
编写于
6月 28, 2011
作者:
S
Sam Saffron
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add support for weakly typed arrays, aka object array.
上级
f9670d28
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
31 addition
and
29 deletion
+31
-29
Dapper/SqlMapper.cs
Dapper/SqlMapper.cs
+22
-29
Tests/Tests.cs
Tests/Tests.cs
+9
-0
未找到文件。
Dapper/SqlMapper.cs
浏览文件 @
7a1840b9
...
...
@@ -286,41 +286,34 @@ public bool Equals(Identity other)
{
IEnumerable
multiExec
=
(
object
)
param
as
IEnumerable
;
Identity
identity
;
CacheInfo
info
;
CacheInfo
info
=
null
;
if
(
multiExec
!=
null
&&
!(
multiExec
is
string
))
{
// we actually want a T from IEnumerable<T>
var
interfaces
=
multiExec
.
GetType
().
GetInterfaces
();
var
openType
=
typeof
(
IEnumerable
<>);
Type
foundType
=
null
;
for
(
int
i
=
0
;
i
<
interfaces
.
Length
;
i
++)
{
bool
isFirst
=
true
;
int
total
=
0
;
using
(
var
cmd
=
SetupCommand
(
cnn
,
transaction
,
sql
,
null
,
null
,
commandTimeout
,
commandType
))
{
if
(
interfaces
[
i
].
IsGenericType
&&
interfaces
[
i
].
GetGenericTypeDefinition
()
==
openType
)
{
// implementing more than one T is self-inflicted
foundType
=
interfaces
[
i
].
GetGenericArguments
()[
0
];
identity
=
new
Identity
(
sql
,
cnn
,
null
,
foundType
,
null
);
info
=
GetCacheInfo
(
identity
);
using
(
var
cmd
=
SetupCommand
(
cnn
,
transaction
,
sql
,
null
,
null
,
commandTimeout
,
commandType
))
string
masterSql
=
null
;
foreach
(
var
obj
in
multiExec
)
{
if
(
isFirst
)
{
bool
isFirst
=
true
;
var
masterSql
=
cmd
.
CommandText
;
var
reader
=
info
.
ParamReader
;
int
total
=
0
;
foreach
(
var
obj
in
multiExec
)
{
if
(
isFirst
)
{
isFirst
=
false
;
}
else
{
cmd
.
CommandText
=
masterSql
;
// because we do magic replaces on "in" etc
cmd
.
Parameters
.
Clear
();
// current code is Add-tastic
}
reader
(
cmd
,
obj
);
total
+=
cmd
.
ExecuteNonQuery
();
}
return
total
;
masterSql
=
cmd
.
CommandText
;
isFirst
=
false
;
identity
=
new
Identity
(
sql
,
cnn
,
null
,
obj
.
GetType
(),
null
);
info
=
GetCacheInfo
(
identity
);
}
else
{
cmd
.
CommandText
=
masterSql
;
// because we do magic replaces on "in" etc
cmd
.
Parameters
.
Clear
();
// current code is Add-tastic
}
info
.
ParamReader
(
cmd
,
obj
);
total
+=
cmd
.
ExecuteNonQuery
();
}
}
return
total
;
}
// nice and simple
...
...
Tests/Tests.cs
浏览文件 @
7a1840b9
...
...
@@ -226,6 +226,15 @@ public void TestExecuteMultipleCommand()
sum
.
IsEqualTo
(
10
);
}
public
void
TestExecuteMultipleCommandObjectArray
()
{
connection
.
Execute
(
"create table #t(i int)"
);
int
tally
=
connection
.
Execute
(
@"insert #t (i) values(@a)"
,
new
object
[]
{
new
{
a
=
1
},
new
{
a
=
2
},
new
{
a
=
3
},
new
{
a
=
4
}
});
int
sum
=
connection
.
Query
<
int
>(
"select sum(i) from #t drop table #t"
).
First
();
tally
.
IsEqualTo
(
4
);
sum
.
IsEqualTo
(
10
);
}
public
void
TestMassiveStrings
()
{
var
str
=
new
string
(
'X'
,
20000
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录