У меня странная проблема, и я не являюсь экспертом в 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
Доступ к базе данных блокируется после любого соединения ⇐ C#
Место общения программистов C#
-
Anonymous
1727773424
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;
}
}
Подробнее здесь: [url]https://stackoverflow.com/questions/79042087/access-database-locked-after-any-connection[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия