Исходный код вики Поиск в таблице по списку ключей
Версия 14.4 от Alexandr Fokin на 2020/03/28 16:33
Скрыть последних авторов
| author | version | line-number | content |
|---|---|---|---|
| |
2.1 | 1 | |
| 2 | **Задача:** | ||
| |
3.1 | 3 | Имеется таблица с записями Таблица1 (При этом размеры таблицы не малы) |
| 4 | Имеется список ключей List1 (Кол-во элементов в списке превышает 500) | ||
| |
2.1 | 5 | |
| 6 | Необходимо отобрать из Таблица1 значения, у которых поле key попадает в список List1. | ||
| 7 | |||
| 8 | **Варианты реализации:** | ||
| 9 | 1) Использование оператора IN, в параметрах у которого перечислены все значения из List1. | ||
| 10 | 2) Созданием временной таблицы в рамках запроса, наполнение таблицы значениями из List1, выполнить join между временной таблицой и Таблица1 | ||
| |
4.1 | 11 | (!При этом одна операция INSERT может вставить не более 1000 строк и если элементов больше, то потребуется несколько операций) |
| |
8.1 | 12 | Реализация происходит в рамках sql запросов ado.net, без хранимых процедур. Время, затрачиваемое на построение текста запроса, не учитывается. |
| |
9.1 | 13 | 3) Использование xml переменной, данные из которой используются для операции join с Таблица1. |
| |
2.1 | 14 | |
| |
3.1 | 15 | {{html}} |
| 16 | <table style="height: 179px; width: 620px;"> | ||
| 17 | <tbody> | ||
| |
9.1 | 18 | <tr> |
| 19 | <td>Кол-во записей с в Таблица1</td> | ||
| 20 | <td>Кол-во элементов в List1</td> | ||
| |
10.1 | 21 | <td>Кол-во запусков</td> |
| |
9.1 | 22 | <td>№</td> |
| |
12.1 | 23 | <td>Среднее время выполнения (мс)</td> |
| |
9.1 | 24 | </tr> |
| 25 | <tr> | ||
| 26 | <td>20000</td> | ||
| 27 | <td>1000</td> | ||
| |
11.1 | 28 | <td>50</td> |
| |
9.1 | 29 | <td>1</td> |
| |
11.1 | 30 | <td>97</td> |
| 31 | </tr> | ||
| 32 | <tr> | ||
| 33 | <td> </td> | ||
| 34 | <td> </td> | ||
| 35 | <td> </td> | ||
| 36 | <td>2</td> | ||
| 37 | <td>70</td> | ||
| 38 | </tr> | ||
| 39 | <tr> | ||
| 40 | <td> </td> | ||
| 41 | <td> </td> | ||
| 42 | <td> </td> | ||
| 43 | <td>3</td> | ||
| 44 | <td>34</td> | ||
| 45 | </tr> | ||
| 46 | |||
| 47 | <tr> | ||
| |
13.1 | 48 | <td> </td> |
| |
11.1 | 49 | <td>2000</td> |
| |
14.1 | 50 | <td>50</td> |
| |
11.1 | 51 | <td>1</td> |
| |
14.1 | 52 | <td>202</td> |
| |
9.1 | 53 | </tr> |
| 54 | <tr> | ||
| 55 | <td> </td> | ||
| 56 | <td> </td> | ||
| |
10.1 | 57 | <td> </td> |
| |
9.1 | 58 | <td>2</td> |
| |
11.1 | 59 | <td>126</td> |
| |
9.1 | 60 | </tr> |
| 61 | <tr> | ||
| 62 | <td> </td> | ||
| 63 | <td> </td> | ||
| |
10.1 | 64 | <td> </td> |
| |
9.1 | 65 | <td>3</td> |
| |
11.1 | 66 | <td>60</td> |
| 67 | </tr> | ||
| |
3.1 | 68 | </tbody> |
| 69 | </table> | ||
| 70 | {{/html}} | ||
| |
5.1 | 71 | |
| 72 | Ссылки: | ||
| 73 | https://metanit.com/sql/sqlserver/10.4.php | ||
| 74 | https://metanit.com/sql/sqlserver/10.3.php | ||
| 75 | https://info-comp.ru/programmirovanie/567-table-variables-in-ms-sql-server.html | ||
| |
6.1 | 76 | https://www.cyberforum.ru/ado-net/thread1948686.html |