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); 异常来了请解决

4

5 回答 5

6

在匿名投影中使用空值合并条件运算符来绘制null

合并:

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

有条件的(对空值不是很有用,但对投影其他值很有用)

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

该字段需要命名(我保留了原来的名称,SPartSalePrice),并且type替换的(0.0)应该与字段的类型相匹配。

于 2013-09-20T06:43:33.467 回答
4

也许您的对象值之一是 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

iF 数据类型是字符串然后

SPartSalePrice =s.SPartSalePrice == null ? "" : s.SPartSalePrice;

如果数据为空则显示空白,否则显示数据。

如果数据类型是 int 则

PartSalePrice = s.SPartSalePrice == null ? 0 : s.SPartSalePrice 
于 2014-04-29T05:45:49.380 回答
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 回答
0

如果您只有一个可以为空的属性,请检查您的班级:十进制?, 用十进制表示。对于声明中带有问号的所有属性,只需删除问号并执行。

于 2014-01-07T13:31:33.000 回答