未分配的局部变量/ alter XML 格式

Unassigned local variable/ alter XML Format

我的程序接受用户输入并使用它来创建查询。该查询的结果将根据他们的选择放入带有 XElements 的 XML 文件中。我有一个字符串 staff,我将其设置为等于 staffType 的值。

使用查询代码片段声明员工的位置:

        using (
            var conn = new SqlConnection("Server=xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx;Database=KUDERDEV;User ID=xxxxxxxxxxxxxxxxxx;Password= xxxxxxxx;Trusted_Connection=False;Encrypt=True;Connection Timeout=30;")
            )
        {
            conn.Open();
            bool quit = false;
            string choice;
            string staff;
            SqlCommand cmd = new SqlCommand();

            while (!quit)
            {
                Console.WriteLine("Sort by staffType: K12Staff, psStaff, WFStaff or none?");
                string staffType = Console.ReadLine();
                staff = staffType;
                if (staffType == "K12Staff")
                {
                    Console.WriteLine("Sort by code, date, both, or none?");
                    choice = Console.ReadLine();
                    switch (choice)
                    {
                        case "code":
                            Console.WriteLine("Sort by code1 or code2?");
                            string codeCol = Console.ReadLine();
                            Console.WriteLine("Enter desired code");
                            string code = Console.ReadLine();
                            cmd = new SqlCommand("SELECT * FROM Staff WHERE (Staff." + @codeCol + "='" + @code + "') AND staffType ='" + @staffType + "' FOR XML PATH('staff'), ROOT('k12Staff')", conn);
                            quit = true;
                            staff = staffType;
                            break;

查询字符串完成后,我进入另一个 using 语句而不关闭第一个语句来写入 XML 文件。在这里,我想根据选择的 staffType 更改 XML (XElement) 的格式。

正在编写 XML 文件片段:

        using (cmd)
        {
            using (var reader = cmd.ExecuteXmlReader())
            {
                var doc = XDocument.Load(reader);
                string path = @"Staff." + DateTime.Now.ToString("yyyyMMdd") + ".xml";
                using (var writer = new StreamWriter(path))
                {
                    //if (staff == "k12Staff")
                    XNamespace ns = "http://specification.sifassociation.org/Implementation/na/3.2/html/CEDS/K12/K12_k12Staff.html";
                    var root = new XElement(ns + "k12Staff");

                    foreach (var d in doc.Descendants("staff"))
                    {
                        root.Add(new XElement(ns + "staff",
                                    new XElement(ns + "identity",
                                        new XElement(ns + "name",
                                            new XElement(ns + "firstName", first),
                                            new XElement(ns + "lastName", last)
                                            )
                                        ),
                                    new XElement(ns + "employment",
                                        new XElement(ns + "positionTitle", position)
                                            ),
                                    new XElement(ns + "assignment",
                                        new XElement(ns + "leaID", leaID),
                                        new XElement(ns + "schoolID", schoolID)
                                                ),
                                    new XElement(ns + "contact",
                                        new XElement(ns + "phoneNumberList",
                                            new XElement(ns + "number", phone),
                                            new XElement(ns + "phoneNumberIndicator", indicator)
                                        ),
                                        new XElement(ns + "emailList",
                                            new XElement(ns + "email", email)
                                            )
                                            ),
                                    new XElement(ns + "delete", delete)

然后,如果 staffType 不同,例如 "psStaff",那么我将更改 XML (XElement) 的格式,使其具有不同的名称、职位等。

所以它会像:

 if(staff == "k12Staff"){
         format xml here...
 }
 else if (staff == "psStaff"){
         format xml here....
 }

等等等

我的问题:

在前面的例子中,我的代码有 if(staff == "k12Staff") 但我被告知它是一个分配的局部变量。我曾尝试在 using 语句之外声明 staff 以及尝试在像 using(staff) 这样的 using 语句中使用 staff,这就是我使用 cmd 变量的方式。为什么我的程序可以识别 cmd 但不能识别 staff

您没有 post 整个代码,因此不可能说出您的变量 staff 应该在何处获取值以及为什么不获取值。

未分配意味着:存在但从未获得值...

尝试以下操作:在您声明变量的地方更改此:

    string staff="defaultValue";

在你处理变量内容的地方改变这个:

 if(staff == "k12Staff"){
         format xml here...
 }
 else if (staff == "psStaff"){
         format xml here....
 }
 else if (staff == "defaultValue"){
      //What ever is to be done if all attempts to set "staff" did not work
      //You must set a stop mark before your `while (!quit)` and step through.
      //There is at least one situation, where `staff` is not set to any value...
      //If there's a bug you must fix this, if this is allowed to happen, solve it here...
 }