Парадокс Вставка данных Операция должна использовать обновляемый запрос
Я пытаюсь записать файл базы данных Paradox, используя C# и oledb в Windows 8. Я могу удалить таблицу, создать таблицу и написать первую строку, прежде чем я получу сообщение об ошибке "операция должна использовать обновляемый запрос".
Я попытался разобраться в следующем: 1) Запуск от имени администратора 2) Обновление разрешений в приложении, чтобы убедиться, что у меня нет свойств только для чтения или архивирования в файле 3) Добавление разрешений для чтения запущенному пользователю / запись / изменение каталогов, в которых находятся файлы базы данных 4) Изменение запроса несколько раз в случае, если я делаю что-то странное с запросом
Если бы мне не удалось написать или вставить вообще, то вышеприведенные шаги имели бы смысл, но первоначальная вставка работает, и любые дополнительные вставки не выполняются.
Код ниже показывает текущий способ, которым я пытаюсь выполнить действия, и я оставил в закомментированных разделах, чтобы вы могли увидеть, что еще я пробовал.
public void OverwriteData(string fileName, DataTable dataToWrite)
{
//split up the filename
string path = Path.GetDirectoryName(fileName);
string file = Path.GetFileName(fileName);
//create the string for creating the table
string strTempCreate = "";
//string strTempInsert = "";
foreach (DataColumn column in dataToWrite.Columns)
{
if (strTempCreate != "")
{
strTempCreate = strTempCreate + ", ";
}
strTempCreate = strTempCreate + "[" + column.ColumnName + "]" + " char(30)";
/*if (strTempInsert != "")
{
strTempInsert = strTempInsert + ", ";
}
strTempInsert = strTempInsert + column.ColumnName;*/
}
string createTableStr = "CREATE TABLE " + file + " (" + strTempCreate + ")";
string dropTableStr = "DROP TABLE " + file;
//build the sql insert command
//string insertSql = "insert into " + file + " values ";
/*foreach (DataRow row in dataToWrite.Rows)
{
insertSql = insertSql + row.Field<string>;
}*/
string connectionString = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + path + @";Extended Properties=Paradox 5.x;";
//DataTable results = new DataTable();
using (OleDbConnection conn = new OleDbConnection(connectionString))
{
conn.Open();
OleDbCommand dbCommand = new OleDbCommand();
dbCommand.Connection = conn;
dbCommand.CommandText = dropTableStr;
try
{
dbCommand.ExecuteNonQuery();
}
catch { }
dbCommand.CommandText = createTableStr;
dbCommand.ExecuteNonQuery();
//try to do the insert
StringBuilder sb = new StringBuilder();
//make sure that the database is not readonly
FileAttributes attributes = File.GetAttributes(fileName);
if ((attributes & FileAttributes.Archive) == FileAttributes.Archive)
{
attributes = attributes & ~FileAttributes.Archive;
File.SetAttributes(fileName, attributes);
}
//then we want to try and connect to this database to put data into it
string selectSQL = "Select * from " + file;
using (var adapter = new OleDbDataAdapter(selectSQL, conn))
{
using (var builder = new OleDbCommandBuilder(adapter))
{
var destinationTable = new DataTable();
adapter.Fill(destinationTable);
destinationTable.Merge(dataToWrite,true,MissingSchemaAction.Ignore);
destinationTable.AcceptChanges();
foreach (DataRow row in destinationTable.Rows)
{
row.SetAdded();
}
builder.QuotePrefix = "[";
builder.QuoteSuffix = "]";
builder.GetInsertCommand();
adapter.Update(destinationTable);
}
}
/*foreach (DataRow row in dataToWrite.Rows)
{
sb.Clear();
sb.Append("insert into " + file + " values ('");
IEnumerable<string> fields = row.ItemArray.Select(field => field.ToString());
sb.Append(string.Join("','", fields));
sb.Append("')");
dbCommand.CommandText = sb.ToString();
dbCommand.ExecuteNonQuery();
}*/
/*sb.Clear();
sb.Append("insert into " + file);
foreach (DataRow row in dataToWrite.Rows)
{
sb.Append(" values ('");
IEnumerable<string> fields = row.ItemArray.Select(field => field.ToString());
sb.Append(string.Join("','", fields));
sb.Append("'),");
}
sb.Remove(sb.Length - 1, 1);
sb.Append(";");
dbCommand.CommandText = sb.ToString();
dbCommand.ExecuteNonQuery();
*/
}
}
1 ответ
Эта статья решила мою проблему: https://msdn.microsoft.com/en-us/library/ms715421(v=vs.85).aspx
Согласно Microsoft: таблица не обновляется драйвером Paradox при двух условиях:
- Когда уникальный индекс не определен в таблице. Это не так для пустой таблицы, которую можно обновить одной строкой, даже если в таблице не указан уникальный индекс. Если в пустую таблицу, в которой нет уникального индекса, вставлена одна строка, приложение не может создать уникальный индекс или вставить дополнительные данные после вставки одной строки.
- Если Borland Database Engine не реализован.