ವರ್ಗ ಆರ್ಕೈವ್ಸ್: ಶೇರ್ಪಾಯಿಂಟ್ ಅಭಿವೃದ್ಧಿ

ಸಿಂಪಲ್ ಎಕ್ಸ್ಪ್ಲನೇಷನ್: “ಮೌಲ್ಯ ನಿರೀಕ್ಷಿತ ವ್ಯಾಪ್ತಿಯಲ್ಲಿ ಬೀಳುತ್ತವೆ ಮಾಡುವುದಿಲ್ಲ.”

ನವೀಕರಿಸಲು: An anonymous poster left a great comment about internal names. Be sure to read it.

ಈವೆಂಟ್ ಗ್ರಾಹಕಗಳು ಮತ್ತು ಇತರ ಕೋಡ್ ಕೆಲಸ ಮಾಡುವಾಗ ವಸ್ತು ಮಾದರಿಯ ಮೂಲಕ ಉಲ್ಲೇಖಗಳು ಶೇರ್ಪಾಯಿಂಟ್ ಪಟ್ಟಿ ಐಟಂಗಳನ್ನು, ನಾನು ಸಾಮಾನ್ಯವಾಗಿ ರನ್ಟೈಮ್ ಈ ದೋಷ ಉತ್ಪಾದಿಸುವ ತಪ್ಪುಮಾಡುವ:

Xyzzy ದೋಷ ಲೋಡ್ ಮತ್ತು ಓಟದ ಸ್ಪರ್ಧೆ ರಿಸೀವರ್ Conchango.xyzzyEventReceiver, ಆವೃತ್ತಿ = 1.0.0.0, ಸಂಸ್ಕೃತಿ = ತಟಸ್ಥ, PublicKeyToken = 0dc50a750396c3ac. Additional information is below. : Value does not fall within the expected range.

I think this is a fairly generic error that is potentially caused many different ways. ಹೇಗಾದರೂ, one simple explanation is that I’m referencing a field incorrectly. If the name of the field is "Due Date", ನಾನು ಕ್ರಿಯೆಯನ್ನು ರಿಸೀವರ್ ಈ ರೀತಿಯ ಇದು ಉಲ್ಲೇಖಿಸಿ ಮಾಡಬೇಕು:

properties.ListItem["Due Date"]

ಕ್ಷೇತ್ರ ಗುರುತಿಸಲಾಗುತ್ತಿದೆ ನಾನು ತಪ್ಪು ಸಂದರ್ಭದಲ್ಲಿ ತಪ್ಪಾಗಿ ಉಚ್ಚರಿಸುತ್ತವೆ ಅಥವಾ ಬಳಸಿದಾಗ, SharePoint generates the above mentioned runtime error. ಉದಾಹರಣೆಗೆ, ಈ ತಪ್ಪು:

properties.ListItem["due Date"]

</ಕೊನೆಯಲ್ಲಿ>

ನನ್ನ ಬ್ಲಾಗ್ ಚಂದಾದಾರರಾಗಿ.

ಚುರುಕಾದ & ಸುಲಭ: ಒಂದು ಫೋಲ್ಡರ್ ರಚಿಸಿ ಮತ್ತು ವಿಷಯ ಕೌಟುಂಬಿಕತೆ ನಿಗದಿಪಡಿಸಿ (ಅಥವಾ, ನಿಮ್ಮ KPIs ಮತ್ತು ದೆಮ್ ಟೂ ಈಟ್)

ಸುಮಾರು ಒಂದು KPI ಸಮಸ್ಯೆ ಕೆಲಸ ಸಲುವಾಗಿ ನಾನು ಇಲ್ಲಿ ಬಗ್ಗೆ ಬರೆದಿದ್ದಾರೆ, I did some testing and discovered that KPI’s work against folders with meta data in the same way that they work against documents or list items. I proved it out by creating a new content type based on the folder content type and then added a few fields. I created some indicators and proved to myself that KPIs work as expected. This was welcome news. It’s not perfect, because the drill-down you get from the KPI against the folders is not exactly what you want. This isn’t too much a drawback in my case because 1) ಅಂತಿಮ ಬಳಕೆದಾರರಿಗೆ ಯಾವುದೇ ಉತ್ತಮ ಮತ್ತು ಗೊತ್ತಿಲ್ಲ 2) the drill-down goes to a folder. They click the folder name and they are at the item. It’s two clicks instead of one, ಇದು ವಿಶ್ವದ ಕೊನೆಯಲ್ಲಿ ಅಲ್ಲ.

This flowed nicely with the work I was doing. I am creating a folder for every document that gets uploaded. This is done via an event receiver. ಪರಿಣಾಮವಾಗಿ, ಇದು ಇರಿಸಿಕೊಳ್ಳಲು ಕೇಕ್ ತುಂಡು ಇಲ್ಲಿದೆ ಫೊಲ್ಡರಿನ ತಂದೆಯ meta data in sync with the KPI-driven meta data from the file itself since the plumbing is already in place. This allows me to have my KPI’s and eat them too 🙂

I modified the event receiver to add the folder and then set this new folder’s content type to my custom KPI-friendly content type. This bit of code did the trick:

 SPFolderCollection srcFolders = targetWeb.GetFolder("Documents").SubFolders;
  SPFolder addedFolder = srcFolders.Add(properties.ListItem.ID.ToString());
  SPContentTypeId kpiCT = ಹೊಸ SPContentTypeId("0x0120002A666CAA9176DC4AA8CBAA9DC6B4039F");
  addedFolder.Item["Content Type ID"] = KpiCT;
  addedFolder.Item.Update();

ನಿಜವಾದ ವಿಷಯ ಕೌಟುಂಬಿಕತೆ ID ಪತ್ತೆ, ನಾನು ತೋರಿಸಿರುವಂತೆ ಸೈಟ್ ಸೆಟ್ಟಿಂಗ್ಗಳು ಮತ್ತು ನಕಲು ಮೂಲಕ ವಿಷಯವನ್ನು ಕೌಟುಂಬಿಕತೆ / URL ನಿಂದ ಇದು ಅಂಟಿಸಲಾಗಿದೆ ಎಂದು ಸಂಕಲನಗೊಂಡಿದೆ:

ಚಿತ್ರ

</ಕೊನೆಯಲ್ಲಿ>

ನನ್ನ ಬ್ಲಾಗ್ ಚಂದಾದಾರರಾಗಿ!

