点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)大家好, 我正在尝试从....
点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)大家好, 我正在尝试从....
加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)
大家好,
我正在尝试从.NET在HANA中检查表是否存在。 所以我写了一个动态SQL,但是执行它会导致以下错误:
必须声明
标识符:1:在Sap.Data.Hana.HanaCommand.ExecuteScalar(Sap.Data.Hana.HanaCommand._ExecuteReader(CommandBehavior commandBehavior,Boolean isExecuteScalar,Boolean isBeginExecuteReader)中位于第8行第21列 )
这是我要构建的代码:
>代码以执行代码
使用(HanaCommand cmd =新的HanaCommand(sql,conn)) { conn.Open(); int ret =(int)cmd.ExecuteScalar(); 返回ret }
>构建要执行的SQL的代码:
StringBuilder sql = new StringBuilder(); sql.AppendFormat( @"做 开始 声明行数INT; 从table_name如'my_table'和schema_name ='my_schema'的表中选择count(*)进入行计数; 如果:rowcount = 0则 从哑元中选择0; 其他 从假人中选择1; 万一; 结束;");
是的,这确实很简单。 但是请记住,只要将自己限制在原始代码中的以下内容,我就可以用更少的行数实现相同的目标:
注意我只是删除了变量" rowcount"? 如果要获得表的存在是我的目的,那就是我要做的一切。 但是正如我在较早的评论中提到的那样。 目标是实际创建该表(如果不存在)。
这就是为什么我需要添加类似脚本的逻辑并通过ExecuteNonQuery执行的原因。 表的定义是动态的,并且是基于配置的,但是一旦找到一种有条件地创建表本身的方法,我将在以后处理。
一周热门 更多>