- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 SQL Server 2014 和 Sisual studio 2013 的 SSIS 设计器 SSDT BI。我在执行 SQL 任务中有以下查询,单个结果集将值分配给字符串数据类型的变量“角色”。
SELECT DISTINCT (STUFF((SELECT CAST(',' + SubTableUser.UserRole AS VARCHAR(MAX))
FROM TableUser AS SubTableUser
WHERE SubTableUser.UserID = TableUser.UserID
FOR XML PATH('')), 1, 1, '')) AS UserRole
FROM TableUser
执行 SQL 任务错误:
值类型(__ComObject)只能转换为Object类型的变量。为变量“role”赋值时出错:“赋值给变量的值类型 (DBNull)“User::role”不同于当前变量类型(字符串)。变量在执行期间可能不会改变类型。变量类型是严格的,除了 Object 类型的变量。”。
我试图在脚本任务 String.Format("{0}", Dts.Variables["User::role"])
中将对象变量值分配给字符串变量并得到此值“System.__ComObject”而不是实际值。
最佳答案
我知道这是一篇较旧的帖子,但像我自己一样,我相信遇到同样问题的其他人也会遇到它。问题在于 SSIS 将 VARCHAR(MAX) 或 NVARCHAR(MAX) 转换为 ComObject。并且没有办法将其转换/转换为其他任何东西。哈迪的上述建议是不正确的。由于它是 varchar(max),因此无法将其转换/强制转换为任何内容,并且必须在结果中将其视为对象。
我的问题是我正在为远远超过 8000 条的电子邮件消息生成一个包含嵌套表格的复杂 HTML 正文,因此无法将我的代码限制为 VARCHAR(8000)。我还附上了一个包含更多详细信息的 Excel 文件。过去,我一直使用 sp_dbSendMail 来完成这项工作,我觉得这要容易得多,但是我们的 IT“领导”决定他们想限制我们启用它的能力,因此我们必须找到绕过它的方法,直到工作场所的政治问题得到解决。解决了。
我发现唯一可行的方法是返回一个表,而不是一个变量。在 SSIS 结果集中创建您的变量作为对象并将其结果名称指定为 0。然后将该结果名称分配给您创建的用户变量 (User::objResultSet)。然后在您的 VstaProject 中将对象 (User::objResultSet) 视为一个表并提取您的值。请记住,SSIS 和 Vsta 不喜欢我一直使用的下划线 (_),因此请适本地命名您的列和变量。
这是我所做的。在您的执行 SQL 任务中,为您的 SQL 语句输入以下变体。此代码假定您已经收集并创建了放入表中的所有值(电子邮件正文、电子邮件主题等)。出于安全目的,我只将输出放入表中:
CREATE TABLE #EMAIL_TEMP
(
EmailBody VARCHAR(MAX)
,EmailSubject VARCHAR(255)
,EmailTo VARCHAR(8000)
,EmailAttach VARCHAR(8000)
)
INSERT INTO #EMAIL_TEMP
(EmailBody, EmailSubject, EmailTo, EmailAttach)
SELECT CAST(ISNULL(@tableHTML , '') AS VARCHAR(MAX)) AS EmailBody
,ISNULL(@emailSubject, '') AS EmailSubject
,ISNULL(@TO_LIST , '') AS EmailTo
,ISNULL(@ATTACH, '') AS EmaiAttach
SELECT EmailBody, EmailSubject, EmailTo, EmailAttach
FROM #EMAIL_TEMP
您会注意到我可以将我的表数据类型保留为电子邮件正文的 VARCHAR(MAX)。可以对所有列执行此操作,因为您要将其视为一个对象。
现在在您的脚本任务中使用以下代码:
using System;
using System.Data;
using Microsoft.SqlServer.Dts.Runtime;
using System.Windows.Forms;
using System.Net;
using System.Net.Mail;
using System.Data.OleDb;
public void Main()
{
OleDbDataAdapter A = new OleDbDataAdapter();
System.Data.DataTable dt = new System.Data.DataTable();
A.Fill(dt, Dts.Variables["User::objResultSet"].Value);
string EmailBody = "";
string EmailSubject = "";
string EmailTo = "";
string EmailFrom = "sombodycool@someplace.com";
string EmailAttach = "";
foreach (DataRow row in dt.Rows)
{
object[] array = row.ItemArray;
EmailBody = array[0].ToString();
EmailSubject = array[1].ToString();
EmailTo = array[2].ToString();
EmailAttach = array[3].ToString();
}
string htmlMessageFrom = EmailFrom.ToString();
string htmlMessageTo = EmailTo.ToString();
string htmlMessageSubject = EmailSubject.ToString();
string htmlMessageBody = EmailBody.ToString();
string htmlMessageAttach = EmailAttach.ToString();
string smtpServer = Dts.Variables["HtmlEmailServer"].Value.ToString();
SendMailMessage(htmlMessageFrom, htmlMessageTo, htmlMessageSubject, EmailBody, htmlMessageAttach, true, smtpServer);
Dts.TaskResult = (int)ScriptResults.Success;
}
private void SendMailMessage(string From, string SendTo, string Subject, string Body, string Attach, bool IsBodyHtml, string Server)
{
MailMessage htmlMessage;
SmtpClient mySmtpClient;
htmlMessage = new MailMessage(From, SendTo, Subject, Body);
htmlMessage.IsBodyHtml = IsBodyHtml;
System.Net.Mail.Attachment attachment;
attachment = new System.Net.Mail.Attachment(Attach);
htmlMessage.Attachments.Add(attachment);
mySmtpClient = new SmtpClient(Server);
mySmtpClient.Credentials = CredentialCache.DefaultNetworkCredentials;
mySmtpClient.Send(htmlMessage);
}
确保在关闭之前保存您的 Vsta 代码,否则您将丢失它。然后在您的脚本任务上选择确定并进行测试。
希望对大家有所帮助。我搜索并为此工作了一个多星期。我找到的文章都没有答案,只有尖刻的、不完整的或无效的回复。
关于c# - 对象类型的SSIS变量到字符串的转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40293586/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!