首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >C# Access无法识别查询中的参数

C# Access无法识别查询中的参数
EN

Stack Overflow用户
提问于 2018-06-10 01:48:52
回答 1查看 310关注 0票数 0

我正在尝试用C#编写一个sql查询来访问。这个查询在Access软件中运行得很好,但是当我试图通过带参数的C#运行它时,它抛出了一个异常,即缺少参数。它好像忽略了我给出的参数。这是我的方法:

public DataTable GetRoomStatusByDate(Room RoomItem, TimeRange TimeItem, WeekDay DayItem, DateTime DateItem)
        {
            string cmdStr = "SELECT Subject, AdditionOrCancellation, Description " + 
                            "FROM (SELECT * " + 
                                "FROM TimeTables TT1 LEFT OUTER JOIN SpecialEvents SE1 " + 
                                "ON TT1.RoomNumber = SE1.RoomNumber AND TT1.StructureNumber = SE1.StructureNumber AND " +
                                "TT1.DayNumber = SE1.DayNumber AND TT1.HourNumber = SE1.HourNumber " + 
                                "UNION " + 
                                "SELECT * " + 
                                "FROM TimeTables TT2 RIGHT OUTER JOIN SpecialEvents SE2 " + 
                                "ON TT2.RoomNumber = SE2.RoomNumber AND TT2.StructureNumber = SE2.StructureNumber " + 
                                "AND TT2.DayNumber = SE2.DayNumber AND TT2.HourNumber = SE2.HourNumber) " +
                            "WHERE (TT1.RoomNumber = @TTRoomNumber OR SE1.RoomNumber = @SERoomNumber) AND (TT1.StructureNumber = @TTStructureNumber OR SE1.StructureNumber = @SEStructureNumber) " +
                            "AND(TT1.HourNumber = @TTHourNumber OR SE1.HourNumber = @SEHourNumber) AND (TT1.DayNumber = @TTDayNumber OR SE1.DayNumber = @@SEDayNumber) " +
                            "AND (SE1.EventDate = @SEEventDate OR SE1.EventDate IS NULL)";
            DataSet ds = new DataSet();
            using (OleDbCommand command = new OleDbCommand(cmdStr))
            {
                command.Parameters.AddWithValue("@TTRoomNumber", RoomItem.Number);
                command.Parameters.AddWithValue("@SERoomNumber", RoomItem.Number);
                command.Parameters.AddWithValue("@TTStructureNumber", RoomItem.Structure);
                command.Parameters.AddWithValue("@SEStructureNumber", RoomItem.Structure);
                command.Parameters.AddWithValue("@TTDayNumber", TimeItem.Number);
                command.Parameters.AddWithValue("@SEDayNumber", TimeItem.Number);
                command.Parameters.AddWithValue("@TTDayNumber", DayItem.Number);
                command.Parameters.AddWithValue("@SEDayNumber", DayItem.Number);
                command.Parameters.AddWithValue("@SEEventDate", DateItem);
                ds = GetMultipleQuery(command);
            }
            DataTable dt = new DataTable();
            try
            {
                dt = ds.Tables[0];
            }
            catch
            { }
            return dt;
        }

我还想提一下,我使用OLEDB,我的连接非常好,因为我有许多带有查询和参数的方法,它们都工作得很好,没有任何问题。这是我唯一一个查询不起作用的方法。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-06-10 01:54:42

OleDb使用位置参数,而不是命名参数。在SQL中将参数名称替换为?。您可以在AddWithValue中保持参数名称不变,因为它会被忽略。

...
"WHERE (TT1.RoomNumber = ? OR SE1.RoomNumber = ?) AND (TT1.StructureNumber = ? OR SE1.StructureNumber = ?) " +
"AND(TT1.HourNumber = ? OR SE1.HourNumber = ?) AND (TT1.DayNumber = ? OR SE1.DayNumber = ?) " +
"AND (SE1.EventDate = ? OR SE1.EventDate IS NULL)";

确保按参数在SQL文本中出现的顺序添加参数。

此外,传递给AddWithValue的值必须具有正确的类型。数字或日期字符串不会自动转换为适当的数字或DateTime类型。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50776991

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档