Аватар для ut7du
0 / 0 / 0
Регистрация: 24.06.2016
Сообщений: 161
Записей в блоге: 1

Удаление всех записей в таблице

20.03.2018, 09:27. Показов 5980. Ответов 37
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет друзья !
Есть таблица в БД (локальный файл)
Как удалить все записи ?

Делаю так :
C#
1
2
3
4
5
6
7
private bool DelFromLog()
        {
            bool ok = true;
            command.CommandText = "DELETE * FROM Log";
            command.ExecuteNonQuery();
            return ok;
        }
Но вылетает с ошибкой

Подскажите пожалуйста как правильно удалить записи
Спасибо
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.03.2018, 09:27
Ответы с готовыми решениями:

Удаление записей в таблице
Как правильно удалять записи из таблицы базы Добавление DataTable table = this.dbDataSet.dbtable; DataRow rowt =...

Отображение всех записей в таблице FastReport
Использую для формирования отчета таблицу в 1 строчке у меня название колонок а во 2 у меня записи из БД У меня печатается только первая...

Удаление всех записей в таблице
Необходимо удалить все записи из таблицы. Делаю так procedure TForm1.DelAllClick(Sender: TObject); begin Form1.tbStd.Active :=...

37
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
21.03.2018, 12:10
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от Usaga Посмотреть сообщение
ну так в этом вопросе не должно быть разницы между DELETE и TRUNCATE
Я не сказал про разницу. Просто некоторые считают, что TRUNCATE - чуть ли не мгновенная операция, поэтому я обратил внимание на ньюансы.
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
21.03.2018, 12:39
Цитата Сообщение от Grossmeister Посмотреть сообщение
Просто некоторые считают, что TRUNCATE - чуть ли не мгновенная операция, поэтому я обратил внимание на ньюансы.
Для MS SQL - да. Последствия такие же, как если просто удалить таблицу и создать новую с той же структурой.
0
Эксперт .NET
 Аватар для Usaga
14336 / 9429 / 1358
Регистрация: 21.01.2016
Сообщений: 35,554
21.03.2018, 13:09
Grossmeister, ясно. Просто прозвучало так, что DELETE не аффектят внешние ключи.
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
21.03.2018, 13:48
Цитата Сообщение от Igr_ok Посмотреть сообщение
Последствия такие же
А гранты на таблицу при этом не слетают?
Кроме того, в Oracle можно выполнить TRUNCATE либо с освобождением пространства, либо без оного, если предполагается последующее новое заполнение. А как в MS SQL? Все таки выделение пространства - операция, требующая определенного времени.
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
21.03.2018, 15:02
Цитата Сообщение от Grossmeister Посмотреть сообщение
А гранты на таблицу при этом не слетают?
Не будем так плохо думать об Microsoft
Для теста взял табличку с логами, в ней было 7,1 млн записей. Время выполнения TRUNCATE 0 секунд.
0
Эксперт .NET
 Аватар для Usaga
14336 / 9429 / 1358
Регистрация: 21.01.2016
Сообщений: 35,554
21.03.2018, 16:27
Grossmeister, MSSQL не чистит место при удалении, только перед перезаписью или по требованию.
0
 Аватар для ut7du
0 / 0 / 0
Регистрация: 24.06.2016
Сообщений: 161
Записей в блоге: 1
21.03.2018, 17:23  [ТС]
Привет всем !
Вот код ошибки -
Code
1
System.Data.SqlClient.SqlException: "An attempt to attach an auto-named database for file C: \Users\UZ5DM\OneDrive\Документы\Visual Studio 2017\Project\My_Logger\My_Logger\bin\x64\Release\DB\HAM.mdf failed. A database with the same name exists, or specified file cannot be opened, or it is located on UNC share."
Что сие значит ? Как исправить ?
0
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
21.03.2018, 17:36
ut7du, а давайте Вы включите гугл переводчик - и переведете последнее предложение на тот язык, который понимаете.
Думаю 99% вопросов отпадет сразу же.
2
22 / 21 / 8
Регистрация: 17.02.2011
Сообщений: 399
13.07.2018, 05:39
Почему-то не работает delete, выдаёт ошибку.
Миниатюры
Удаление всех записей в таблице   Удаление всех записей в таблице  
0
Эксперт .NET
 Аватар для Usaga
14336 / 9429 / 1358
Регистрация: 21.01.2016
Сообщений: 35,554
13.07.2018, 05:55
Цитата Сообщение от leonidSDF Посмотреть сообщение
Почему-то не работает
Так вы вчитайтесь в текст ошибки-то. Она ведь на русском.
1
22 / 21 / 8
Регистрация: 17.02.2011
Сообщений: 399
13.07.2018, 06:00
Вчитался, конфликт инструкции delete с ограничением reference, что это было? Люди пишут что where как то решает проблему, но тогда пишет ошибку использования. Where. Похоже проблема в подчиненной таблице в столбце внешнего ключа party. Может надо было чистить сначало чайлд табл
0
Эксперт .NET
 Аватар для Usaga
14336 / 9429 / 1358
Регистрация: 21.01.2016
Сообщений: 35,554
13.07.2018, 06:04
leonidSDF, это значит, что нельзя удалить запись, на которую есть ссылка из записи из другой таблицы (или из этой же).

Сначала удалите запись, которая ссылается на текущую. Или настройте каскадное удаление.
1
22 / 21 / 8
Регистрация: 17.02.2011
Сообщений: 399
13.07.2018, 06:48
Подозревал, а какой механизм тогда такого удаления должен быть?

