c# – 从数据库获取数据的问题

我试图通过使用下面的代码数据库获取数据…..

如果表中没有数据,它将始终进入
这个说法

我使用mysql.net连接器获取数据,我正在做winforms应用程序
使用c#

public DataTable sales(DateTime startdate,DateTime enddate)
     {
         const string sql = @"SELECT memberAccTran_Source as Category,sum(memberAccTran_Value) as Value
                              FROM memberacctrans
                              WHERE memberAccTran_DateTime BETWEEN @startdate AND @enddate
                              GROUP BY memberAccTran_Source";

         return sqlexecution(startdate,enddate,sql);
     }

以下代码用于返回sqlexceution …函数..

private static DataTable sqlexecution(DateTime startdate,DateTime enddate,string sql)
 {
         var table = new DataTable();
         using (var conn = new MysqL.Data.MysqLClient.MysqLConnection(connectionstring))
         {
             conn.open();

             var cmd = new MysqL.Data.MysqLClient.MysqLCommand(sql,conn);

             var ds = new DataSet();

             var parameter = new MysqL.Data.MysqLClient.MysqLParameter("@startdate",MysqL.Data.MysqLClient.MysqLDbType.DateTime);
             parameter.Direction = ParameterDirection.Input;
             parameter.Value = startdate.ToString(dateformat);
             cmd.Parameters.Add(parameter);

             var parameter2 = new MysqL.Data.MysqLClient.MysqLParameter("@enddate",MysqL.Data.MysqLClient.MysqLDbType.DateTime);
             parameter2.Direction = ParameterDirection.Input;
             parameter2.Value = enddate.ToString(dateformat);
             cmd.Parameters.Add(parameter2);

             var da = new MysqL.Data.MysqLClient.MysqLDataAdapter(cmd);

             da.Fill(ds);
             try
             {
                 table = ds.Tables[0];

             }
             catch
             {
                 table = null;
             }
         }
         return table;
     }

即使没有数据,流程也会流向此行

table = ds.Tables[0];

我怎么能减少这个……

任何人都会对此有所帮助….

解决方法

在你的情况下,如果你认为如果没有可用的行,那么catch块会被释放,因为即使没有数据,一旦选择查询被排除而没有例外,它会创建带有列但没有行的数据表.

为此,我认为你可以使用ds.table [0] .rows.count属性,如果datatable中没有行,则返回0.

if ( ds.Tables[0].Rows.Count > 0 )
     table = ds.Tables[0];
else
     table=null;

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...