- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在编写一个类,它封装了使用 ADO.NET 从数据库中检索数据的复杂性。其核心方法是
private void Read<T>(Action<T> action) where T : class, new() {
var matches = new LinkedList<KeyValuePair<int, PropertyInfo>>();
// Read the current result set's metadata.
using (DataTable schema = this.reader.GetSchemaTable()) {
DataRowCollection fields = schema.Rows;
// Retrieve the target type's properties.
// This is functionally equivalent to typeof(T).GetProperties(), but
// previously retrieved PropertyInfo[]s are memoized for efficiency.
var properties = ReflectionHelper.GetProperties(typeof(T));
// Attempt to match the target type's columns...
foreach (PropertyInfo property in properties) {
string name = property.Name;
Type type = property.PropertyType;
// ... with the current result set's fields...
foreach (DataRow field in fields) {
// ... according to their names and types.
if ((string)field["ColumnName"] == name && field["DataType"] == type) {
// Store all successful matches in memory.
matches.AddLast(new KeyValuePair<int, PropertyInfo>((int)field["ColumnOrdinal"], property));
fields.Remove(field);
break;
}
}
}
}
// For each row, create an instance of the target type and set its
// properties to the row's values for their matched fields.
while (this.reader.Read()) {
T result = new T();
foreach (var match in matches)
match.Value.SetValue(result, this.reader[match.Key], null);
action(result);
}
// Go to the next result set.
this.reader.NextResult();
}
关于该方法的正确性,不幸的是我现在无法测试,我有以下问题:
当单个 IDataReader
用于从两个或多个结果集中检索数据,IDataReader.GetSchemaTable
返回所有结果集的元数据,还是只返回当前结果集对应的元数据?
列序号是否由 IDataReader.GetSchemaTable
检索等于索引器使用的序数 IDataReader[int]
?如果不是,有没有办法将前者映射到后者?
关于该方法的效率,我有以下问题:
DataRowCollection
的底层数据结构?即使这个问题不能回答,至少,删除 DataRow
的渐近计算复杂度是多少?来自DataRowCollection
使用 DataRowCollection.Remove()
?而且,关于该方法的明显丑陋,我有以下问题:
有没有办法从 IDataReader
中检索特定的元数据(例如,仅列的序号、名称和类型),而不是完整的模式表? ?
是对 string
的转换在(string)field["ColumnName"] == name
必要的? .NET 如何比较 object
恰好包含对 string
的引用的变量到 string
变量:按引用值还是按内部数据值? (当有疑问时,我更愿意在正确性方面犯错,因此会犯错误;但是,当能够消除所有怀疑时,我更愿意这样做。)
即使我使用的是 KeyValuePair<int, PropertyInfo>
s 表示匹配的字段和属性对,这些对不是实际的键值对。它们只是普通的二元组。但是,.NET Framework 2.0 版不提供元组数据类型,如果我要创建自己的专用元组,我仍然不知道在哪里声明它。在 C++ 中,最自然的地方是在方法内部。但这是 C#,方法内类型定义是非法的。我应该怎么办?应对使用根据定义不是最合适的类型 (KeyValuePair<int, PropertyInfo>
) 的不雅之处,还是应对无法声明最适合的类型?
最佳答案
就 A1 而言,我相信在调用 IDataReader.NextResult()
之前,GetSchemaTable
只会返回当前结果集的信息。
然后当调用 NextResult()
时,您必须再次执行 GetSchemaTable
以获取有关当前结果集的信息。
HTH.
关于c# - 使用 Reflection 和 IDataReader.GetSchemaTable 创建读取和处理 IDataReader 当前结果集的通用方法时出现的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6628816/
我有: func NewMethodDescriptor(typ interface{}) *MethodDescriptor { reflectedMethod := reflect.Val
我需要确定地检查 reflect.Type 是否是一个错误。 错误没有反射(reflect)类型。在 go reflect 中检查类型错误的正式/惯用方式是什么? Go Playground Full
根据 reflect 文档 reflect.Value.MapIndex() 应返回一个 reflect.Value,它表示存储在 map 特定键处的数据的值.所以我的理解是以下两个表达式应该是相同的
与 reflect pkg 有点混淆 所有示例都使用 reflect.NewValue() 来获取 var 的 reflect.Value,但是 func NewValue 未记录在 http://g
在计算机语言的上下文中,我从未找到关于反射的词源的明确解释,所以我想在这里澄清一下。 “Reflection”源于拉丁语,有以下definitions : bend back turn back tu
我写了一个漂亮的函数,它可以接受 system.object ,反射(reflect)其属性并将对象序列化为 JSON 字符串。它看起来像这样: public class JSONSerializer
我正在尝试创建一个函数 import Language.Reflection foo : Type -> TT 我尝试使用reflect 策略: foo = proof { intro t
最近我和一位同事谈论 C++,感叹没有办法获取带有类字段名称的字符串并提取具有该名称的字段;换句话说,它缺乏反射(reflection)。他困惑地看着我,并问什么时候有人需要做这样的事情。 除了“嘿,
我正在考虑允许模块与属性文件中的类一起使用的想法;像 availableModules.properties Contact=org.addressbook.ContactMain Business=
这个问题特别与为具有大量字段的对象覆盖 equals() 方法有关。首先,让我说这个大对象不能在不违反 OO 原则的情况下分解成多个组件,所以告诉我“没有类应该有超过 x 个字段”无济于事。 继续前进
例子 router.Get(path, handler) // works fine methodStr = "Get" router.methodStr(path, handler) // e
我一直坚持使用反射库的问题。由于很多推荐,我决定使用它,但我只是在学习,有些部分并不是很容易.. 我有这部分代码: func countDataByName(sourceName string, s
我有一个包含一些 url 参数的特定结构,我想使用 reflect 构建一个 url 参数字符串以遍历结构字段,这样我就不会关心结构真正包含什么。 假设我有一个这样的结构: type Student
我正在尝试从 reflect.Value 中检索字符串值, 我希望 value.String()成为okok但我得到了相反。 我错过了什么吗? package main import ( "f
为了避免创建 org.reflections.Reflections 类的多个实例,我只想创建一个并根据需要重用。有谁知道这个类是否是线程安全的? 如果它不是线程安全的,我知道我可以使用 Java 的
我最近对引用、具体化和反射(reflection)感到困惑。有人可以很好地解释他们的关系和差异(如果有的话)吗? 最佳答案 引用 这可能是最简单的一个。考虑一下当您在 REPL 中键入以下内容时会发生
less main.go输出: ``` package main import ( "reflect" "net/url" "fmt" ) type User struct {
我在 golang 中使用 gorm 包 ( https://github.com/jinzhu/gorm ) 作为我的数据库库。我有很多类(数据库表),如“酒店”或“套餐”。复制代码不是好的编程习惯
我有代码 var t reflect.Type = LaunchController(route.controller) // create controller ptr . var
是否有可能以及如何在不从类型创建对象并调用它的情况下获取类型的 reflect.Type reflect.TypeOf(obj) Java 中的内容是:MyType.class 最佳答案 您可以使用以
我是一名优秀的程序员,十分优秀!