Добавлено через 10 минут
Сори, понял сейчас попробую

Добавлено через 32 минуты
Получилось, но оказалось, что столбец первичного ключа помнит значение инкремента и новые записи продолжает вставлять с этого числа, есть возможность как - то сбросить его?
И команда truncate table TableParty невозможно выполнить из-за foreign key, я могу как нибудь снять ограничение из под c# и потом восстановить их
0
Эксперт .NET
 Аватар для Usaga
14336 / 9429 / 1358
Регистрация: 21.01.2016
Сообщений: 35,554
13.07.2018, 07:02
leonidSDF, что? Чего сбросить? Я не понял.
0
22 / 21 / 8
Регистрация: 17.02.2011
Сообщений: 399
13.07.2018, 07:12
Ну у меня в обоих таблицах первичные ключи стоят в автоинкременте. Команда delete не сбрасывает счётчик, а truncate не позволяет стирать родительскую таблицу
Миниатюры
Удаление всех записей в таблице   Удаление всех записей в таблице  
0
Эксперт .NET
 Аватар для Usaga
14336 / 9429 / 1358
Регистрация: 21.01.2016
Сообщений: 35,554
13.07.2018, 07:24
leonidSDF, DELETE и не должна сбрасывать счётчик. И нафига его вообще сбрасывать?
1
22 / 21 / 8
Регистрация: 17.02.2011
Сообщений: 399
13.07.2018, 07:40
Ну я подумал что должна быть функция зачистки бд, опять же переполнение возможно, так ведь?
0
Эксперт .NET
 Аватар для Usaga
14336 / 9429 / 1358
Регистрация: 21.01.2016
Сообщений: 35,554
13.07.2018, 07:42
leonidSDF, зачистки?

Цитата Сообщение от leonidSDF Посмотреть сообщение
опять же переполнение возможно, так ведь?
Идентификатора? Вы представляете себе 2 миллиарда записей? Кстати, первичный ключ может быть не только INT, но и BIGINT (64 бита), а так же GUID. Тогда до переполнения вы тупо не доживёте.
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
13.07.2018, 07:42
Помогаю со студенческими работами здесь

TADOTable Удаление всех записей в таблице
Почему не хочет работать такой код: ADOTable_x->DeleteRecords(arAll) т.е. функция DeleteRecords(TAffectRecords AffectRecords) ...

Удаление всех записей из DataGridView и добавление записей
Всем доброго времени суток. Столкнулся со следующей проблемой: написал код на удаление строк DataGridView. Строки удаляет но не все, а...

Удаление записей в таблице
Здравствуйте! Подскажите, какими способами удобнее удалять выделенные записи в таблице (Но не все записи, а, например, 2-4 записи из ...

Удаление и добавление записей в таблице
У меня имеется 3 таблицы: читатели, книги, выданые книги. мне надо чтобы при нажатии кнопки выдать книгу в таблице книги уменшалось кол...

Удаление записей в таблице Delphi
У в MS Access создан запрос на выборку из нескольких таблиц (К одной таблице добавил пару связанных записей из других таблиц). Этот запрос...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
38
Ответ Создать тему
Опции темы

Новые блоги и статьи
[golang] Breadth-First Search
alhaos 19.05.2026
BFS (Breadth-First Search) — это базовый алгоритм обхода графа в ширину, который поуровнево исследует все связанные вершины. Он начинает с выбранной точки и проверяет всех соседей, прежде чем. . .
[golang] Алгоритм «Хак Госпера»
alhaos 17.05.2026
Алгоритм «Хак Госпера» Хак Госпера (Gosper's Hack) — алгоритм нахождения следующего по величине числа с тем же количеством установленных бит. Придуман Биллом Госпером в 1970-х, опубликован в. . .
Рисование бинарного древа до 6-го колена на js, svg.
russiannick 17.05.2026
<svg width="335" height="240" viewBox="0 0 335 240" fill="#e5e1bb"> <style> <!]> </ style> <g id="bush"> </ g> </ svg> function fn(){ let rost;/ / высота древа let xx=165,yy=210,w=256;
FSharp: interface of module
DevAlt 16.05.2026
Интерфейс модуля F# позволяет управлять доступностью членов, содержащихся в реализации модуля. По-умолчанию все члены модуля доступны: module Foo let x = 10 let boo () = printfn "boo" . . .
Хитросплетение родственных связей пантеона греческих богов.
russiannick 14.05.2026
Однооконник, позволяющий узреть и изучить отдельных героев древней Греции. <!DOCTYPE html> <html lang="ru"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible". . .
[golang] Угол между стрелками часов
alhaos 12.05.2026
По заданным значениям часа и минуты необходимо определить значение меньшего угла между стрелками аналогового циферблата часов. import "math" func angleClock(hour int, minutes int) float64 { . . .
Debian 13: Установка Lazarus QT5
ВитГо 09.05.2026
Эта инструкция моя компиляция инструкций volvo https:/ / www. cyberforum. ru/ blogs/ 203668/ 10753. html и его же старой инструкции по установке Lazarus с gtk2. . .
Нейросеть на алгоритме "эстафета хвоста" как перспектива.
Hrethgir 06.05.2026
На десерт, когда запущу сервер. Статья тут https:/ / habr. com/ ru/ articles/ 1030914/ . Автор я сам, нейросеть только помогает в вопросах которые мне не известны - не знаю людей которые знали-бы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru