Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/287.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 在数据绑定的情况下,当c-sharp图表控件没有数据时,如何显示至少x轴和y轴?_C#_Asp.net_Charts - Fatal编程技术网

C# 在数据绑定的情况下,当c-sharp图表控件没有数据时,如何显示至少x轴和y轴?

C# 在数据绑定的情况下,当c-sharp图表控件没有数据时,如何显示至少x轴和y轴?,c#,asp.net,charts,C#,Asp.net,Charts,我有下面的代码,它创建了一个包含三个系列的图表,第一个系列是柱形条,第二行和第三行。当从sqlcommand返回数据时,将创建图表,但当没有返回行时,图表应至少显示x和y轴 C代码: string DatabaseConnectionString = System.Configuration.ConfigurationManager.ConnectionStrings["AVISConnectionString"].ConnectionString; SqlConnection conn = n

我有下面的代码,它创建了一个包含三个系列的图表,第一个系列是柱形条,第二行和第三行。当从sqlcommand返回数据时,将创建图表,但当没有返回行时,图表应至少显示x和y轴

C代码:

string DatabaseConnectionString = System.Configuration.ConfigurationManager.ConnectionStrings["AVISConnectionString"].ConnectionString;
SqlConnection conn = new SqlConnection(DatabaseConnectionString);
conn.Open();
DataTable dtSr = new DataTable();
SqlCommand cmd = null;
SqlDataReader reader = null;
cmd = new SqlCommand("Select case when KWmittel is null then '0' else KWmittel  end as [KWmittel], case when YTD is null then '0' else YTD  end as [YTD], case when soll is null then '0' else soll end as [soll] from dbo.Ausbringung_Wiegen_2013 a inner join dbo.ytd y on a.weekID = y.weekID inner join dbo.sollno s on y.weekID = s.weekID where a.weekID < datepart(week,getdate())", conn);
reader = cmd.ExecuteReader();
if (!reader.Read())
{
    //I don't know how to handle here, I just gave a try but doesn't work
    Chart4.ChartAreas["Chartarea1"].AxisX.Minimum = 0;
    Chart4.ChartAreas["Chartarea1"].AxisY.Minimum = 0;
    Chart4.Series["s1"].YValueMembers = null;
    Chart4.Series["s2"].YValueMembers = null;
    Chart4.Series["s3"].YValueMembers = null;
}
dtSr.Load(reader);            
Chart4.DataSource = dtSr;
Chart4.Series["s1"].YValueMembers = "KWmittel";
Chart4.Series["s2"].YValueMembers = "YTD";
Chart4.Series["s3"].YValueMembers = "soll";            
Chart4.DataBind();
cmd = null;
dtSr.Clear(); 

我真的非常感谢任何帮助和想法。谢谢:

我自己找到了这个问题的答案,代码如下:

dtSr.Load(reader);
        if(dtSr.Columns==null)
        {
            for (int i = 0; i < seriesa.Length; i++)
            {
                Chart3.Series[seriesa[i]].Points.AddY(0);
            }
        }
        else
        {
            Chart3.DataSource = dtSr;                                                    
            Chart3.Series["s2"].YValueMembers = "YTD";
            Chart3.Series["s3"].YValueMembers = "soll";
            Chart3.Series["s1"].YValueMembers = "KW_Mittel";
            Chart3.DataManipulator.InsertEmptyPoints(1, System.Web.UI.DataVisualization.Charting.IntervalType.Number, Chart3.Series["s3"]);
            Chart3.DataManipulator.InsertEmptyPoints(1, System.Web.UI.DataVisualization.Charting.IntervalType.Number, Chart3.Series["s2"]);
            Chart3.Series["s3"].EmptyPointStyle.Color = System.Drawing.Color.Transparent;
            Chart3.Series["s2"].EmptyPointStyle.Color = System.Drawing.Color.DarkGreen;
            Chart3.Series["s2"].BorderWidth = 2;
            Chart3.DataBind();
        }