|
0 / 0 / 0
Регистрация: 16.03.2018
Сообщений: 51
|
||||||
Сортировка при нажатии на DBgrid14.04.2019, 15:37. Показов 2308. Ответов 21
Метки нет (Все метки)
При клике на заголовок выполняется сортировка вроде бы нашел как это сделать но в составных таблицах это не работает. И выдается ошибка.
0
|
||||||
| 14.04.2019, 15:37 | |
|
Ответы с готовыми решениями:
21
Отсортировать DBGrid при нажатии RadioButton
При нажатии на поле в DBGrid показана картинка |
|
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
|
|
| 14.04.2019, 16:44 | |
|
Неоднозначность имен полей в двух таблицах мешает серверу СУБД понять по полю какой таблицы сортировать.
В тексте запроса поля с именем NAME указаны с алиасами таблиц: pp.name, p.name, а в предложении ORDER BY, подставляется переменная, которой, скорее всего, присвоено имя 'NAME' без указания таблицы. Отсюда ошибка. Решение может быть в двух вариантах: - добавить имя (алиас) таблицы к имени поля в переменной s; - указать в предложении ORDER BY номер поля (номер поля в списке полей в запросе), а не его имя.
0
|
|
|
0 / 0 / 0
Регистрация: 16.03.2018
Сообщений: 51
|
|
| 14.04.2019, 19:29 [ТС] | |
|
Что-то немного не понимаю, а как указать номер поля?
0
|
|
| 14.04.2019, 19:39 | ||||||||||||
ЗЫ зачем вы в DataModule2.QPoc.SQL.Text 2 раза пишите запрос? почему бы не сделать так:
0
|
||||||||||||
|
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
|
||
| 14.04.2019, 19:43 | ||
|
select p.id<1-е поле>, pp.name<2-е>, p.data<3-е>, p.name<4-е>
0
|
||
|
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
|
|
| 14.04.2019, 20:57 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 16.03.2018
Сообщений: 51
|
|
| 14.04.2019, 22:01 [ТС] | |
|
Ну я переделал но, теперь таблица копирует все значения. И если s:='p.'+s, то фильтрует только по тем столбцам которые начинаются на p. , но тут понятно почему. А как добавить 2 таблицу?
0
|
|
|
0 / 0 / 0
Регистрация: 16.03.2018
Сообщений: 51
|
||||||
| 14.04.2019, 22:39 [ТС] | ||||||
0
|
||||||
|
231 / 163 / 54
Регистрация: 26.10.2014
Сообщений: 928
|
|
| 14.04.2019, 22:41 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 16.03.2018
Сообщений: 51
|
|
| 14.04.2019, 22:43 [ТС] | |
|
Да вот тоже что-то смотрю,но до 22 ID идет сортировка нормально
0
|
|
|
231 / 163 / 54
Регистрация: 26.10.2014
Сообщений: 928
|
||||||
| 14.04.2019, 22:55 | ||||||
|
как то больно сложно у вас выполняется сортировка
0
|
||||||
|
0 / 0 / 0
Регистрация: 16.03.2018
Сообщений: 51
|
||||||
| 14.04.2019, 22:59 [ТС] | ||||||
0
|
||||||
|
0 / 0 / 0
Регистрация: 16.03.2018
Сообщений: 51
|
|
| 14.04.2019, 23:15 [ТС] | |
|
0
|
|
|
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
|
|||||||
| 14.04.2019, 23:21 | |||||||
|
Могу предложить "дурацкий", но 100% работающий прием. Для объединенных таблиц с небольшим колич. полей годится.
1. дать второму полю с тем же самым именем псевдоним (алиас): select p.id, pp.name, p.data, p.name namep from poctuplenia p, postavshik pp 2. если в гриде есть список колонок, поменять в гриде имя поля (свойство FieldName) с name на его алиас (namep). А в процедуре проверять какая колонка нажата (с наличием алиаса - определяется просто) и присваивать номера полей переменной:
Добавлено через 6 минут Грид используемый ТС не из библиотеки компонентов EhLib.
0
|
|||||||
|
0 / 0 / 0
Регистрация: 16.03.2018
Сообщений: 51
|
|
| 14.04.2019, 23:40 [ТС] | |
|
0
|
|
|
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
|
||
| 14.04.2019, 23:42 | ||
|
Если бы был проект с базой, то можно было попытаться найти "собаку".
0
|
||
|
0 / 0 / 0
Регистрация: 16.03.2018
Сообщений: 51
|
||||||
| 14.04.2019, 23:44 [ТС] | ||||||
|
Это вообще возможно реализовать?
Для простых таблиц использовал вот это работает нормально. Но опять же не знаю как реализовать для составных таблиц
0
|
||||||
| 14.04.2019, 23:44 | |
|
Помогаю со студенческими работами здесь
20
При нажатии кнопки отсортировать поля из DBGrid в ListBox При нажатии кнопки добавить новую строку в DbGrid
DBGrid: При нажатии на сотрудника, вывести его посещаемость за год Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|