Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
Работа с .mdb через ADO.NET
|
|||
|---|---|---|---|
|
#18+
В MSAccess создаю таблицу Result, поля: Code, No – числовые Var,Val – текстовые ключевое поле отсутствует. Вот код программы, вызывающий исключение, помогите пожалуйста понять, почему выставился флаг HasErrors и как все-таки сохранить результаты: Обработчик кнопки: if( openFileDialog1.ShowDialog() != DialogResult.OK ) return; string conStr = "provider=Microsoft.JET.OLEDB.4.0; " + "data source=" + openFileDialog1.FileName; string selStr = "SELECT * FROM Result"; OleDbConnection con = new OleDbConnection(conStr); OleDbDataAdapter da = new OleDbDataAdapter(); da.SelectCommand = new OleDbCommand(selStr,con); OleDbCommandBuilder cb = new OleDbCommandBuilder(da); con.Open(); DataSet ds = new DataSet(); da.Fill(ds, "Result"); dataGrid1.DataSource = ds.Tables["Result"].DefaultView; // отображает правильно object[] rowVals = new object[4]; rowVals[0] = 5; rowVals[1] = 5; rowVals[2] = "value"; rowVals[3] = "value"; ds.Tables["Result"].Rows.Add(rowVals); // если поставить задержку, то покажет новый ряд DataSet changes = ds.GetChanges(); // в changes правильно заностся новый ряд string s = ""; try { da.Update(changes, "Result"); } catch( OleDbException oleE ) { s = "Message: " + oleE.Message + "\n" + "Sourse: " + oleE.Source + "\n" + "Command: " + cb.GetInsertCommand().CommandText + "\n" + "Errors in changes: " + changes.HasErrors; MessageBox.Show(s); // на главной форме слева на dataGrid1 во введенном ряду стоит ! } finally { con.Close(); } s получает значение: Message: Ошибка синтаксиса в инструкции INSERT INTO. Sourse: Microsoft JET Database Engine Command: INSERT INTO Result( Code , No , Var , Val ) VALUES ( ? , ? , ? , ? ) Errors in changes: True ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 09.11.2004, 23:04 |
|
||
|
Работа с .mdb через ADO.NET
|
|||
|---|---|---|---|
|
#18+
ты используешь в качестве имени поля название функции Var. добавь 2 строки: Код: plaintext 1. 2. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 09.11.2004, 23:28 |
|
||
|
Работа с .mdb через ADO.NET
|
|||
|---|---|---|---|
|
#18+
И еще [Val] ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 10.11.2004, 08:37 |
|
||
|
|

start [/forum/topic.php?fid=17&msg=32774648&tid=1353960]: |
0ms |
get settings: |
10ms |
get forum list: |
16ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
235ms |
get topic data: |
13ms |
get forum data: |
3ms |
get page messages: |
46ms |
get tp. blocked users: |
2ms |
| others: | 267ms |
| total: | 600ms |

| 0 / 0 |
