Как обновить значение внешнего ключа объекта с помощью LINQ to Entities? - PullRequest
1 голос
/ 05 мая 2009

Предположим, у меня есть эти таблицы:

Fruits
 - FruitID       INT PK
 - FruitName     NVARCHAR(30)
 - FruitStatusID INT FK: Statuses

Statuses
 - StatusID      INT PK
 - StatusName    NVARCHAR(30)

Как мне обновить имя Фрукта и его статус в базе данных в этих ситуациях?

  1. Обновление фрагмента Фрукты, полученного от предыдущего вызова L2E
  2. учитывая целое число, соответствующее FruitID (то есть у меня нет полного объекта Fruit в руке для начала)

VB или C # в порядке, спасибо!

Ответы [ 2 ]

2 голосов
/ 05 мая 2009

Это работает , но это не то, на что я надеялся:

int StatusID = 4; // Some ID
Fruit.FruidIDReference.EntityKey = 
    New EntityKey("MyEntities.Statuses", "StatusID", StatusID)

Конечно, есть более чистый способ сделать это, не требующий жесткого кодирования строк (который вводит исключения во время выполнения, если я сделаю опечатку).

0 голосов
/ 05 мая 2009

Если объект Fruit передается другому методу, вы можете:

  1. Передайте ссылку на объект контекста вместе с Fruit и вызовите SaveChanges ()

  2. Внесите изменения в объект Fruit в методе нижнего уровня и вызовите SaveChanges () в вызывающем методе (вы можете проверить, был ли он изменен, если хотите избежать ненужных вызовов БД.)

Код:

//Change the name
FruitEntities fe = new FruitEntities();
Fruit f = fe.Friuts.First();
f.FruitName = "NewName";
fe.SaveChanges();

//Get a fruit by ID and change the status
//Statuses will need to be included as an Entity in your model with an association to Fruits
int Id = 2;
int newStatusID = 0;
FruitEntities fe = new FruitEntities();
Fruit f = (from x in fe.Fruits
           where x.FruitID == Id
           select x).First();
Status s = (from y in fe.Statuses
            where y.StatusID = newStatusID
            select y).First();
f.Status = s;
fe.SaveChanges();
...