ತ್ವರಿತ ಮತ್ತು ಸುಲಭ: ಕ್ರಿಯೆಯನ್ನು ಸ್ವೀಕರಿಸುವವರ ಒಂದು SPListItem ಆಫ್ SPFolder ಪಡೆಯಿರಿ

ನಾನು ಅದನ್ನು ಒಪ್ಪಿಕೊಳ್ಳಲು ದ್ವೇಷಿಸುತ್ತೇನೆ, but I struggled with this one all day. My event receiver needs to update a field of its parent folder. This little bit shows how to do it:

ಖಾಸಗಿ ಶೂನ್ಯವಾಗುವ UpdateParentFolder(SPItemEventProperties ಗುಣಗಳು)
{

SPFolder thisItemFolder = properties.ListItem.File.ParentFolder;
thisItemFolder.Item["ZZ Approval Status"] = "Good news, ಪ್ರತಿಯೊಂದು!";
thisItemFolder.Item.Update();


} // UpdateParentFolder

ಈ ಸಂದರ್ಭದಲ್ಲಿ, ನಾನು ಡಾಕ್ಯುಮೆಂಟ್ ಗ್ರಂಥಾಲಯದ ಕೆಲಸ ಬಾಗುತ್ತೇನೆ ಮತ್ತು ಗುಣಗಳನ್ನು ಒಂದು ItemAdded ಘಟನೆಯ ಬರಲಿವೆ.

ಟ್ರಿಕ್ ನೀವು ಐಟಂ ಸ್ವತಃ ನೇರವಾಗಿ ಐಟಂ SPFolder ಪಡೆಯಲು ಸಾಧ್ಯವಿಲ್ಲ ಎಂಬುದು (ಅಂದರೆ. properties.ListItem.Folder ಶೂನ್ಯ ಆಗಿದೆ). ಬದಲಿಗೆ, ಪಟ್ಟಿ ಐಟಂನ ಸಂಬಂಧಿಸಿದ ಕಡತ ಹೋಗಿ ಫೈಲ್ ಆದ ಫೋಲ್ಡರ್ ಪಡೆಯಿರಿ.

</ಕೊನೆಯಲ್ಲಿ>

ನನ್ನ ಬ್ಲಾಗ್ ಚಂದಾದಾರರಾಗಿ!

ಮತ್ತೊಂದು ಈವೆಂಟ್ ಸ್ವೀಕರಿಸುವವರ ಡೀಬಗ್ ಟ್ರಿಕ್

I’m sure I’m not the first person to come up with this. ಹೇಗಾದರೂ, I haven’t noticed anyone publish a trick like this since I started paying close attention to the community last July. ಆದ್ದರಿಂದ, ನಾನು ಈ ತ್ವರಿತ ಮತ್ತು ಸುಲಭ ಡಿಬಗ್ ಸಲಹೆ ಪೋಸ್ಟ್ ಎಂದೆನಿಸಿತ್ತು.

ನಾನು ಈ ದೋಷ ಉತ್ಪಾದಿಸಲು ಆರಂಭಿಸಿದರು ಕ್ರಿಯೆಯನ್ನು ಗ್ರಾಹಕದ ಕೆಲಸ ಬಾಗುತ್ತೇನೆ 12 ಜೇನುಗೂಡು:

Xyzzy ದೋಷ ಲೋಡ್ ಮತ್ತು ಓಟದ ಸ್ಪರ್ಧೆ ರಿಸೀವರ್ Conchango.xyzzyEventReceiver, ಆವೃತ್ತಿ = 1.0.0.0, ಸಂಸ್ಕೃತಿ = ತಟಸ್ಥ, PublicKeyToken = blahbalhbalh. Additional information is below. : ಆಬ್ಜೆಕ್ಟ್ ಉಲ್ಲೇಖ ವಸ್ತುವಿನ ಉದಾಹರಣೆಗೆ ಗೆ ಸೆಟ್ ಆಗಿಲ್ಲ.

I didn’t know where I had introduced this bug because I had done too many things in one of my code/deploy/test cycles.

ನಾನು ಪ್ರಯತ್ನಿಸಿದ ಈ ಪರಿಹಾರ ನಿರೀಕ್ಷೆಯೊಂದಿಗೆ ಅಲ್ಲಿ ನನ್ನ PDB ಪಡೆಯಲು ಎಂದು ಶೇರ್ಪಾಯಿಂಟ್ ತಂದೆಯ 12 ಜೇನುಗೂಡಿನ ಸ್ಟಾಕ್ ಜಾಡಿನ ತೋರಿಸಿದವು, but no luck. I don’t know if it’s possible and if someone does, ನನಗೆ ತಿಳಿಸಿ ದಯವಿಟ್ಟು 🙂

ನಾನು ಸಾಧ್ಯ ಅಂತ ಗೊತ್ತು ನಿಮ್ಮ ಸ್ವಂತ ಲಾಗ್ ಸಂದೇಶಗಳನ್ನು ಬರೆಯಲು 12 ಜೇನುಗೂಡು. Frankly, ನಾನು ಕಾರ್ಯಗತಗೊಳಿಸಲು ಸ್ವಲ್ಪ ಕಡಿಮೆ ಹೆದರಿಕೆಯೆ ಮತ್ತು ಕ್ಷಿಪ್ರವಾಗಿ ಏನೋ ಬೇಕಾಗಿದ್ದಾರೆ.

ನಾನು ಕನಿಷ್ಠ ಈ ರೀತಿಯ ಸಾರ್ವತ್ರಿಕ ವಿನಾಯಿತಿಗಳು ಹಿಡಿಯುವ ಮತ್ತು ಮರು ಎಸೆಯುವ ಮೂಲಕ ಕೆಲವು ಮೂಲಭೂತ ಜಾಡಿನ ಮಾಹಿತಿ ಪಡೆಯಿರಿ ಎಂದು ನನಗೆ ಸಂಭವಿಸಿದೆ:

  ಪ್ರಯತ್ನಿಸಿ {
    UpdateEditionDate(ಗುಣಗಳು);
  }
  ಹಿಡಿ (ಎಕ್ಸೆಪ್ಶನ್ ಮತ್ತು)
  {
    ಎಸೆ ಹೊಸ ಎಕ್ಸೆಪ್ಶನ್("Dispatcher, UpdateEditionDate(): ಎಕ್ಸೆಪ್ಶನ್: [" + e.ToString() + "].");
  }

