在工作缓慢的时候,我想将我编写的一个小数据库访问框架从 C# 转换为 F#。该框架广泛使用动态和 ExpandoObjects。特别是,有一点让我很头疼:
public static List<dynamic> ToDynamic(this IDataReader reader)
{
dynamic result = new List<dynamic>();
while (reader.Read())
{
var item = new ExpandoObject();
var dc = item as IDictionary<String, object>;
for (int i = 0; i < reader.FieldCount; i++)
{
dc.Add(reader.GetName(i), DBNull.Value.Equals(reader[i]) ? null : reader[i]);
}
result.Add(item);
}
return result;
}
你怎么把它翻译成F#?这就是我能想到的:
let (~~) (x:obj) =
match x with
| :? 't as t -> t
| _ -> null
let rec mapper (reader : SqlDataReader) : list<'Value> =
match reader.Read() with
| false -> []
| true ->
let dc = new ExpandoObject()
let dictionary = ~~dc : Dictionary<string, obj>
[for i in [0 .. reader.FieldCount - 1] do
dictionary.Add(reader.GetName(i), reader.GetValue(i))] @ mapper reader
当然,除了字典在循环中出现空值。~~
应该替换 C# 中的运算as
符,但我想事情并不那么简单。可能只是周五的情况,但我真的看不透。