我目前正在将数据从数据库导出到 XML 文件中。这很好用。根据数据量的不同,一个 XML 文件可能只包含一个数据集,也可能包含数百个数据集。这个过程每天都会触发。现在数据集应该有一个像“FileNo”这样的属性,它应该在开始时为零,然后总是增加值 1。现在看到SSIS中有foreach-container和for-container。不幸的是,恐怕使用这样的容器每天都会为所有数据集提供相同的“FileNo”,因此它们并没有被正确地提升。此外,我不知道SSIS中是否可以将变量“FileNo”的最后一个值缓存在某处,以便第二天可以使用下一个更高的“FileNo”值而不是从零重新开始。 ..
你知道如何计算这样一个变量并将其存储在某个地方,以便在第二天再次调用它吗?所以最后它应该是这样的:
感谢您的帮助。
最佳答案
C# 脚本任务可用于检索最后的 FileNo 值。完成此操作后,可以更新 SSIS 变量以保存它,您可以通过将其记录到表或其他方法来存储它。另一种选择是直接存储在脚本任务中的表中。下面概述了这两个选项。在脚本中,DateTime.Now 属性也存储为时间戳。下面的示例涵盖了使用 LINQ 的 LastOrDefault 方法从 XML 元素和属性获取最后一个 FileNo .如果未找到任何元素,此方法将返回默认值,而 Last 方法将在这种情况下抛出错误。使用的 XML 路径当然是一个示例,需要将其更改为您的路径。
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Xml.Linq;
string xmlFile = Dts.Variables["User::XMLFilePath"].Value.ToString();
//load xml document
XDocument xmlDoc = XDocument.Load(xmlFile);
//get last FileNo value
string lastFileNoElement = xmlDoc.Elements("Root").Elements("Element1").
Elements("Element2").Elements("FileNo").LastOrDefault().Value.ToString();
string lastFileNoAttribute = xmlDoc.Elements("Root").Elements("Element1")
.Elements("Element2").Attributes("FileNo").LastOrDefault().Value.ToString();
//update ssis variable (element)
Dts.Variables["User::FileNoElement"].Value = lastFileNoElement;
//update ssis variable (attribute)
Dts.Variables["User::FileNoAttribute"].Value = lastFileNoAttribute;
//create connection
string connStr = @"Data Source=YourServer;Initial Catalog=Database;Integrated Security=true";
string cmd = "INSERT INTO Schema.LoggingTable (FileNoAttribute, FileNoElement, ExecutionTime) values(@atName, @eleName, @execTime)";
using (SqlConnection conn = new SqlConnection(connStr))
{
SqlCommand sql = new SqlCommand(cmd, conn);
//attribute parameter
SqlParameter aParam = new SqlParameter("@atName", SqlDbType.VarChar);
aParam.Size = 50;
aParam.Direction = ParameterDirection.Input;
aParam.Value = lastFileNoAttribute;
//element parameter
SqlParameter eParam = new SqlParameter("@eleName", SqlDbType.VarChar);
eParam.Size = 50;
eParam.Direction = ParameterDirection.Input;
eParam.Value = lastFileNoElement;
//timestamp
SqlParameter dateParam = new SqlParameter("@execTime", SqlDbType.DateTime);
dateParam.Direction = ParameterDirection.Input;
dateParam.Value = DateTime.Now;
sql.Parameters.Add(aParam);
sql.Parameters.Add(eParam);
sql.Parameters.Add(dateParam);
conn.Open();
//insert data
sql.ExecuteNonQuery();
}
关于xml - 在 SSIS 中保存/记录变量的值以供下次执行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54867173/
我在使用omniauth/openid时遇到了一些麻烦。在尝试进行身份验证时,我在日志中发现了这一点:OpenID::FetchingError:Errorfetchinghttps://www.google.com/accounts/o8/.well-known/host-meta?hd=profiles.google.com%2Fmy_username:undefinedmethod`io'fornil:NilClass重要的是undefinedmethodio'fornil:NilClass来自openid/fetchers.rb,在下面的代码片段中:moduleNetclass
我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为
我正在查看instance_variable_set的文档并看到给出的示例代码是这样做的:obj.instance_variable_set(:@instnc_var,"valuefortheinstancevariable")然后允许您在类的任何实例方法中以@instnc_var的形式访问该变量。我想知道为什么在@instnc_var之前需要一个冒号:。冒号有什么作用? 最佳答案 我的第一直觉是告诉你不要使用instance_variable_set除非你真的知道你用它做什么。它本质上是一种元编程工具或绕过实例变量可见性的黑客攻击
我正在编写一个gem,我必须在其中fork两个启动两个webrick服务器的进程。我想通过基类的类方法启动这个服务器,因为应该只有这两个服务器在运行,而不是多个。在运行时,我想调用这两个服务器上的一些方法来更改变量。我的问题是,我无法通过基类的类方法访问fork的实例变量。此外,我不能在我的基类中使用线程,因为在幕后我正在使用另一个不是线程安全的库。所以我必须将每个服务器派生到它自己的进程。我用类变量试过了,比如@@server。但是当我试图通过基类访问这个变量时,它是nil。我读到在Ruby中不可能在分支之间共享类变量,对吗?那么,还有其他解决办法吗?我考虑过使用单例,但我不确定这是
我遵循了教程http://gettingstartedwithchef.com/,第1章。我的运行list是"run_list":["recipe[apt]","recipe[phpap]"]我的phpapRecipe默认Recipeinclude_recipe"apache2"include_recipe"build-essential"include_recipe"openssl"include_recipe"mysql::client"include_recipe"mysql::server"include_recipe"php"include_recipe"php::modul
Sinatra新手;我正在运行一些rspec测试,但在日志中收到了一堆不需要的噪音。如何消除日志中过多的噪音?我仔细检查了环境是否设置为:test,这意味着记录器级别应设置为WARN而不是DEBUG。spec_helper:require"./app"require"sinatra"require"rspec"require"rack/test"require"database_cleaner"require"factory_girl"set:environment,:testFactoryGirl.definition_file_paths=%w{./factories./test/
我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R
我有一个这样的哈希数组:[{:foo=>2,:date=>Sat,01Sep2014},{:foo2=>2,:date=>Sat,02Sep2014},{:foo3=>3,:date=>Sat,01Sep2014},{:foo4=>4,:date=>Sat,03Sep2014},{:foo5=>5,:date=>Sat,02Sep2014}]如果:date相同,我想合并哈希值。我对上面数组的期望是:[{:foo=>2,:foo3=>3,:date=>Sat,01Sep2014},{:foo2=>2,:foo5=>5:date=>Sat,02Sep2014},{:foo4=>4,:dat
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
我在用Ruby执行简单任务时遇到了一件奇怪的事情。我只想用每个方法迭代字母表,但迭代在执行中先进行:alfawit=("a".."z")puts"That'sanalphabet:\n\n#{alfawit.each{|litera|putslitera}}"这段代码的结果是:(缩写)abc⋮xyzThat'sanalphabet:a..z知道为什么它会这样工作或者我做错了什么吗?提前致谢。 最佳答案 因为您的each调用被插入到在固定字符串之前执行的字符串文字中。此外,each返回一个Enumerable,实际上您甚至打印它。试试