ಇದು ತೋರುತ್ತಿತ್ತು 12 ಜೇನುಗೂಡಿನ thusly:

Xyzzy ದೋಷ ಲೋಡ್ ಮತ್ತು ಓಟದ ಸ್ಪರ್ಧೆ ರಿಸೀವರ್ Conchango.xyzzyEventReceiver, ಆವೃತ್ತಿ = 1.0.0.0, ಸಂಸ್ಕೃತಿ = ತಟಸ್ಥ, PublicKeyToken = blahblahblah. Additional information is below. : ರವಾನೆದಾರ, UpdateEditionDate(): ಎಕ್ಸೆಪ್ಶನ್: [System.NullReferenceException: ಆಬ್ಜೆಕ್ಟ್ ಉಲ್ಲೇಖ ವಸ್ತುವಿನ ಉದಾಹರಣೆಗೆ ಗೆ ಸೆಟ್ ಆಗಿಲ್ಲ. at Conchango.xyzzyManagementEventReceiver.UpdateEditionDate(SPItemEventProperties ಗುಣಗಳು) at Conchango.xyzzyManagementEventReceiver.Dispatcher(SPItemEventProperties ಗುಣಗಳು, ಸ್ಟ್ರಿಂಗ್ eventDescription)].

ಎಂದು ನಾನು ನಿರ್ದಿಷ್ಟ ತೊಂದರೆಯನ್ನು ಗುರುತಿಸುವಲ್ಲಿ ಬೇಕಾದ ಎಲ್ಲಾ ವಿವರ ನೀಡಿದರು ಮತ್ತು ನಾನು ಇದು ಮುಂದೆ ಹೋಗಿ ಬಹಳಷ್ಟು ಬಳಸಲು ನಿರೀಕ್ಷಿಸಬಹುದು.

</ಕೊನೆಯಲ್ಲಿ>

ನನ್ನ ಬ್ಲಾಗ್ ಚಂದಾದಾರರಾಗಿ!

ಪರಿಹಾರ: SPQuery ಫೋಲ್ಡರುಗಳು ಹುಡುಕು ಮಾಡುತ್ತಿಲ್ಲ

This past week I was implementing an "evolving" solution for a client that uses BDC and SPQuery and ran into some difficulty using SPQuery against a document library containing folders. ಬಾಟಮ್ ಲೈನ್: assign "recursive" ಪ್ರಶ್ನೆಗೆ ನೋಟ ಗುಣಲಕ್ಷಣ ಗೆ.

ನನ್ನ ಸನ್ನಿವೇಶದಲ್ಲಿ:

  • ಸೋಮವಾರ, ನಾನು ಡಾಕ್ಯುಮೆಂಟ್ ಅಪ್ಲೋಡ್ ಮತ್ತು ಕೆಲವು ಮೆಟಾ ಅಕ್ಷಾಂಶ ಪೂರೈಕೆ.
  • ಮುಂದಿನ ವಾರ, I upload a new document. Much of this new document’s meta data is based on the document I uploaded on Monday (which we call the "master document").
  • ಬಳಕೆದಾರರು ಸುಲಭವಾಗಿ ಶೀರ್ಷಿಕೆ ಹುಡುಕಾಟ ಮೂಲಕ ಎಂದು ಸೋಮವಾರ ಡಾಕ್ಯುಮೆಂಟ್ ಪತ್ತೆ ಇದರಿಂದ ನಾವು ಪಟ್ಟಿಗೆ ಒಂದು BDC ಸ್ನೇಹಿ ಇಂಟರ್ಫೇಸ್ ಒದಗಿಸುವ ಒಂದು ವೆಬ್ ಸೇವೆ ಮುಂಭಾಗ ರಚಿಸಿದ.
  • A BDC data column provides a friendly user interface. (ಇದು ಹೆಚ್ಚು ಸ್ನೇಹಿ ಲುಕಪ್ ಕಾಲಮ್ BDC ಬಳಸಿಕೊಂಡು ನನ್ನ ಪ್ರಯತ್ನದ ಭಾಗವಾಗಿದೆ).

ಅಂತಿಮ BDC ಮುಂಭಾಗ ಸೇವೆ ವೀಕ್ಷಣ ಮಾಡಲು ಈ ರೀತಿಯ ಪ್ರಶ್ನೆಯನ್ನು ಬಳಸುತ್ತದೆ:

 // ಈ CAML ಪ್ರಶ್ನೆಗೆ ಉತ್ಪಾದಿಸುವ ನೆರವಾಗಲು ಉಪಯೋಗಿಸಿದ U2U ಉಪಕರಣ.
      oQuery.Query =
        "<ಎಲ್ಲಿ>";

      ವೇಳೆ (titleFilter.Length > 0)
        oQuery.Query   =
          "  <ಮತ್ತು>";

      oQuery.Query   =
        "    <ಮತ್ತು>" +
        "      <Geq>" +
        "        <FieldRef Name=\"DocumentId\" />" +
        "        <Value Type=\"Text\">" + MinID + "</ಮೌಲ್ಯ>" +
        "      </Geq>" +
        "      <Leq>" +
        "        <FieldRef Name=\"DocumentId\" />" +
        "        <Value Type=\"Text\">" + maxId + "</ಮೌಲ್ಯ>" +
        "      </Leq>" +
        "    </ಮತ್ತು>";

      ವೇಳೆ (titleFilter.Length > 0)
        oQuery.Query   =
          "    <ಹೊಂದಿದ್ದರೆ>" +
          "      <FieldRef Name=\"Title\" />" +
          "      <Value Type=\"Text\">" + titleFilter + "</ಮೌಲ್ಯ>" +
          "    </ಹೊಂದಿದ್ದರೆ>" +
          "  </ಮತ್ತು>";
      oQuery.Query   =
        "</ಎಲ್ಲಿ>";

