3
public partial class Form2 : Form
{
        public Form2()
        {
            InitializeComponent();
        }
        private void Form2_Load(object sender, EventArgs e)
        {
            RST_DBDataContext db = new RST_DBDataContext();
            var d = (from s in db.TblSpareParts
                                        select new {  s.SPartName, s.SPartCode, s.ModelID, s.SPartLocation,  s.SPartActive, s.SPartSalePrice }).ToArray();
            CrystalReport1 c = new CrystalReport1();
            c.SetDataSource(d);
            crystalReportViewer1.ReportSource = c;

        } 
}

私はクリスタルレポートを生成しようとしています.SQLテーブルでSPartSalePriceはc.SetDataSource(d);でnull可能です。例外が来て解決してください

4

5 に答える 5

6

匿名射影でnull 合体演算子または条件付き演算子を使用して、以下をマップしnullます。

合体:

var d = (from s in db.TblSpareParts
  select new 
  { 
    s.SPartName,
    ...,
    SPartSalePrice = s.SPartSalePrice ?? 0.0,
    ...
  }).ToArray();

条件付き(null にはあまり役に立ちませんが、他の値の射影には役立ちます)

  SPartSalePrice = s.SPartSalePrice == null ? 0.0 : s.SPartSalePrice,

フィールドには名前を付ける必要があり (元の名前をそのまま使用していますSPartSalePrice)、type置換 ( 0.0) はフィールドのタイプと一致する必要があります。

于 2013-09-20T06:43:33.467 に答える
4

オブジェクト値の 1 つが Null である可能性があります。そのようなことを試してください

        private void Form2_Load(object sender, EventArgs e)
    {
        RST_DBDataContext db = new RST_DBDataContext();
        var d = (from s in db.TblSpareParts
                                    select new {  
                                                    s.SPartName?? DBNull.Value, 
                                                    s.SPartCode?? DBNull.Value, 
                                                    s.ModelID ?? DBNull.Value, 
                                                    s.SPartLocation ?? DBNull.Value,  
                                                    s.SPartActive ?? DBNull.Value, 
                                                    s.SPartSalePrice ?? DBNull.Value, 
                                                }).ToArray();
        CrystalReport1 c = new CrystalReport1();
        c.SetDataSource(d);
        crystalReportViewer1.ReportSource = c;

    } 
于 2013-09-20T06:49:10.110 に答える
1

これを試して :

public partial class Form2 : Form
{
        public Form2()
        {
            InitializeComponent();
        }
        private void Form2_Load(object sender, EventArgs e)
        {
            RST_DBDataContext db = new RST_DBDataContext();
    var d = (from s in db.TblSpareParts
             select new { s.SPartName, s.SPartCode, s.ModelID, s.SPartLocation, s.SPartActive, newPartSalePrice = s.SPartSalePrice == null ? 0 : s.SPartSalePrice }).ToArray();
    CrystalReport1 c = new CrystalReport1();
    c.SetDataSource(d);
    crystalReportViewer1.ReportSource = c;

        } 
}

選択でnullをチェックする必要があります

s.SPartSalePrice == null ? 0 : s.SPartSalePrice 

null かどうか。null の場合は 0 を返します。それ以外の場合は値を返し、それを新しい変数に割り当てます。

newPartSalePrice = s.SPartSalePrice == null ? 0 : s.SPartSalePrice 
于 2013-09-20T06:53:28.603 に答える