适用于所有表的 LINQ 2 SQL 方法
我的标题可能略有偏差,但这就是我正在尝试做的事情。我有一个 L2S 方法,适用于我想编写一次的每个表。这是为了设置一个软锁定列,我还需要一个 Read 和 UnLock 方法。这是我到目前为止所做的:
public static void LockRow(string TableName, int TablePrimaryKey)
{
using (var context = McpDataContext.Create())
{
var tableToLock = (from lockTable in context.tblPlans
where lockTable.PlanID == TablePrimaryKey
select lockTable).Single();
tableToLock.Locked = true;
context.SubmitChanges();
}
}
我想做的是将 context.tblPlans
替换为 context.TableName
。这在 LINQ 中可能吗?为何如此?我假设我的处理方式是错误的,所以我将不胜感激一些方向/指示。
谢谢
My Title may be slightly off but here is what I am trying to do. I have a L2S Method that would be for every table that I would like to write once. This is to set a soft lock column where I will also need a Read
and UnLock
method. Here is what I have so far:
public static void LockRow(string TableName, int TablePrimaryKey)
{
using (var context = McpDataContext.Create())
{
var tableToLock = (from lockTable in context.tblPlans
where lockTable.PlanID == TablePrimaryKey
select lockTable).Single();
tableToLock.Locked = true;
context.SubmitChanges();
}
}
What I would like to do is replace context.tblPlans
with context.TableName
. Is this possible in LINQ? How so? I am assumming that I am going about it the wrong way so I'd be grateful for some direction/pointers.
Thanks
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
更新,因为第一个示例不起作用。
您可以使用通用方法和接口来完成此操作:
您还必须利用 Linw2SQL 表被创建为部分类的事实来扩展它们,以便所有相关表都实现
IPlanTable
您将使用它如下所示:
只需将
tblPlan
替换为表类的名称即可。然而,这不允许您在运行时设置表,LinqToSQL 是面向对象且类型安全的,指定要检索的表与其设计的工作方式相反。
Update becuase the first example would not work.
You could do it with a generic method and an interface:
You will also have to use the fact that the Linw2SQL tables are created as partial classes to extend them so all the relevent table implement
IPlanTable
You would use it like below:
simply replace
tblPlan
with whatever the name of your table class is.However this won't allow you to set the table at runtime, LinqToSQL is object orientated and type safe, specifying the table you want to retreive is contrary to how it si designed to work.