Ho utilizzato la procedura memorizzata con parametri sql con il mio report principale che funziona.Report Crystal con sottoreport collegato che funziona solo su Anteprima report
mia stored procedure per il mio rapporto principale
poi ho cercato di aggiungere subreport all'interno del rapporto di lavoro con la seguente stored procedure
quindi collegare campo Subreport parametri per il mio principale
ho controllato il principale Anteprima di report se subreport stanno lavorando
Poi ho eseguito la relazione, ma tutto quello che vedo è questa appena bloccato in questo messaggio e continuò a correre, Attendo persino ore e controllo se il task manager ha bloccato il report, ma no. Inoltre non ha alcun messaggio di errore. Ma per chiudere il rapporto in esecuzione devo "Termina processo" nel Task Manager.
così ho provato a rimuovere i parametri di campo dal rapporto secondario, nonché i collegamenti e rieseguire il rapporto.
si sta lavorando, ma è inutile avere un rapporto senza passare i valori dalla relazione principale. perché ho un intervallo di date in esso. Quello che sembra essere il problema? Perché è rimasto bloccato sul caricamento del rapporto quando collego i parametri?
per ulteriori informazioni che sto utilizzando SAP Crystal Report Service Pack 16, e IDE come Visual Studio 2015
e questo è il codice che ho usato per i valori di get/set per i parametri sulla relazione principale
private void SalesByRangeReport_Load(object sender, EventArgs e)
{
FormBorderStyle = FormBorderStyle.Sizable;
WindowState = FormWindowState.Maximized;
TopMost = true;
DataTable dtSalesByRangeReport = GetData();
showReport(dtSalesByRangeReport);
}
private void showReport(DataTable dtSalesByRangeReport)
{
ReportDocument rdoc = new ReportDocument();
//rdoc.Load(@"Report\SalesByRangeReport.rpt");
rdoc.Load(AppDomain.CurrentDomain.BaseDirectory + @"Report\SalesByRangeReport.rpt");
rdoc.SetDataSource(dtSalesByRangeReport);
TextObject txt;
if (rdoc.ReportDefinition.ReportObjects["test"] != null)
{
txt = (TextObject)rdoc.ReportDefinition.ReportObjects["test"];
txt.Text = "From :" + StartDate.ToString(" MMMM dd yyyy hh :mm") + " To :" + EndDate.ToString(" MMMM dd yyyy hh :mm");
}
SalesByRangeCystalReport.ReportSource = rdoc;
}
private DataTable GetData()
{
DataTable dtData = new DataTable();
using (SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["CSPOSWare.Reports.Properties.Settings.fpos_chaplinConnectionString"].ConnectionString))
{
//TODO Mark and Reni : Create a Stored Procedure, Saved in SalesByRangeReport.txt
using (SqlCommand cmd = new SqlCommand("usp_ReportShowSalesRangeDateTime", conn))
{
cmd.CommandType = CommandType.StoredProcedure;
conn.Open();
//cmd.Parameters.AddWithValue("@TopInt", this.TopInt);
cmd.Parameters.AddWithValue("@SortType", this.SortType);
cmd.Parameters.AddWithValue("@StartDate", this.StartDate);
cmd.Parameters.AddWithValue("@EndDate", this.EndDate);
cmd.Parameters.AddWithValue("@DeptGroup", this.DeptGroup);
cmd.Parameters.AddWithValue("@DateType", this.DateType);
//Console.WriteLine("Start Date" + StartDate);
SqlDataReader rdr = cmd.ExecuteReader();
dtData.Load(rdr);
}
}
return dtData;
}
ed entrambi della mia relazione hanno queste proprietà:
Build Action: Compile
Copy to Output Directory: Copy Always
Custom Tool:
Custom Tool Name:
Così ho provato AGGIUNTO OPTIMIZE FOR UNKNOWN sia sul mio principale SP e SUB SP PRINCIPALE:
ALTER PROCEDURE[dbo].[usp_ReportShowSalesRangeDateTime]
(
@SortType Varchar(50),
@StartDate DATETIME,
@EndDate DATETIME,
@DeptGroup Varchar(50),
@DateType Varchar(50)
)
AS
BEGIN
Declare @SQLQuery NVARCHAR(max)
Declare @ReportCriteria NVARCHAR(max)
If (LEN(@DeptGroup) > 0)
Set @ReportCriteria = ' AND B.Department = ''' + @DeptGroup + '''';
If (LEN(@DeptGroup) = 0)
Set @ReportCriteria = ' ';
WITH SalesRange AS(
Select A.EndDate as [Log Date], A.StoreDate as [Store Date], B.Department as [Department], B.Quantity as [Quantity],
isnull(C.Amount,0) as [Discount], B.AmountDue as [AmountDue],round(B.BasePrice*1.12,4) as [Gross Sales],
B.BasePrice + isnull(vsa.Tax,0) as [BasePrice],
case when vsa.type = 0 then isnull(vsa.Amount,0) else 0.0000 end As [VAT Sales Amount],
case when vsa.type = 1 then isnull(vsa.Amount,0) else 0.0000 end As [VAT Exempt Sales Amount],
B.ServiceCharge as [ServiceCharge], isnull(vsa.Tax,0) As [VAT Sales Tax],
case when D.[Type] = 0 Then D.Tax Else 0 End As [Tax],
case when T.MediaIndex = 4 then T.Amount else 0 End As [GiftCert],
case when T.MediaIndex = 4 then 1 else 0 End As [GCCount]
FROM CSSaleItem B WITH(NOLOCK)
LEFT JOIN CSSaleItemDiscount C WITH(NOLOCK) ON B.CSSaleItemID = C.CSSaleItemID
LEFT JOIN CSSale A WITH(NOLOCK) ON A.CSSaleID = B.CSSaleID
LEFT JOIN CSSaleItemTax D WITH(NOLOCK) ON B.CSSaleItemID = D.CSSaleItemID
LEFT JOIN (Select CSSaleItemID, Amount, Tax, [Type] From CSSaleItemTax WITH(NOLOCK) Where [Type] = 0) As vsa ON vsa.CSSaleItemID = B.CSSaleItemID
LEFT JOIN CSSaleTender T WITH(NOLOCK) ON T.CSSaleID = A.CSSaleID
Where StoreDate BETWEEN convert(VARCHAR,@StartDate) AND convert(VARCHAR,@EndDate) and a.RefundStoreDate IS NULL
)
SELECT [Department], sum([Quantity]) as [Quantity], SUM([Tax]) as [Tax] , sum([Discount]) as [Discount],
sum(([Gross Sales]+[ServiceCharge])) as [Gross Sales], sum(([BasePrice]+[ServiceCharge]-[Discount])) As [Net Sales],
sum(([BasePrice]+[ServiceCharge]-[Discount]))/
(Select sum(NetSales) FROM CSSale B LEFT JOIN (select csSaleID, Department from CSSaleItem WITH(NOLOCK) group by Department, CSSALEID) AS A On A.CSSaleID = B. CSSaleID
Where StoreDate BETWEEN convert(VARCHAR,@StartDate) AND convert(VARCHAR,@EndDate) and RefundStoreDate IS NULL)*100 as [% Total],
sum([GiftCert]) as [Gift Cert Total], sum([ServiceCharge]) as [Service Charge], sum([GCCount]) as [GCCountTotal]
From SalesRange
Group By [Department]
Order By [Department] desc
OPTION (OPTIMIZE FOR (@StartDate UNKNOWN, @EndDate UNKNOWN))
END
Subreport:
ALTER PROCEDURE[dbo].[usp_ReportShowMedia](
@StartDate2 DATETIME,
@EndDate2 DATETIME
)
As
BEGIN
Select isnull(M.MediaName,'Other') As [Media],
COUNT(T.MediaIndex) As [Count],
isnull(sum(T.Amount),0) As [Sales Amount],
isnull(sum(case when S.EndDate IS NOT NULL and DateRefunded IS NULL Then S.NetSales Else 0 End),0) As [Total Sales],
isnull(sum(case when S.EndDate IS NULL then S.NetSales else 0 end),0) as [Cancelled Sales],
isnull(sum(case when S.DateRefunded IS NOT NULL then S.NetSales else 0 end),0) as [Refunded Sales]
FROM CSSale S WITH(NOLOCK)
LEFT JOIN (Select CSSaleID, Department from CSSaleItem WITH(NOLOCK) group by CSSaleID,Department) As I ON I.CSSaleID = S.CSSaleID
LEFT JOIN CSSaleTender T WITH(NOLOCK) On S.CSSaleID = T.CSSaleID
LEFT JOIN Media M WITH(NOLOCK) ON M.MediaIndex = T.MediaIndex
Where StoreDate BETWEEN convert(VARCHAR,@StartDate2) AND convert(VARCHAR,@EndDate2)
group by M.MediaName
order by M.MediaName
OPTION (OPTIMIZE FOR (@StartDate2 UNKNOWN, @EndDate2 UNKNOWN))
END
stessi risultati, credo che il dal report principale non passano attraverso il rapporto di sub, perché sempre funziona solo su Preview, ma il runtime appena bloccato sul caricamento.
Ho provato sp_who2 attivo per controllare se bloccato.
btw Sto usando questa connessione, sul mio App.config se questo aiuta ..
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<startup useLegacyV2RuntimeActivationPolicy="true">
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.2" />
</startup>
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<probing privatePath="lib" />
</assemblyBinding>
</runtime>
<connectionStrings>
<add name="CSPOS.Reports.Properties.Settings.chaplinConnectionString" connectionString="Data Source=RENZ\SQLEXPRESS;Initial Catalog=erika;Integrated Security=True" providerName="System.Data.SqlClient"/>
</connectionStrings>
</configuration>
ho controllato autorizzazioni per il database su Master
In quale sezione hai inserito il rapporto secondario all'interno del rapporto principale? potrebbe essere che sta causando il problema – Siva
L'ho messo nella sezione Pippo di riporto del rapporto – FatalError
Perché stai convertendo le date in VARCHAR? "BETWEEN convert (VARCHAR, @ StartDate2) AND convert (VARCHAR, @ EndDate2)" – Alex