指定した日よりも古いサーバー上のログ ファイルを削除するプログラムを作成する方法を学んでいます。このプログラムは、サーバー ベースではなく、テーブル ベースになります。UNC を使用すると、ログ ファイルのディレクトリのパスがデータベースに格納されます。Directory.GetFiles() メソッドについて学んでいますが、どの構文がパスになるのかわかりません。パスが保存されているので、workListになると思います。これを解決するための助けをいただければ幸いです。私のコードは以下です。
//create list to store database contents
static List<LogData> GetWorkList()
{
List<LogData> logDatas = new List<LogData>();
LogData logData = new LogData();
//execute sql query
//execute database reader
string sqlQuery = "Select daysToKeep, fileLocation, active from dbo.FileDeletion where fileLocation='@fileLocation';";
SqlCommand command = new SqlCommand(sqlQuery);
SqlDataReader reader = command.ExecuteReader();
while (reader.Read())
{
//make a logData, creating a new instance of a class
logData = new LogData();
//move stuff from reader into log data, and exp
logData.DaysToKeep = Convert.ToInt32(reader["daysToKeep"]);
logData.Active = Convert.ToBoolean(reader["active"]);
logData.FileLocation = Convert.ToString(reader["fileLocation"]);
//add logData to list
logDatas.Add(logData);
}
return logDatas;
}
//Get active entries from table, call getWorkList
public static void WorkList(//Not sure of what path to use)
{
//get active entries
List<LogData> workList = GetWorkList();
foreach()
{
if(File.Exists()
{
}
}
//check to see if date created in directory is older that x number of days
if(DateTime.Now.Subtract(dt).TotalDays <= 1)
{
log.Info("This directory is less than a day old");
}
//if file is older than x number of days
else if (DateTime.Now.Subtract(dt).TotalDays <= //not sure of what variable or property to use)
{
File.Delete
}
//delete file
}