Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


Problem med ObjectDataSource/DetailsView

Postades av 2006-04-12 12:58:05 - Jakob Nilsson, i forum asp.net generellt, Tråden har 0 Kommentarer och lästs av 416 personer

Hej!

Jag har ett litet problem vid insättning av data tillsammans med ObjectDataSource och parameterlistor.

I projektet har jag datatyperna Photo och Album som också har två egna klasser som används vid insert/update osv med ObjectDataSource (DataObjectTypeName). Varje Photo har ett AlbumId som specificerar vilket album det tillhör.

På sidan har jag två ObjectDataSource, en för foton och en för album. Dessa är kopplade till metoder för att hämta/lägga till/ta bort och uppdater datan. Dessa har jag verifierat och dessa verkar fungera korrekt.

På min testsida har jag två GridViews, en som listar alla album och en som listar alla foton för det valda fotoalbumet. Detta gör jag genom att i ObjectDataSource_Photos ha en ControlParameter som hämtar AlbumId från det valde värdet i GridView_Albums:

<asp:ObjectDataSource ID="ObjectDataSource_Photos" runat="server" DataObjectTypeName="Photo"
    DeleteMethod="DeletePhoto" InsertMethod="CreatePhoto" SelectMethod="GetPhotos"
    TypeName="AccessPhotoAlbumProvider" UpdateMethod="UpdatePhoto" OnInserting="ObjectDataSource_Photos_Inserting">
    <SelectParameters>
        <asp:ControlParameter ControlID="GridView_Albums" Name="albumId" />
    </SelectParameters>
    <InsertParameters>
        <asp:ControlParameter ControlID="GridView_Albums" Name="albumId" />
        <asp:Parameter DefaultValue="DEFAULT_PATH" Name="relativeDirectoryPath" />
        <asp:Parameter DefaultValue="DEFAULT_FILENAME" Name="filename" />
    </InsertParameters>
</asp:ObjectDataSource>


Detta funkar kanon.

Jag har också en DetailsView som jag använder för att lägga till ett nytt foto. Tanken är att även denna ska använda en ControlParameter, men i InsertParameter-listan för att hämta aktuellt AlbumId som ska läggas till i det nya fotot. Men detta fungerar inte! Så här ser DetailsView_Photo ut:

<asp:DetailsView ID="DetailsView_Photo" runat="server" AutoGenerateRows="false" DataSourceID="ObjectDataSource_Photos" DefaultMode="Insert">
    <Fields>
        <asp:BoundField DataField="Title" HeaderText="Path"/>
        <asp:BoundField DataField="Filename" HeaderText="FileName" />
        <asp:CommandField ShowInsertButton="True" />
    </Fields>
</asp:DetailsView>


När jag ska lägga till ett foto med denna får jag detta felet från OleDb:

"The field 'PhotosTable.AlbumId' cannot contain a Null value because the Required property for this field is set to True. Enter a value in this field."

Detta betyder att det inte skickas med något AlbumId trots att jag har den som ControlParameter och en likadan parameter fungerar för Select-metoden?! Lägger jag till DefaultValue på min ControlParameter så fungerar det inte heller. Men om jag samtidigt lägger till raden:

<asp:BoundField DataField="AlbumId" HeaderText="AlbumId"/>


till DetailsViewns Field-lista så kommer i alla fall DefaultValue från ControlParameter fram till Insert-metoden?!? ObjectDataSource ska väl skicka med InsertParametrarna trots att det inte kommer in någon data för just det fältet?

Jag kan lösa problemet genom att snappa upp Inserting-eventet:

protected void ObjectDataSource_Photos_Inserting(object sender, ObjectDataSourceMethodEventArgs e)
{
    Photo photo = (Photo)e.InputParameters["photo"];
    photo.AlbumId = (int)GridView_Albums.SelectedDataKey.Value;
} 


och det fungerar. Men varför fungerar inte den deklarativa lösningen?? Den verkar bara fungera om det finns ett AlbumId-field i DetailsViewn och då kan bara DefaultValue i parametern funka. Inte att den hämtar värdet korrekt från GridView_Albums, vilket den borde?


Tacksam för svar :)


//Jakob


Svara

Nyligen

  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo
  • 14:25 Tips på verktyg för att skapa QR-k
  • 14:23 Tips på verktyg för att skapa QR-k
  • 20:52 Fungerer innskuddsbonuser egentlig

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 602
27 953
271 705
5 910
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies