C# GridControl主控-带有存储过程的详细视图

C# GridControl主控-带有存储过程的详细视图,c#,winforms,stored-procedures,devexpress,gridcontrol,C#,Winforms,Stored Procedures,Devexpress,Gridcontrol,我的第一个存储过程如下所示: Use [Stock] Go Create Proc Get_Orders AS SELECT [Number_Order] ,[Date_Order] ,[FullName] ,[Location] FROM [Order] USE [Stock] GO ALTER Proc [dbo].[Get_Order_Res] AS SELECT i.Name_Item ,od.[ID_Order] ,od.[Project] ,od.[Len

我的第一个存储过程如下所示:

Use [Stock]
Go
Create Proc Get_Orders
AS
SELECT [Number_Order]
  ,[Date_Order]
  ,[FullName]
  ,[Location]
FROM [Order]
USE [Stock]
GO
ALTER Proc [dbo].[Get_Order_Res]
AS

SELECT i.Name_Item
  ,od.[ID_Order]
  ,od.[Project]
  ,od.[Length]
  ,od.[Width]
  ,od.[Quantity]
  ,od.[Weight]
  ,od.[Supplier]
  ,od.[GDS_Name]
  ,od.[GDS_Date]
  ,od.[WorkshopName]
  ,od.[WorkshopDate]
  ,od.[ReservedQty]
 FROM OdredDetails od
   INNER JOIN ItemQuantity iq 
           ON iq.ID_ItemQte = od.ID_ItemQte 
   INNER JOIN item i
           ON i.ID_Item = iq.ID_Item 
   INNER JOIN [Order] ord
           ON ord.Number_Order=od.ID_Order
 where ord.[Location]='PRODUCTION'
我的第二个存储过程如下所示:

Use [Stock]
Go
Create Proc Get_Orders
AS
SELECT [Number_Order]
  ,[Date_Order]
  ,[FullName]
  ,[Location]
FROM [Order]
USE [Stock]
GO
ALTER Proc [dbo].[Get_Order_Res]
AS

SELECT i.Name_Item
  ,od.[ID_Order]
  ,od.[Project]
  ,od.[Length]
  ,od.[Width]
  ,od.[Quantity]
  ,od.[Weight]
  ,od.[Supplier]
  ,od.[GDS_Name]
  ,od.[GDS_Date]
  ,od.[WorkshopName]
  ,od.[WorkshopDate]
  ,od.[ReservedQty]
 FROM OdredDetails od
   INNER JOIN ItemQuantity iq 
           ON iq.ID_ItemQte = od.ID_ItemQte 
   INNER JOIN item i
           ON i.ID_Item = iq.ID_Item 
   INNER JOIN [Order] ord
           ON ord.Number_Order=od.ID_Order
 where ord.[Location]='PRODUCTION'
在我的c#代码中,我使用此代码从存储过程中获取数据

        public DataTable Get_Order_Res()
    {
        DAL.DataAccessLayer DAL = new DAL.DataAccessLayer();
        DataTable dt = new DataTable();
        dt = DAL.SelectData("Get_Order_Res", null);
        DAL.Close();
        return dt;

    }
    public DataTable Get_Orders()
    {
        DAL.DataAccessLayer DAL = new DAL.DataAccessLayer();
        DataTable dt = new DataTable();
        dt = DAL.SelectData("Get_Orders", null);
        DAL.Close();
        return dt;

    }
在我的表单中,我使用此代码创建主细节视图

    public partial class FRM_Reserved : Form
{
BL.CLS_Order ord = new BL.CLS_Order();
DataTable master = new DataTable();
DataTable details = new DataTable();
DataSet dataSet = new DataSet();
public FRM_Reserved()
 {
InitializeComponent();      
master = ord.Get_Orders();
details = ord.Get_Order_Res();
dataSet.Tables.Add(master);
dataSet.Tables.Add(details);
dataSet.Relations.Add("OderDetails",
dataSet.Tables["master"].Columns["Number_Order"],
dataSet.Tables["details"].Columns["ID_Order"]);
gridControl3.DataSource = dataSet.Tables["master"];
但是当我运行代码时,我得到一个错误:对象引用没有设置为对象的实例。
请帮助我,提前谢谢。

由于您尚未为数据表命名,因此当您尝试访问它们时,它将返回null

dataSet.Tables["master"] // this returns null
要解决此问题,请为数据表命名

DataTable master = new DataTable("master");
DataTable details = new DataTable("details");

因此,您需要调试并检查哪一行抛出错误并进行修复。是的,我尝试了,发现问题出在dataSet.Relations.Add中,但我找不到如何修复它。我还检查存储过程是否返回数据gridControl3.DataSource=order.Get_Orders();我更改了它,但仍然存在相同的问题。检查这行之后,master=ord.Get_Orders();您是否设置了数据表名称?对于master,我得到了表1,对于详细信息,我得到了表2,然后将它们用作数据集。表[“表1”]或更新它们的名称,我更改了它,它就工作了。感谢Shivani Katukota,我非常感谢