ಅಭಿವೃದ್ಧಿಯ ಆರಂಭಿಕ ಹಂತದ ಅವಧಿಯಲ್ಲಿ, this worked great. ಹೇಗಾದರೂ, ನಾವು ಇದ್ದಕ್ಕಿದ್ದಂತೆ ಕೆಲವು ಸಮಸ್ಯೆಗಳನ್ನು ಪರಿಹರಿಸಲು ಮತ್ತು ಕೋಶಕ್ಕೆ ಫೋಲ್ಡರ್ಗಳನ್ನು ಪರಿಚಯಿಸಲಾಯಿತು, my BDC picker wouldn’t return any results. I tracked this down to the fact that the SPQuery would never return any results. We used folders primarily to allow multiple files with the same name to be uploaded but with different meta data. When the file is uploaded, ನಾವು ಪಟ್ಟಿ ಐಟಂನ ID ಆಧರಿಸಿ ಫೋಲ್ಡರ್ ರಚಿಸಲು ಮತ್ತು ನಂತರ ಅಲ್ಲಿ ಫೈಲ್ ಸರಿಸಲು (ನಾನು ಆ ಬಗ್ಗೆ ಬರೆದಿದ್ದಾರೆ ಇಲ್ಲಿ; ನಾವು ಹೊಂದಿತ್ತು ಬಂದಿದೆ ಮಿಶ್ರ ಫಲಿತಾಂಶಗಳನ್ನು ಈ ವಿಧಾನ ಆದರೆ ಒಟ್ಟಾರೆಯಾಗಿ, ಇದು ಚೆನ್ನಾಗಿ ಕೆಲಸ ವಿಶೇಷವೇನು). The user don’t care about folders and in fact, don’t really understand that there are any folders. We have configured all the views on the library to show items without regard to folders.

I hit this problem twice as the technical implementation evolved and solved it differently each time. The first time, I wasn’t using the CONTAINS operator in the query. Without a CONTAINS operator, I was able to solve the problem by specifying the view on the SPQuery’s contructor. Instead of using the default constructor:

SPList oList = web.Lists["Documents"];

SPQuery oQuery = ಹೊಸ SPQuery();

ನಾನು ಬದಲಿಗೆ ವೀಕ್ಷಿಸಿ ಸ್ಪೆಸಿಫೈಡ್ ನಿರ್ಮಾಣಕಾರ ಬಳಸಲಾಗುತ್ತದೆ:

SPList oList = web.Lists["Documents"];

SPQuery oQuery = ಹೊಸ SPQuery(oList.Views["All Documents"]);

ಆ ಸಮಸ್ಯೆಗೆ ಪರಿಹಾರ ಮತ್ತು ನನ್ನ ಫಲಿತಾಂಶಗಳನ್ನು ಪಡೆಯಲು ಪ್ರಾರಂಭಿಸಿದರು.

I then added the CONTAINS operator into the mix and it broke again. It turns out that the CONTAINS operator, ಇಲ್ಲಿಯವರೆಗೆ ನಾನು ಹೇಳಬಲ್ಲೆ ಮಾಹಿತಿ, ಒಂದು ಸರಳ GEQ ಮಾಹಿತಿ ದೃಷ್ಟಿಯಿಂದ ಅದೇ ರೀತಿಯಲ್ಲಿ ಕೆಲಸ ಮಾಡುವುದಿಲ್ಲ / LEQ operators. I did some searching and learned that the query’s ViewAttributes should be set to "Recursive", ನಲ್ಲಿ:

oQuery.ViewAttributes = "Scope=\"Recursive\"";

That solved the problem for CONTAINS. ವಾಸ್ತವವಾಗಿ, ಇದು ನನ್ನ ಮೂಲ ಹುಡುಕು ಸಮಸ್ಯೆಯನ್ನು ಪರಿಹರಿಸಬಹುದು ಮತ್ತು ನಾನು ಪುನರಾವರ್ತಿತ ಗುಣಲಕ್ಷಣ ಮೊದಲ ಬಾರಿಗೆ ನಿರ್ದಿಷ್ಟಪಡಿಸಿದ ಎಂದು, ನಾನು ಮತ್ತೆ ಸಮಸ್ಯೆಯನ್ನು ಎದುರಾದವು ಎಂದು.

ಒಂದು ನೋಟ ಆಧಾರಿತ SPQuery ಕೆಲವು ನಿರ್ವಾಹಕರು ಕೆಲಸ ಎಂದು ವಾಸ್ತವವಾಗಿ (GEQ/LEQ) ಮತ್ತು ಇತರರು (ಹೊಂದಿದ್ದರೆ), KPIs ಫೋಲ್ಡರ್ ಹೊಂದಿರುವ ಡಾಕ್ಯುಮೆಂಟ್ ಗ್ರಂಥಾಲಯಗಳು ಜೊತೆಗೆ ಕೆಲಸ ತೋರುತ್ತಿಲ್ಲ ಎಂಬ ಅಂಶವೂ ಸೇರಿಕೊಂಡು ನನ್ನನ್ನು SPQuery ಕೆಲವು ಆರ್ಥೊಗೊನಾಲಿಟಿಯನ್ನ ಸಮಸ್ಯೆಗಳನ್ನು ಹೊಂದಿದೆ ನಂಬಲು ದಾರಿ.

ವಿಶೇಷ ಧನ್ಯವಾದಗಳು:

  • ಉತ್ತಮ ಜನರಾಗಿದ್ದರು U2U ಮತ್ತು ಅವರ ಪ್ರಶ್ನೆಗೆ ಉಪಕರಣ.
  • ಮೈಕೆಲ್ ಹಾಫರ್ ಶ್ರೇಷ್ಠ "ಮಾಡುವುದರ ಮೂಲಕ ಕಲಿಯುವುದರ" ಬ್ಲಾಗ್ ಪೋಸ್ಟ್, ಕಾಮೆಂಟ್ಗಳನ್ನು ಮತ್ತು ಪ್ರತಿಕ್ರಿಯೆಗಳು.

</ಕೊನೆಯಲ್ಲಿ>

ನನ್ನ ಬ್ಲಾಗ್ ಚಂದಾದಾರರಾಗಿ!

MOSS KPI ದೋಷ? ಪಟ್ಟಿ ಸೂಚಕ ಫೋಲ್ಡರ್ಗಳು ವಿತ್ ಡಾಕ್ಯುಮೆಂಟ್ ಲೈಬ್ರರಿ ಟೈಡ್ ಟು

ನವೀಕರಿಸಲು 02/29/08: I solved this problem by creating a folder and then assigning a content type to the folder which has the meta data I need for the KPIs. ನಾನು ಇಲ್ಲಿ ಸ್ವಲ್ಪ ವಿವರವಾಗಿ ಎಂದು ವಿವರಿಸಲಾಗಿದೆ.

