2010-03-23 3 views
0

사용자가있는 데이터베이스가 있습니다. 사용자가 항목이 있습니다.IList <Item> 컬렉션 클래스 데이터베이스 액세스

이 항목은 적극적으로 변경할 수 있습니다. 컬렉션 형식 형식의 항목에 어떻게 액세스합니까? 사용자의 경우 인스턴스화시 모든 사용자 속성을 채 웁니다. 인스턴스화시 사용자 항목을로드하고 항목이 변경되면 이전 데이터가 있습니다.

저는 ItemCollection 클래스가 필요하고 foreach 루프를 사용할 수있는 모든 사용자 항목을 트래버스하는 방법으로 사용자 클래스의 필드/속성을 분리해야한다고 생각했습니다.

그래서, 내 질문은 어떤 종류의 컬렉션을 사용하여 데이터베이스에서 항목에 액세스하는 가장 좋은 방법/최선의 방법은 무엇입니까? 특정 Item에 액세스 할 때 최신 데이터베이스 정보를 가져와야하고 사용자가 foreach 루프를 수행 할 때 최신 항목 정보를 사용할 수 있어야합니다.

e.e. 내가

Console.WriteLine(User.Items[3].ID); returns 5. 
//this updates the item information and saves it to the database. 
User.Items[3].ID = 13; 

//Add a new item to the database. 
User.Items.Add(new Item { id = 17}); 

foreach (Item item in User.Items) { 
    //this would traverse all items in the database. 
    //not some cached copy at the time of instantiation of the user. 
} 

편집을 할 노력하고있어 무엇 : 미안 해요, 난이 질문에 약간 잘못 작성했습니다. 현재 Linq를 사용하고 있지만 비즈니스 개체에 클래스 매핑이 있습니다. 비즈니스 개체를 트래버스 할 때 Linq datacontext로 이동하여 정보를 얻고 싶습니다.

인터페이스 IList를 구현하는 새 클래스 "ItemCollection"을 구현할 때 항목을 반환하려면 어떻게해야합니까?

User.Items [3]에서는 public Item this [int index] 메서드로 구현됩니다. 인덱스 메서드가 linq.Skip 연산자를 사용하여 데이터베이스에서 항목의 인덱스를 가져와야합니까?

비즈니스 개체 컬렉션을 데이터베이스에 매핑하는 것에 대해 약간 혼란 스러울뿐입니다.

+0

Entity Framework를 사용하고 있습니까? – kervin

+0

아니요,하지만 Linq to SQL – Mike

답변

1

이렇게 할 수는 있지만 일부 비정상적인 요구 사항이 필요합니다.

우선, 이는 데이터베이스와 애플리케이션간에 과도한 트래픽을 발생시킵니다. 둘째, 동시 환경에서, 이것은 많은 양의 경쟁 조건을 초래할 것입니다. 그냥 빨리 예를 들어

, 코드 세그먼트 :

User.Items[3].ID = 13; 
User.Items[3].Color = Color.Blue; 

가 허용되지 않는 상태를 생산할 수있는, 그러나 그것 때문에 상태를 유지하는 열의 적어도 잠시 동안 데이터베이스에 존재합니다. 또한 위의 코드 세그먼트는 간단한 업데이트를 만들기 위해 데이터베이스에 두 번 액세스합니다. 그리고이 변화가 원자적일 것이라고 보장하는 것이 훨씬 더 어렵습니다.

+0

+1 - 정확하게, 일반적으로 당신은 그들을 반복하기 전에 사용자와 그들의 항목을 다시로드합니다. –

0

LINQ to SQL 또는 Entity Framework를 확인 했습니까?

그들은 모두 당신이 필요로 유사한 기능을 제공합니다

// Get first user with Id of 5 
var users = _dbContext.Users.FirstOrDefault(u => u.Id == 5); 

// Loop through all users in the context 
foreach(var user in _dbContext.Users) 
{ 
    foreach(var item in user.Items) 
    { 
     // Work with your item here. 
    } 
} 

당신은 당신이 최신 정보를 가질 수 있도록 당신이 당신의 상황을 관리해야한다.

0

데이터베이스 클래스에 IList를 구현하고 속성이 변경 될 때마다 데이터베이스에 쓸 필요가 있습니다.

일부 상황에서는 IList에서 데이터에 액세스 할 수 있지만 누군가가 속성을 변경할 때마다 자동으로 데이터베이스에 쓰면 누군가 인스턴스에서 20 개의 속성을 변경하면 불쾌한 상황이 발생합니다.

컬렉션과 같은 방식으로 데이터에 액세스하는 가장 좋은 방법은 LiNQ를 살펴 보는 것입니다.

0

Object-Relational Mapping 공구가 필요합니다.

저는 ADO.Net Entity Framework을 사용하고 있습니다.

대부분의 ORM에는 캐싱 계층이 있습니다.그리고 그것은 여러분이 작성하기 시작한 것입니다.

큰 이점은 현재 설계중인 캐싱 계층이 사용자를 위해 구축되었으며 사용자 (또는 내) 구현보다 성능이 우수하다는 것입니다. 엔티티 프레임 워크, 활동하기 시작하는 주요 구성 요소에 대해 구체적으로

"Saving Changes and Managing Concurrency"에서 Entity Framework Component Stack http://upload.wikimedia.org/wikipedia/en/b/b7/ANEF.PNG

...

개체 서비스 변경 사항을 추적하는 "Object Services"구성 요소에게 있습니다 그 은 (는) 캐시의 개체로 만들어졌습니다. SaveChanges 메서드가 이면 Object Services는 데이터 원본의 변경 내용을 병합하려고합니다. 객체 후에 데이터 소스를 변경된 객체와 캐시 충돌 데이터 변경 추가되거나 캐시 리프레쉬 있었을 때 SaveChanges를 OptimisticConcurrencyException는 실패 할 수있다.

이렇게 이것은 주로 무대 뒤에서 처리됩니다. 또한 엔티티 세트가 커짐에 따라 객체 캐싱 레이어를 수정하지 않아도됩니다.