- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一些使用不同源表的 sql View ,但每个 View 都返回完全相同的结构。
非常简单:
view1
select tblA.Name as custName,
tblA.DOB as DateOfBirth,
tblA.accountBalance as AccountBalance
from myFirstTable tblA
view2
select tblB.AccountName as custName,
tblB.BirthDate as DateOfBirth,
tblB.Balance as AccountBalance
from mySecondTable tblB
view3
select tblC.CustomerName as custName,
tblC.DateOfBirth as DateOfBirth,
tblC.accBal as AccountBalance
from myThirdTable tblC
因此,即使源表中的字段名不同,不同的 View 也会返回同名(和类型)的字段。实际 View 复杂而庞大,每个 View 有数百行。
然后我将这些 View 拖到我的 Linq-to-sql 设计器中,并尝试在通用类中使用它们。
public static List<T> MainSearch<T>(ReportParams RP)
{
MyDataContext dc = new MyDataContext();
if (string.IsNullOrEmpty(RP.appType)) { return null; }
var searchQuery = new List<T>();
switch (RP.appType)
{
case "type1":
searchQuery = (from t in dc.view1s select t);
break;
case "type2":
searchQuery = (from t in dc.view2s select t);
break;
case "type3":
searchQuery = (from t in dc.view3s select t);
break;
}
//do other stuff with search query depending on params
DateTime dtFrom = Convert.ToDateTime(RP.fromDate);
searchQuery = searchQuery.Where(q => convert.ToDateTime(q.DateOfBirth) >= dtFrom);
//and so on...
想法是可以使用通用前端,根据用户选择传入参数,然后使用这些参数缩小搜索结果的范围,以搜索特定源数据(永远不会返回组合) ,它始终是三个 View 中的一个或另一个)。
上面的代码不起作用。在我的 switch 语句中,智能感知提示它无法从特定类型(例如 view1)隐式转换为 T 的泛型列表。这让我无法在 lambda 表达式中进一步使用强类型。
有什么方法可以实现我正在尝试做的事情,还是我在这里咆哮完全错误的树?
最佳答案
我还没有对此进行全面测试,但我认为您可以通过创建一个具有属性 custName、DOB 和 AccountBalance 的接口(interface)来实现。然后让每个生成的 LINQ-to-SQL 类(tblA、tblB、tblC)在单独的部分类文件中实现此接口(interface)。只要属性名称和类型匹配,这应该没问题。
interface IAccountTable
{
string custName { get; set; }
DateTime DOB { get; set; }
Decimal AccountBalance { get; set; }
}
和
partial class tblA : IAccountTable
{
}
使您的 searchQuery 成为该接口(interface)的列表。
var searchQuery = new List<IAccountTable>();
将您实际查询的结果转换到界面。
searchQuery = tblA.Where(t => t.custName == "Uday").Select(t => (IAccountTable)t).ToList();
关于c# - 使用泛型方法返回 list<T>,其中 T 可以是共享相同结构的三种类型之一,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35344220/
我想使用 R 预定义这样的列表 DATA<-list( list(list(),list(),list()), list(list(),list(),list()), list(list(),l
如何将一个列表添加到另一个列表,返回一个列表的列表? foo :: [a] -> [a] -> [[a]] 例如,我想要的结果是: foo [1,2] [3,4] 将是 [[1,2], [3,4]]。
我还没有在这里找到类似问题的解决方案,所以我会寻求你的帮助。 有 2 个列表,其中之一是列表列表: categories = ['APPLE', 'ORANGE', 'BANANA'] test_re
这个问题不同于Converting list of lists / nested lists to list of lists without nesting (这会产生一组非常具体的响应,但无法解决
原始列表转换为 List正好。为什么原始列表的列表不能转换为 List 的列表? { // works List raw = null; List wild = raw; } {
在下面的代码中,get()被调用并将其结果分配给类型为 List> 的变量. get()返回 List>并在类型参数为 T 的实例上调用设置为 ? ,所以它应该适合。 import java.util
原始列表转换为 List正好。为什么原始列表的列表不能转换为 List 的列表? { // works List raw = null; List wild = raw; } {
在insufficiently-polymorphic 作者说: def foo[A](fst: List[A], snd: List[A]): List[A] There are fewer way
我有下面的代码有效。 class ListManipulate(val list: List, val blockCount: Int) { val result: MutableList>
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 5 年前。 Improve this ques
在 scala (2.9) 中转换列表列表的最佳方法是什么? 我有一个 list : List[List[A]] 我想转换成 List[A] 如何递归地实现这一点?或者还有其他更好的办法吗? 最佳答案
我编写了这个函数来确定给定元素是否存储在元组列表的列表中,但目前它只搜索第一个列表。我将如何搜索其余列表? fun findItem (name : command, ((x,y)::firstlis
我创建了一个类名 objectA,它有 4 个变量:约会时间;字符串文本;变量 1,变量 2 我需要创建一个 ObjectA() 列表。然后首先按时间对它们进行分组,其次按 var1,然后按 var2
我有一套说法 char={'J','A'} 和列表的列表 content = [[1,'J', 2], [2, 'K', 3], [2, 'A', 3], [3,'A', 9], [5, 'J', 9
我有以下列表 List >>> titles = new ArrayList >>> ();我想访问它的元素,但我不知道该怎么做.. 该列表有 1 个元素,它又包含 3 个元素,这 3 个元素中的
转换 List[List[Long]] 的最佳方法是什么?到 List[List[Int]]在斯卡拉? 例如,给定以下类型列表 List[List[Long]] val l: List[List[Lo
我有一个来自 Filereader (String) 的 List-List,如何将其转换为 List-List (Double):我必须返回一个包含 line-Array 的第一个 Values 的
我收集了List> 。我需要将其转换为List> 。这是我尝试过的, List> dataOne = GetDataOne(); var dataTwo = dataOne.Select(x => x
这个问题在这里已经有了答案: Cannot convert from List to List> (3 个答案) 关闭 7 年前。 我没有得到这段代码以任何方式编译: List a = new Ar
这个问题在这里已经有了答案: Cannot convert from List to List> (3 个答案) 关闭 7 年前。 我没有得到这段代码以任何方式编译: List a = new Ar
我是一名优秀的程序员,十分优秀!