We have implemented a technical solution where users upload documents to a document library. An event receiver creates a directory and moves the file to that directory (ನಾನು ಬರೆದ ರೀತಿಯಲ್ಲೇ ಒಂದು ಕೌಶಲವನ್ನು ಬಳಸಿ ಇಲ್ಲಿ). We’ve successfully navigated around the potential issues caused by event receivers that rename uploaded files (mainly because users never start their document by clicking on "New" ಬದಲಿಗೆ ಸ್ಥಳೀಯವಾಗಿ ಡಾಕ್ಸ್ ರಚಿಸಲು ಮತ್ತು ನಂತರ ಅವುಗಳನ್ನು ಅಪ್ಲೋಡ್).

The meta data for these documents includes a Yes/No site column called "Urgent" and another site column called "Status". We need to meet a business requirement that shows the percentage of "Urgent" documents whose status is "Pending".

ಈ ಮಾಡಲು ಸಾಮಾನ್ಯವಾಗಿ ಸರಳ ಮತ್ತು ನಾನು ಶೇರ್ಪಾಯಿಂಟ್ ಬೀಗಲ್ ನಲ್ಲಿ ತುಂಬಾ ಈ ರೀತಿಯ ವಿವರಿಸಲಾಗಿದೆ ಸ್ಕ್ರೀನ್ ಶಾಟ್ ಲಾಟ್ಸ್ ಆಫ್ ನೀವು ಆಕ್ತಿಹೊಂದಿದ್ದರೆ ಜೊತೆ.

ಸಂಕ್ಷಿಪ್ತ ನಿರೂಪಣೆ, ನಾನು ಕೆಳಗಿನ ಮಾಡಿದರು:

  • Create a view on the doc library called "Pending".
  • ಫೋಲ್ಡರ್ ರಚನೆ ನಿರ್ಲಕ್ಷಿಸಿ ವೀಕ್ಷಿಸಿ ಸಂರಚಿಸಿ.
  • ಒಂದು KPI ಪಟ್ಟಿ ರಚಿಸಿ.
  • Create an indicator in the list that points to the doc lib and that "Pending" ನೋಟ.

This simply does not work. The KPI shows my target (ಉದಾ.. ಐದು ತುರ್ತು ದಾಖಲೆಗಳು) but always shows the actual number of urgent documents as zero. Paradoxically, ನೀವು ವಿವರಗಳು ಕೆಳಗೆ ಕೊರೆತಕ್ಕಾಗಿ ವೇಳೆ, it shows the five urgent documents in the list. I created a very simple scenario with two documents, one in a folder and one not. Here is the screen shot:

ಚಿತ್ರ

The above screen shot clearly shows there are two documents in the view but the "value" is one. The "CamlSchema" with blank document Id is in the root folder and the other is in a folder named "84".

ಇದು ಸಹ ನೀವು ಒಂದು ನೋಟ ನಿರ್ದಿಷ್ಟಪಡಿಸುವ ನನಗೆ ಕಾಣುತ್ತದೆ, the KPI doesn’t honor the "show all items without folders" ನಿಗದಿಪಡಿಸಿ ಬದಲಿಗೆ, ಮೂಲ ಫೋಲ್ಡರ್ಗೆ ಸೀಮೆಯು ಸ್ವತಃ.

ನಾನು ತಪ್ಪು ಮನುಷ್ಯ ವೇಳೆ, ನನಗೆ ಒಂದು ಸಾಲಿನ ಡ್ರಾಪ್ ಅಥವಾ ಪ್ರತಿಕ್ರಿಯಿಸುವಾಗ ಮಾಡಿ.

</ಕೊನೆಯಲ್ಲಿ>

ನನ್ನ ಬ್ಲಾಗ್ ಚಂದಾದಾರರಾಗಿ!

ನನ್ನ ಟ್ಯಾಗ್ಗಳು:

ಸಮಸ್ಯೆಗೆ ಪರಿಹಾರವು: “FileNotFoundException” ನನ್ನ ವೈಶಿಷ್ಟ್ಯ ಪಡೆಯುವ.

I was working on a feature last week that would add some event receivers to a specific list instance. (ನಾನು ಇಲ್ಲಿ ಆ ಪಟ್ಟಿಯಲ್ಲಿ ರಿಸೀವರ್ ಬಗ್ಗೆ ಸ್ವಲ್ಪ ಬ್ಲಾಗ್).

ಆಜ್ಞಾ ಸಾಲಿನ ಬಳಸಿ, ನಾನು ಯಾವುದೇ ದೋಷದೊಂದಿಗೆ ವೈಶಿಷ್ಟ್ಯವನ್ನು ಅನುಸ್ಥಾಪಿಸಲು ಸಾಧ್ಯವಿಲ್ಲ (ಆದರೆ ಗುಪ್ತ ದೋಷ ಕೆಳಗೆ ನೋಡಿ). When I tried to deploy the feature on the site, MOSS complained of a "FileNotFoundException" ದೋಷ. This blog entry describes how I solved it.

ಈ MOSS ವೆಬ್ ಬ್ರೌಸರ್ನಲ್ಲಿ ನನಗೆ ತೋರಿಸಿದರು ದೋಷವೆಂದು:

