我需要帮助来理解这件事。为什么在下面的代码中,变量“ejes”和“habilidades”被解析为“dynamic”而第三个被解析为IEnumerable<dynamic>
. 这会影响接下来运行的代码,当我尝试调用扩展方法“Count()”时出现异常,因为“ejes”和“habilidades”不是 IEnumerable。它们是相同方法“Database.Query”的结果。
这是片段:
var db = Database.Open("froned");
db.Execute("begin transaction");
try
{
var asignacion = db.QuerySingle("select * from asignacion_avanza where id_asignacion = @0", id_asignacion);
var ejes = db.Query(String.Format(@"
select id_eje
from asignatura_eje_nivel
where id_nivel = {0}
and id_asignatura = {1}",
asignacion.id_nivel,
asignacion.id_asignatura));
var habilidades = db.Query(String.Format(@"
select id_habilidad
from asignatura_habilidad_nivel
where id_nivel = {0}
and id_asignatura = {1}",
asignacion.id_nivel,
asignacion.id_asignatura));
var dificultades = db.Query("select id_dificultad from dificultad");
var c_dif = dificultades.Count();
var c_eje = ejes.Count();
var c_habilidades = habilidades.Count();
我放了一个调试器的图像来显示变量的运行时类型。