通过LLBLGEN

问题描述

您好,根据我的情况,我正在尝试使用llblgen执行纯sql,并且我一直将此页面作为指南:https://www.llblgen.com/Documentation/5.1/LLBLGen%20Pro%20RTF/Using%20the%20generated%20code/gencode_executing_plain_sql.htm

我不确定您是否被允许做我想做的事情,因为该页面上的所有示例都没有使用表名参数,而是使用诸如“ UPDATE Customer SET”之类的直接名,在这种情况下,我会想要“ UPDATE @table SET”,但是当我尝试执行此操作时,在执行说“必须声明@table”的sql语句时出现错误。我对sql确实很陌生,但是如果要添加“ DECLARE”语句,它将创建一个全新的表,我只想使用存储在参数中的现有表,因此可以参考一种方法对于所有这些更新语句,只需传入我需要的参数即可。

我想做的是,我试图从本地时间更新为协调世界时(UTC)的数据库中的每个表中都有这两个日期时间记录,但是我不能一次全部更新它们,并且相反,我需要遍历表的层次结构并一次为每个表更新它们,更新语句如下所示:

adapter.executesql("Update [MyDatabaseSchema].[MyTable] SET MyTimestamp=DATEADD(ss,DATEDIFF(ss,GETDATE(),GETUTCDATE()),MyTimestamp) WHERE ID=@id",new
   {
       id = tableEntity.id.ToString()
   });

所以我想做类似[MyDatabaseSchema]。@ table的操作,然后在新部分添加一个表参数,但是我正在努力解决该声明错误,有人知道它是否可以完成就是这样吗?

非常感谢!

编辑: 抱歉,发布之前我可能应该已经解释了这一部分。为什么我的表有一个实体类,却又需要使用普通的sql更新这两个记录,而不是使用entity.mytimestamp,这可能令人困惑,但是尽管这两个记录在数据库的每个表中都没有,任何表的实体类,因为它们没有被任何代码使用,因此entity.timestamp不存在。因此,我认为对于这两条记录,我将需要使用普通sql更新它们,但是在获取它们对应的实体时必须这样做。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...