gpt4 book ai didi

c# - 以编程方式获取 Windows 服务并写入 SQL

转载 作者:太空宇宙 更新时间:2023-11-03 19:54:50 25 4
gpt4 key购买 nike

我正在尝试查询远程服务器上的服务并将它们插入到 SQL 中。我知道我遗漏了一些实际上会写回的东西,但我不知道它是什么。一切正常,直到我尝试将数据写入 SQL。

static void Main(string[] args)
{
string username = ConfigurationManager.AppSettings["UserName"].ToString();
string password = ConfigurationManager.AppSettings["Password"].ToString();
string domain = ConfigurationManager.AppSettings["Domain"].ToString();
var logonType = SimpleImpersonation.LogonType.NewCredentials;

using (SimpleImpersonation.Impersonation.LogonUser(domain, username, password, logonType))
{
var connection = ConfigurationManager.ConnectionStrings["Connection"].ConnectionString;

using (SqlConnection conn = new SqlConnection(connection))
{
conn.Open();
using (SqlCommand command = new SqlCommand("SELECT ServerName, ServerIP FROM Server", conn))
{
SqlDataReader reader = command.ExecuteReader();

while (reader.Read())
{
string serverIP = reader["ServerIP"].ToString();
string serverName = reader["ServerName"].ToString();

ServiceController[] services = ServiceController.GetServices(serverIP);

foreach (ServiceController service in services)
{
using (SqlCommand cmd = new SqlCommand("sp_InsertServices", conn))
{
cmd.CommandType = System.Data.CommandType.StoredProcedure;
SqlParameter ID = new SqlParameter();
ID.ParameterName = "@ID";
ID.Direction = System.Data.ParameterDirection.Output;
cmd.Parameters.AddWithValue("@ID", ID);
cmd.Parameters.AddWithValue("@Display", service.DisplayName);
cmd.Parameters.AddWithValue("@Service", service.ServiceName);
cmd.Parameters.AddWithValue("@Status", service.Status);
cmd.Parameters.AddWithValue("@Server", serverName);
}
}
}
}
}
}
}

存储过程

PROCEDURE [dbo].[sp_InsertServices]
@ID int,
@Display nvarchar(50),
@Service nvarchar(50),
@Status nvarchar(50),
@Server nvarchar(50)

AS
BEGIN

SET NOCOUNT ON

INSERT INTO Services
(ID,
DisplayName,
ServiceName,
Status,
Server)

VALUES
(@ID,
@Display,
@Service,
@Status,
@Server)

SET @ID = SCOPE_IDENTITY()

END

编辑:抱歉,请提供更多信息。我在参数添加后最后添加了一个执行,但出现此错误。

System.Data.dll 中发生类型为“System.InvalidOperationException”的未处理异常

附加信息:已经有一个与此命令关联的打开的 DataReader,必须先将其关闭。

看起来我需要关闭第一个阅读器,但我仍然在第二个命令中使用它。现在不要在我可以安全关闭它的地方。

最佳答案

您永远不会执行您的 SqlCommand。添加参数后,尝试添加 cmd.ExecuteNonQuery();

第二个问题是您试图重用相同的 SqlConnection。您将需要创建一个新的 SqlConnection,因为您正在使用现有连接循环访问服务器列表。

关于c# - 以编程方式获取 Windows 服务并写入 SQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34911220/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com