jjzjj

nullability

全部标签

c# - Nullable 可以用作 C# 中的仿函数吗?

考虑以下C#代码。publicintFoo(inta){//...}//insomeothermethodint?x=0;x=Foo(x);最后一行会返回一个编译错误cannotconvertfrom'int?'到'int'这很公平。但是,例如在Haskell中有Maybe,它对应于C#中的Nullable。因为Maybe是一个Functor,所以我可以使用fmap将Foo应用于x>。C#有没有类似的机制? 最佳答案 我们可以自己实现这样的功能:publicstaticclassFuncUtils{publicstaticNulla

c# - DataMember IsRequired 属性与 Nullable 类型的组合是否矛盾?

我今天在WCF契约(Contract)中遇到了这个:[DataMember(IsRequired=true)]publicDateTime?LastModified{get;set;}IsRequired=True和可为空的DateTime的结果是什么?它们似乎相互矛盾。 最佳答案 如果您想用null初始化它并让用户设置有效日期,这是有意义的。因此在提交之前它可以验证用户输入。这里有一个类似的矛盾可能会回答你的问题。InteractionwithIsRequiredTheDataMemberAttributeattributehas

c# - 我可以在一行中从 DBNull 转换为 Nullable Bool 吗?

我有一个数据库查询将返回NULL或bool(位)值。我希望将此值存储在类型为Nullable的变量中在C#中。我似乎找不到可以接受的显式强制转换和转换的组合,以简单的方式执行此操作而不抛出异常。可以在一行可读的代码中完成吗?编辑:要求的代码privateNullableIsRestricted;...//dataaccessIsRestricted=(bool?)DataBinder.GetPropertyValue(dataObj,"IsRestricted");或许IsRestricted=(bool?)(bool)DataBinder.GetPropertyValue(dataO

c# - 为什么 GetType() 为 Nullable<DateTime> 返回 DateTime 类型

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Nullabletypeisnotanullabletype?在下面的代码中:DateTime?dt=DateTime.Now;MessageBox.Show(dt.GetType().ToString());消息框显示“System.DateTime”,而不是Nullable.下面也返回false(因为GetType错误):if(dt.GetType().IsAssignableFrom(typeof(DateTime?)))...(顺便说一下,使用DateTime?或Nullable没有区别)在监wind

c# - LINQ to Entities 无法识别方法 'System.String StringConvert(System.Nullable` 1[System.Double])

我不明白为什么会出现此错误。我已经在以前版本的EntityFramework中成功地使用了这个函数,但是我已经使用EF6设置了一个新项目并且它没有合作。usingSystem.Data;usingSystem.Data.Objects.SqlClient;e.Result=fromninMyDB.tblBulletinswheren.AnncStartDateTime.Now&&n.Approved==trueorderbyn.AnncStartdescending,n.AnncDatedescendingselectnew{n.RecID,AnncTitle=n.AnncTitle+

C# 在使用反射时确定一个 Nullable 属性 DateTime 类型

我有一个关于如何确定对象的Nullable属性类型的问题。ObjectA有一个属性DateTime?创建日期;当我像下面的代码一样遍历其属性时,如何检查属性是否为NullableDateTime类型?foreach(PropertyInfopiinObjectA.GetType().GetProperties()){//dothecomparehere} 最佳答案 pi.PropertyType==typeof(DateTime?) 关于C#在使用反射时确定一个Nullable属性Dat

c# - Entity Framework : field of composite key cannot be nullable?

我有一个带有复合键的模型-行是键:publicclassItem{[Key,Column(Order=0)]publicintUserId{get;set;}[Key,Column(Order=1)]publicDateTime?Date{get;set;}}运行下面的代码会抛出异常DbEntityValidationException消息:TheDatefieldisrequired.:varit=newItem{Date=null,UserId=2};m_Entities.Items.Add(it);m_Entities.SaveChanges();//throwsexceptio

c# - Entity Framework : Problem associating entities with nullable field

我正在使用EntityFramework,我正在尝试将从数据库表创建的实体与从数据库View创建的实体相关联。因为EntityFramework无法自动推断数据库表和View之间的关系,所以我使用实体设计器来构建实体之间的“关联”。但是,如果外键是nullalbe类型,则会出现以下错误:错误113:多重性在关系“UsersView”中的角色“公司”中无效。因为DependentRole中的所有属性都可以为null,所以PrincipalRole的多重性必须为“0..1”。在我的场景中,我的UsersView中有一个可以为null的CompanyId外键(即用户可能没有公司)。使用可为空

java - JDBC getColumns "IS_NULLABLE"和 "NULLABLE"之间的差异

我正在尝试提取JDBC数据库驱动程序的数据库元数据。现在我面临着文档的一部分,我无法向自己解释:方法DatabaseMetaData.getColumns(...);(JavaDoc)声明了两个不同的“可空性”列:NULLABLEint=>isNULLallowed.columnNoNulls-mightnotallowNULLvaluescolumnNullable-definitelyallowsNULLvaluescolumnNullableUnknown-nullabilityunknown和IS_NULLABLEString=>ISOrulesareusedtodetermi

java - 持久化@Column nullable = false 可以插入null

我想做的是这一列不能为空,但是当我在数据库中插入一个寄存器值为空时,这允许我插入。我读了documentation我不知道为什么不起作用。@Column(name="QWECOD",nullable=false)私有(private)字符串qwe;谢谢更新:我正在使用Toplink和javaorg.eclipse.persistence.eclipselink:2.4.2。 最佳答案 我认为如果您使用entitymanager的实现生成模式,则可以使用nullable。我不知道在持久化实体时是否/必须对其进行验证。如果您使用@Not