Feature ‘b2cb42e3-4f0a-4380-aaba-1ef9cd526f20’ could not be installed because the loading of event receiver assembly "xyzzyFeatureReceiver_0" ವಿಫಲನಾದ: System.IO.FileNotFoundException: Could not load file or assembly ‘xyzzyFeatureReceiver_0’ ಅದರ ಅವಲಂಬಿಗಳು ಅಥವಾ ಒಂದು. ವ್ಯವಸ್ಥೆಯ ನಿರ್ದಿಷ್ಟಪಡಿಸಿದ ಫೈಲ್ ಸಿಗುವುದಿಲ್ಲ.
ಫೈಲ್ ಹೆಸರು: ‘xyzzyFeatureReceiver_0’
at System.Reflection.Assembly.nLoad(ಫೈಲ್ಹೆಸರು AssemblyName, ಸ್ಟ್ರಿಂಗ್ ಕೋಡ್ಬೇಸ್, ಎವಿಡೆನ್ಸ್ assemblySecurity, ಅಸೆಂಬ್ಲಿ locationHint, StackCrawlMark& ಮಣ್ಣಿನ ಬಣವೆ, ಬೂಲಿಯನ್ throwOnFileNotFound, ಬೂಲಿಯನ್ forIntrospection)
at System.Reflection.Assembly.InternalLoad(AssemblyRef AssemblyName, ಎವಿಡೆನ್ಸ್ assemblySecurity, StackCrawlMark& ಮಣ್ಣಿನ ಬಣವೆ, ಬೂಲಿಯನ್ forIntrospection)
at System.Reflection.Assembly.InternalLoad(ಸ್ಟ್ರಿಂಗ್ assemblyString, ಎವಿಡೆನ್ಸ್ assemblySecurity, StackCrawlMark& ಮಣ್ಣಿನ ಬಣವೆ, ಬೂಲಿಯನ್ forIntrospection)
at System.Reflection.Assembly.Load(ಸ್ಟ್ರಿಂಗ್ assemblyString)
at Microsoft.SharePoint.Administration.SPFeatureDefinition.get_ReceiverObject()
WRN: ಅಸೆಂಬ್ಲಿ ಬಂಧಿಸುವ ಲಾಗಿಂಗ್ ಆಫ್ ಮಾಡಲಾಗಿದೆ.
ವಿಧಾನಸಭೆ ಬಂಧಿಸಲ್ಪಡುತ್ತವೆ ವೈಫಲ್ಯ ಲಾಗಿಂಗ್ ಶಕ್ತಗೊಳಿಸಲು, ನೋಂದಣಿ ಮೌಲ್ಯವನ್ನು [HKLM ತಂತ್ರಾಂಶ ಮೈಕ್ರೋಸಾಫ್ಟ್ ಫ್ಯೂಷನ್!EnableLog] (DWORD) ಗೆ 1.
ನೋಡು: ವಿಧಾನಸಭೆ ಬಂಧಿಸಲ್ಪಡುತ್ತವೆ ವೈಫಲ್ಯ ಲಾಗಿಂಗ್ ಸಂಬಂಧಿಸಿದ ಕೆಲವು ಸಾಧನೆ ಪೆನಾಲ್ಟಿ ಇಲ್ಲ.
ಈ ವೈಶಿಷ್ಟ್ಯವನ್ನು ಆಫ್ ಮಾಡಲು, ನೋಂದಣಿ ಮೌಲ್ಯದ ತೆಗೆದು [HKLM ತಂತ್ರಾಂಶ ಮೈಕ್ರೋಸಾಫ್ಟ್ ಫ್ಯೂಷನ್!EnableLog].

ವಿಂಡೋಸ್ ಶೇರ್ಪಾಯಿಂಟ್ ಸರ್ವೀಸಸ್ ಸಮಸ್ಯೆಯಿಂದ ನಿವಾರಣೆ.

ನಾನು ಉದ್ದೇಶಪೂರ್ವಕವಾಗಿ ದೋಷ ಉಂಟುಮಾಡುವ ಗೊತ್ತಿಲ್ಲ: don’t install the assembly in the GAC. ಆದರೆ, it was in the GAC. I normally install assemblies into the GAC by dragging them into the c:\windows\assembly folder using windows explorer. I’ve never felt 100% ನಾನು ಯಾವಾಗಲೂ ಎಂದು gacutil ಒಂದು ಕಾರಣಕ್ಕಾಗಿ ಅಸ್ತಿತ್ವದಲ್ಲಿತ್ತು ಅಭಿಪ್ರಾಯವಾಗಿತ್ತು ಆರಾಮದಾಯಕ ಎಂದು ಮಾಡುವ … so I tried that. It made no difference.

ನಾನು Internets ಅನೂಶೋಧಿಸಬಹುದು ಮತ್ತು ಈ ಪೋಸ್ಟ್ ಕಂಡುಬಂದಿಲ್ಲ: http://forums.microsoft.com/MSDN/ShowPost.aspx?PostID=2243677&SiteID=1

ಪೋಸ್ಟರ್ ಕೋಡ್ ಅದೇ ಮೂಲ ಬಿಟ್ ಬಳಸಿಕೊಂಡು ಹರಿಯುತ್ತಿತ್ತು (ಈ ಪಟ್ಟಿಯಿಂದ ಇನ್ಸೈಡ್ WSS ಪುಸ್ತಕ) so that was a hopeful sign. ಹೇಗಾದರೂ, ಒಂದು ಜೊತೆ ಅಲಂಕಾರ ವಿಧಾನಸಭಾ ಸಲಹೆ [ಕೂಟ: ] directive didn’t make sense to me. I tried it anyway and I was right. It made no difference.

Then I noticed that my class definition was not public. I made it public and that made no difference.

ಮುಂದೆ, I went to the trouble of enabling the "assembly bind failure log" (ಒದಗಿಸಿದ ಉಪಯುಕ್ತ ಮತ್ತು ನಿಖರ ಸೂಚನೆಗಳನ್ನು ಅನುಸರಿಸಿ) and this is where things started to get interesting. That log shows me that the runtime is searching everywhere on that server for my assembly. It even appears to be searching for it in my medicine cabinet. ಆದರೆ … ಇದು GAC ಇದನ್ನು ಹುಡುಕಲು ಆಗುವುದಿಲ್ಲ.

I put on my winter jacket and go searching the Internets again and find that someone has had this problem too. The lengthy discussion in that posting peters off into nothing and I can’t find a solution.

I move my assembly into one of the places the log claims it’s searching and I make a little more progress. I’m rewarded with a new error in the browser when I try to activate the feature:

Failed to create feature receiver object from assembly "xyzzyFeatureReceiver_0", type "Conchango.xyzzyFeatureReceiver" ವೈಶಿಷ್ಟ್ಯವಾದ b2cb42e3-4f0a-4380-ಆಬ-1ef9cd526f20: System.ArgumentNullException: ಮೌಲ್ಯ ಶೂನ್ಯ ಸಾಧ್ಯವಿಲ್ಲ.
ನಿಯತಾಂಕ ಹೆಸರು: ಕೌಟುಂಬಿಕತೆ
at System.Activator.CreateInstance(ಕೌಟುಂಬಿಕತೆ ಮಾದರಿ, ಸಾರ್ವಜನಿಕವಲ್ಲದ ಬೂಲಿಯನ್)
at System.Activator.CreateInstance(ಕೌಟುಂಬಿಕತೆ ಮಾದರಿ)
at Microsoft.SharePoint.Administration.SPFeatureDefinition.get_ReceiverObject()

ವಿಂಡೋಸ್ ಶೇರ್ಪಾಯಿಂಟ್ ಸರ್ವೀಸಸ್ ಸಮಸ್ಯೆಯಿಂದ ನಿವಾರಣೆ.

