データベースに10個のレコードが表示されないのはなぜですか?
-
08-07-2019 - |
質問
JMeterを使用してWebアプリケーションをテストします。 私のテストケースは、データベースにレコードを追加することです。 そして、「スレッドユーザーの数」を設定します。 20にすると、20人のユーザーが同時に作業することをシミュレートします。 そして、テストケースを実行します。 しかし、最後に、システムはデータベースに20レコードを作成せず、データベースに13レコードを作成するだけでした。
なぜこれが起こったのか知りたいですか? 私のWebアプリケーションでは、「同期」を追加しなかった可能性があります。レコード追加メソッドの前に?私はlinqを使用しました。2人のユーザーがサーバーにレコードを作成する要求を同時に投稿すると、どうなりますか?レコードを作成するか、2つのレコードを作成できますか、または不明ですか?
以下は、データベースにレコードを作成するためのサンプルコードです。
public int SaveEventGroup(int id, Models.Entities.EventGroup e, Nullable<int> setpublish)
{
try
{
Entities.EventGroup db;
if (id == 0)
{
db = new Entities.EventGroup();
db.CreatedBy = e.CreatedBy;
db.CreateDatetime = DateTime.Now;
db.Status = true;
}
else
{
db = this.GetEventGroup(id);
}
db.NameCN = e.NameCN;
db.NameEN = e.NameEN;
db.NameZH = e.NameZH;
db.NamePT = e.NamePT;
db.DisplayOrder = GetGroupMaxDisplayOrder() + 1;
if (setpublish == null)
{
db.PublishStatus = false;
db.PublishDatetime = null;
db.UpdateDatetime = DateTime.Now;
db.UpdatedBy = e.UpdatedBy;
}
if (id == 0)
dataContext.AddToEventGroupSet(db);
dataContext.SaveChanges();
return db.Id;
}
catch (Exception ex)
{
log.Error(ex.Message, ex);
throw ex;
}
}
解決
データベース自体はACIDに準拠している必要があるため、同期に関してはデータベースに問題があるとは思いません。新しいレコードを挿入し、そのレコードに自動インクリメント整数などのキーが設定されている場合、新しいレコードを挿入するのではなく、そのIDで更新するように指示しない限り、データベースはそれを踏みつけません。しかし、あなたはSQLを書いていないので、データベースに何を指示するかを本当に知っている人がいます。
私は、方程式からlinqを削除し、手動でこれを作成することをお勧めします。テストしているのは、非常に単純な「アップサート」のようです。操作。
所属していません StackOverflow