Доступ к базе данных блокируется после любого соединенияC#

Место общения программистов C#
Ответить
Anonymous
 Доступ к базе данных блокируется после любого соединения

Сообщение Anonymous »

У меня странная проблема, и я не являюсь экспертом в Access.
В сети на клиентских ПК есть приложение, которое использует базу данных Access, расположенную на сервере. .
Мы можем использовать приложение на нескольких машинах одновременно.
На сервере у меня есть веб-сервис, разработанный в .NET, у меня есть простой метод, который проверяет, есть ли запись существует или нет. Если она существует, она обновляет запись, если нет, то вставляет ее. Эта служба используется в другом приложении, установленном на всех компьютерах.
Проблема:
-Приложение, которое подключается напрямую к базе данных доступа, работает на любая машина.
-Другое приложение, которое использует службу, установленную на сервере, выполняет вызов вставки. Метод возвращает ответ ok без ошибок.
-Приложение, которое подключается напрямую к базе данных доступа, заблокировано! До закрытия и повторного открытия он не отвечает. Так как я не привык работать с Access, я поискал и, как я понял, сервис блокирует базу данных.
Но, я не нашел, как выполнить команду без блокировки база данных на C#.
Есть идеи?
Вот мой код сервиса.
// Checks if the patient exists :

// My connection string :

string odbcConnection = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" +
System.IO.Path.GetDirectoryName(System.Configuration.ConfigurationManager.AppSettings["DbPath"]) + @"\MyDbName.mdb;";

public TransactionResult PatientExists(string objectID)
{
TransactionResult result = new TransactionResult();
using (var oConn = new OleDbConnection(odbcConnection))
{
try
{
using (var oComm = new OleDbCommand("SELECT COUNT(*) FROM Patient WHERE ObjectID = @OBJECTID", oConn))
{
oConn.Open();
oComm.Parameters.Add(new OleDbParameter("@OBJECTID", objectID));
var count = Convert.ToInt32(oComm.ExecuteScalar());

if (count > 0)
result.Message = "exists";
else
result.Message = "not-exists";
oConn.Close();
}
}
catch (Exception ex)
{
result.Message = "Error in transaction check patient";
result.ExceptionMessage = ex.Message;
if (ex.InnerException != null)
result.InnerExceptionMessage = ex.InnerException.Message;
}
}
return result;
}

//If not Exists :

public TransactionResult InsertPatient(Patient pt)
{
TransactionResult result = new TransactionResult();

using (var oConn = new OleDbConnection(odbcConnection))
{
try
{
using (var oComm = new OleDbCommand(
"INSERT INTO " +
"Patient " +

"(" +
"[ObjectID]," +
...) " +

"VALUES " +

"(" +
"@ObjectID," +
...) ", oConn))
{
if (oComm.Connection.State == System.Data.ConnectionState.Closed)
{
oComm.Connection.Open();
}
oComm.Parameters.Add(new OleDbParameter("@ObjectID", pt.ObjectID));

....

if (Convert.ToBoolean(oComm.ExecuteNonQuery()))
result.Message = "Patient has successfully been inserted into the FreeStep Database.";
else
result.Message = "Unknown error.";
}
}
catch (DbEntityValidationException ex)
{
oConn.Close();
result.ExceptionMessage = ex.Message;
result.InnerExceptionMessage = (ex.InnerException != null) ? ex.InnerException.Message : "No inner exception.";
}
catch (Exception ex)
{
oConn.Close();
result.ExceptionMessage = ex.Message;
result.InnerExceptionMessage = (ex.InnerException != null) ? ex.InnerException.Message : "No inner exception.";
}
oConn.Close();
return result;
}
}


Подробнее здесь: https://stackoverflow.com/questions/790 ... connection
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»