Internets ಒಂದು ಕೊನೆಯ ಟ್ರಿಪ್ ಟೈಮ್ ಫಾರ್!

ನಾನು ಕಂಡುಹಿಡಿಯಲು ಈ ಸಮಯ, ನಿರೀಕ್ಷಿತವಾಗಿ ಸಾಕಷ್ಟು, that MOSS issues this error because the assembly is not in GAC.

ನಾನು ಈ ಆಫ್ ಏನಾದರೂ ಧನಾತ್ಮಕ ಹೊರಬರಲು ಮತ್ತು ನಾನು ರಚಿಸಿದ ಎಂದು ಸ್ವಲ್ಪ ಹೆಮ್ಮೆ ಅಭಿಪ್ರಾಯ ಪ್ರಯತ್ನಿಸಿ ಬಯಸುವ MSIL ಅಸೆಂಬ್ಲಿಗಳ ಪ್ಯುಗಿಟಿವ್, but it’s not working. I’m just plain annoyed. I find myself muttering "chicken or the egg" ನನ್ನ ಉಸಿರು ಅಡಿಯಲ್ಲಿ.

I finally decide to punt. I create an entirely new project and copy/paste the code from the incredible-cloaked-from-the-GAC-assembly non-working project over to this new project. (I look for a build flag called something like "hide from assembly binding if installed in the GAC" ಆದರೆ ಒಂದು ಸಿಗುವುದಿಲ್ಲ).

ನಾನು ವೈಶಿಷ್ಟ್ಯವನ್ನು ಅನುಸ್ಥಾಪಿಸಲು ಮತ್ತು ಅದನ್ನು ಸಕ್ರಿಯಗೊಳಿಸಲು ಮತ್ತು … ಇದು ಕೆಲಸ! ಆದ್ದರಿಂದ, ಎಲ್ಲಾ ನಂತರ, I had to basically ‘reboot’ my project. ನಾನು ಕಂಪ್ಯೂಟರ್ ದ್ವೇಷ ಏಕೆ ಇನ್ನೊಂದು ಕಾರಣ.

I did learn something useful from this. I had been installing features using the stsadm command line all day long and been using the "-force" option out of habit. ಕೆಲವು ಕಾರಣಕ್ಕಾಗಿ, I did not use the -force option when I installed the new project. ಈ ಸಮಯ, ನಾನು ವಾಸ್ತವವಾಗಿ ಮಾಡಿದರು, truly forget to copy this new project’s assembly into the GAC. ಪರಿಣಾಮವಾಗಿ, I received that "FielNotFoundException" ದೋಷ. ಈ ಸಮಯ, ನಾನು stsadm ರಿಂದ ಅರ್ಥವಾಯಿತು, not when I tried to activate the feature via the web browser. ಆದ್ದರಿಂದ, -force actually plays two roles. It allows you to re-install an existing feature. It also allows you to install a buggy feature that cannot work at runtime by suppressing the error. It probably says as much in the help somewhere but I never noticed it.

</ಕೊನೆಯಲ್ಲಿ>

ಚುರುಕಾದ & ಸುಲಭ: ಕ್ರಿಯೆಯನ್ನು ರಿಸೀವರ್ ಮೂಲಕ ಶೇರ್ಪಾಯಿಂಟ್ ಆಬ್ಜೆಕ್ಟ್ ಮಾಡೆಲ್ ಬಳಸಿ ಅಪ್ಲೋಡ್ ಮಾಡಿದ ಫೈಲ್ ಮರುಹೆಸರಿಸಿ

ನವೀಕರಿಸಲು: This works but there are significant limitations which are described in the comments. This may still be useful in some cirumstances.

ನವೀಕರಿಸಲು 2: ನನ್ನ ಪ್ರಸ್ತುತ ಯೋಜನೆಯಲ್ಲಿ, users always upload documents. ಪರಿಣಾಮವಾಗಿ, I don’t run into a problem where MS Word is running and thinks that the file was renamed on it. I did run into a problem, "the file was modified by someone else" and solved this via a simple semaphore type flag. Users need to change a meta data field from its default value to something else. The itemupdated() ರಿಸೀವರ್ ವಾಸ್ತವವಾಗಿ ಮರುಹೆಸರಿಸು ಪ್ರದರ್ಶನ ಮೊದಲು ಮತ್ತು ನಂತರ ಅಲ್ಲಿ ಒಂದು ಮಾನ್ಯವಾದ ಮೌಲ್ಯವನ್ನು ಹುಡುಕುತ್ತದೆ, I have not had any problems. Your mileage may vary.

I have a client requirement to change the name of files uploaded to a specific document library to conform with a particular naming convention. The API does not provide a "rename()" ವಿಧಾನ. ಬದಲಿಗೆ, ನಾವು ಬಳಸಿ "MoveTo(…)". Here is a minimal bit of code to accomplish this:

 ಸಾರ್ವಜನಿಕ ಸ್ವಯಂಚಾಲನೆಯ ಸ್ತಂಭನ ಶೂನ್ಯವಾಗುವ ItemAdded(SPItemEventProperties ಗುಣಗಳು)
        {
            SPFile ಎಫ್ = properties.ListItem.File;

            f.MoveTo(properties.ListItem.ParentList.RootFolder.Url + "/xyzzy.doc");
            f.Update();

        }

The only tricky bit is the "properties.ListItem.ParentList.RootFolder.Url". The MoveTo() method requires a URL. That mashed up string points me to the root folder of my current document library. This allows me to avoid any hard coding in my event receiver.

