Версия 15.1 от Alexandr Fokin на 2020/03/28 17:18

Последние авторы
1
2 **Задача:**
3 Имеется таблица с записями Таблица1 (При этом размеры таблицы не малы)
4 Имеется список ключей List1 (Кол-во элементов в списке превышает 500)
5
6 Необходимо отобрать из Таблица1 значения, у которых поле key попадает в список List1.
7
8 **Варианты реализации:**
9 1) Использование оператора IN, в параметрах у которого перечислены все значения из List1.
10 2) Созданием временной таблицы в рамках запроса, наполнение таблицы значениями из List1, выполнить join между временной таблицой и Таблица1
11 (!При этом одна операция INSERT может вставить не более 1000 строк и если элементов больше, то потребуется несколько операций)
12 Реализация происходит в рамках sql запросов ado.net, без хранимых процедур. Время, затрачиваемое на построение текста запроса, не учитывается.
13 3) Использование xml переменной, данные из которой используются для операции join с Таблица1.
14
15 {{html}}
16 <table style="height: 179px; width: 620px;">
17 <tbody>
18 <tr>
19 <td>Кол-во записей с в Таблица1</td>
20 <td>Кол-во элементов в List1</td>
21 <td>Кол-во запусков</td>
22 <td>№</td>
23 <td>Среднее время выполнения (мс)</td>
24 </tr>
25 <tr>
26 <td>20000</td>
27 <td>1000</td>
28 <td>50</td>
29 <td>1</td>
30 <td>97</td>
31 </tr>
32 <tr>
33 <td>&nbsp;</td>
34 <td>&nbsp;</td>
35 <td>&nbsp;</td>
36 <td>2</td>
37 <td>70</td>
38 </tr>
39 <tr>
40 <td>&nbsp;</td>
41 <td>&nbsp;</td>
42 <td>&nbsp;</td>
43 <td>3</td>
44 <td>34</td>
45 </tr>
46
47 <tr>
48 <td>&nbsp;</td>
49 <td>2000</td>
50 <td>50</td>
51 <td>1</td>
52 <td>202</td>
53 </tr>
54 <tr>
55 <td>&nbsp;</td>
56 <td>&nbsp;</td>
57 <td>&nbsp;</td>
58 <td>2</td>
59 <td>126</td>
60 </tr>
61 <tr>
62 <td>&nbsp;</td>
63 <td>&nbsp;</td>
64 <td>&nbsp;</td>
65 <td>3</td>
66 <td>60</td>
67 </tr>
68
69 <tr>
70 <td>&nbsp;</td>
71 <td>4000</td>
72 <td>50</td>
73 <td>1</td>
74 <td>423</td>
75 </tr>
76 <tr>
77 <td>&nbsp;</td>
78 <td>&nbsp;</td>
79 <td>&nbsp;</td>
80 <td>2</td>
81 <td>247</td>
82 </tr>
83 <tr>
84 <td>&nbsp;</td>
85 <td>&nbsp;</td>
86 <td>&nbsp;</td>
87 <td>3</td>
88 <td>82</td>
89 </tr>
90 </tbody>
91 </table>
92 {{/html}}
93
94 Ссылки:
95 https://metanit.com/sql/sqlserver/10.4.php
96 https://metanit.com/sql/sqlserver/10.3.php
97 https://info-comp.ru/programmirovanie/567-table-variables-in-ms-sql-server.html
98 https://www.cyberforum.ru/ado-net/thread1948686.html