BCS datetime 时间区间问题

BCS 整合sql表时发现以下问题:
datetime字段在列表中带了时区,比如插入12-6号的数据,在sql中显示的是12-5

date类型字段无法正确识别,插入成功但报错

LobSystem (外部系统)为实体(外部内容类型)“BDI,http://10.136.240.66/kpi”的“创建”创建方法返回的标识符为 Null。


解决:
1.SPD导出BDC模型,并从SPD中删除
2.VS打开编辑

3.修改以下内容
本地时区:<NormalizeDateTime LobDateTimeMode="UTC" /> 为    <NormalizeDateTime LobDateTimeMode="Local" /> 
只显示日期部分:<Property Name="Format" Type="System.String">DateOnly</Property>
显示两位小数:<Property Name="Decimal Digits" Type="System.Int32">4</Property>修改为<Property Name="Decimal Digits" Type="System.Int32">2</Property>

                <Parameter Direction="In" Name="@PublicDate">
                  <TypeDescriptor TypeName="System.DateTime" CreatorField="true" IdentifierName="PublicDate" Name="PublicDate" DefaultDisplayName="日期">
                    <Interpretation>
                      <NormalizeDateTime LobDateTimeMode="UTC" />
                    </Interpretation>
                  </TypeDescriptor>
                </Parameter>
改为
                <Parameter Direction="In" Name="@PublicDate">
                  <TypeDescriptor TypeName="System.DateTime" CreatorField="true" IdentifierName="PublicDate" Name="PublicDate" DefaultDisplayName="日期">
                    <Properties>
                      <Property Name="Format" Type="System.String">DateOnly</Property>
                    </Properties>
                    <Interpretation>
                      <NormalizeDateTime LobDateTimeMode="Local" />
                    </Interpretation>
                  </TypeDescriptor>
                </Parameter>
4.保存文件并在管理中心导入






posted @ 2013-12-06 13:13  ruijian  阅读(343)  评论(0编辑  收藏  举报