ಇದೇ ಕೆಲಸ ಮಾಡುವ ಒಂದು ಹೆಚ್ಚು ಉಪಯುಕ್ತ ಆವೃತ್ತಿಯಾಗಿದೆ, but assigns the name of the file to "Title":

 ಸಾರ್ವಜನಿಕ ಸ್ವಯಂಚಾಲನೆಯ ಸ್ತಂಭನ ಶೂನ್ಯವಾಗುವ ItemAdded(SPItemEventProperties ಗುಣಗಳು)
        {
            DisableEventFiring();

            // ಫೈಲ್ ಸ್ವತಃ ಹೆಸರಿನ ಈ ಐಟಂ ಶೀರ್ಷಿಕೆ ನಿಗದಿಪಡಿಸಿ.
 // ಟಿಪ್ಪಣಿ: ನಾವು ಫೈಲ್ ಸ್ವತಃ ಮಾರ್ಪಡಿಸಿ ಮೊದಲು ಈ ಹುದ್ದೆ ನಡೆಯುತ್ತವೆ ಮಾಡಬೇಕು.
 // ಅಪ್ಡೇಟ್ ಕರೆ() SPFile ಮೇಲೆ ಗುಣಲಕ್ಷಣಗಳನ್ನು ಅನೂರ್ಜಿತಗೊಳಿಸುವ ತೋರುತ್ತದೆ
 // ಕೆಲವು ಅರ್ಥದಲ್ಲಿ.  Updates to "Title" ಬದಲಾವಣೆ ತನಕ ವಿಫಲವಾಗಿದೆ (ಮತ್ತು ಅಪ್ಡೇಟ್() ಕರೆ)
 // ಫೈಲ್ ಹೆಸರು ಬದಲಾವಣೆಯು ಮುಂದೆ ಸ್ಥಳಾಂತರಿಸಲಾಯಿತು.
            properties.ListItem["Title"] = Properties.ListItem.File.Name;

            properties.ListItem.Update();

            SPFile ಎಫ್ = properties.ListItem.File;

            // ಕಡತದ ವಿಸ್ತರಣೆಯನ್ನು ಪಡೆಯಿರಿ.  ನಾವು ಆ ಅಗತ್ಯವಿದೆ.
 ದಾರ spfileExt = ಹೊಸ ಫೈಲ್ ಮಾಹಿತಿ(f.Name).ಚಾಚುವುದು;

            // ಪಟ್ಟಿ ಐಟಂನ ID ಗೆ ಫೈಲ್ ಮರುಹೆಸರಿಸು ಮತ್ತು ಇರಿಸಿಕೊಳ್ಳಲು ಕಡತ ವಿಸ್ತರಣೆಯನ್ನು ಬಳಸಲು
 // ಹಾಗೇ ಇದರ ಭಾಗವನ್ನು.
            f.MoveTo(properties.ListItem.ParentList.RootFolder.Url +
                "/" + properties.ListItem["ID"] + spfileExt);

            // ನಡೆಸುವಿಕೆಯನ್ನು ಕಮಿಟ್.
            f.Update();

            EnableEventFiring();
        }

ತ್ವರಿತ ಸಲಹೆ: ವಿಷಯ ಪ್ರಶ್ನೆ ವೆಬ್ ಭಾಗ, ಕಾಲಮ್ ಮೌಲ್ಯ ಮತ್ತು XSL ನೋಡು

I have a column name in a content type named "Real Estate Location".

That column is of type "lookup".

ನಾನು ಮಾರ್ಪಡಿಸಿದ <CommonViewFields> ಮತ್ತು ItemStyle.xsl ಕಾಲಮ್ ತೋರಿಸಲು.

ಸರಳ <XSL:= ಆಯ್ಕೆ ಮೌಲ್ಯ ಆಫ್…> ಮತ್ತೆ ಕ್ರಮಾಂಕ ಸ್ಥಾನ ಡೇಟಾವನ್ನು ಒಳಗೊಂಡಿರುವ ಆಂತರಿಕ ಮೌಲ್ಯವನ್ನು ಹಿಂದಿರುಗಿಸುತ್ತದೆ, ಉದಾಹರಣೆಗೆ:

1;#ಮಿಯಾಮಿ

ಮಾನವ ಸ್ನೇಹಿ ಮೌಲ್ಯವನ್ನು ಪಡೆಯಲು, ಸಬ್-ನಂತರ XSL ಬಳಸಿ, ತೋರಿಸಲಾಗಿದೆ ಎಂದು:

<XSL:value-of select="substring-after(@ Real_x005F_x0020_Estate_x005F_x0020_Location,'#')"></XSL:ಮೌಲ್ಯ ಆಫ್>

ನೀವು XSL ಮಾರ್ಪಾಡುಗಳ ರಲ್ಲಿ ವೀಕ್ಷಣ ಮೌಲ್ಯಗಳು ಕೆಲಸ ಮತ್ತು ಮಾನವ ಸ್ನೇಹಿ ಮೌಲ್ಯವನ್ನು ಪಡೆಯಬೇಕು ಇರುತ್ತವೆ ಬಂದ ಈ ತಂತ್ರವನ್ನು ಬಳಸಿ.

<ಕೊನೆಯಲ್ಲಿ />

ನನ್ನ ಟ್ಯಾಗ್ಗಳು: , ,

ತ್ವರಿತ ಮತ್ತು ಸುಲಭ: ಒಂದು ಸೈಟ್ ಲಂಬಸಾಲಿನ ಆಂತರಿಕ ಅಂಕಣ ಹೆಸರು ನಿರ್ಧರಿಸಲು

ನವೀಕರಿಸಲು: ಜೆರೆಮಿ ಥಾಕೆ has blogged about this and put up some code for a console application that shows internal names.

I was trying to get a content query web part to display a due date from a task and because the screen label is "Due Date", ನಾನು ಕಾಲಮ್ ಹೆಸರಿನಲ್ಲಿ ಬಳಸಲು ಊಹಿಸಲಾಗಿದೆ <CommonViewFields> is "Due_x0020_Date".

ತಪ್ಪಾದ!

The real column name in this case was "DueDate".

How did I find it? I re-read Heather Solomon’s blog entry on modifying CQWP to show additional columns of data. She describes this process at step #13. Trust it. It’s correct. ಕನಿಷ್ಠ, it was correct for me. I did not trust it at first for another column with a much longer name.

I say "Trust it" because I did not trust it and probably wasted near two hours butting my head up against a wall. After I resolved the "DueDate" ಹೆಸರು, I wanted to add another field to <CommonViewFields>. Using the Solomon technique, I was getting a column name like "XYZ_x0020_Project_x0020_Due_x00".

I thought to myself, that’s clearly a truncated name. I went ahead and un-truncated it with no success. I finally used the seemingly truncated name and it worked.

Bonus tip: When I was working with the CQWP, if I added a bad internal name to <CommonViewFields>, the CQWP would tell me that the query had returned no results. ಆದರೆ, if I added a data type to the field name, it would return a result. Adding the data type actually masked a problem since I was referencing a non-existent field. I could add it, but when I tried to display its value, I would always get a blank.

This did not mask the error:

<CommonViewFields>Due_x0020_Date;</CommonViewfields>

This did mask the error:

<CommonViewFields>Due_x0020_Date,DateTime;</CommonViewfields>

</ಕೊನೆಯಲ್ಲಿ>