Deployed 901748f to 5.4 with MkDocs 1.1.2 and mike 0.5.5
[GitHub/WoltLab/woltlab.github.io.git] / latest / package / database-php-api / index.html
CommitLineData
0c5338dd
TD
1
2<!doctype html>
3<html lang="en" class="no-js">
4 <head>
5
6 <meta charset="utf-8">
7 <meta name="viewport" content="width=device-width,initial-scale=1">
8
9
10
11
fb962f09
WG
12 <link rel="icon" href="../../assets/default.favicon.ico">
13 <meta name="generator" content="mkdocs-1.1.2, mkdocs-material-7.1.0">
0c5338dd
TD
14
15
16
17 <title>Database PHP API - WoltLab Suite Documentation</title>
18
19
20
fb962f09 21 <link rel="stylesheet" href="../../assets/stylesheets/main.33e2939f.min.css">
0c5338dd
TD
22
23
fb962f09 24 <link rel="stylesheet" href="../../assets/stylesheets/palette.ef6f36e2.min.css">
0c5338dd
TD
25
26
27
28 <meta name="theme-color" content="#009485">
29
30
31
32
33
fd8430cb
WG
34
35
0c5338dd
TD
36
37
38 <link rel="stylesheet" href="../../stylesheets/extra.css">
39
40
41
42
43
44 </head>
45
46
47
48
49
50
51
52 <body dir="ltr" data-md-color-scheme="" data-md-color-primary="teal" data-md-color-accent="">
0c5338dd
TD
53
54
fb962f09
WG
55 <script>function __prefix(e){return new URL("../..",location).pathname+"."+e}function __get(e,t=localStorage){return JSON.parse(t.getItem(__prefix(e)))}</script>
56
0c5338dd
TD
57 <input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
58 <input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
59 <label class="md-overlay" for="__drawer"></label>
60 <div data-md-component="skip">
61
62
63 <a href="#database-php-api" class="md-skip">
64 Skip to content
65 </a>
66
67 </div>
68 <div data-md-component="announce">
69
70 <aside class="md-announce">
71 <div class="md-announce__inner md-grid md-typeset">
72
73 <a href="https://www.woltlab.com">Back to <strong>woltlab.com</strong></a>
74
75 </div>
76 </aside>
77
78 </div>
79
fb962f09 80 <header class="md-header" data-md-component="header">
0c5338dd 81 <nav class="md-header__inner md-grid" aria-label="Header">
fb962f09 82 <a href="../.." title="WoltLab Suite Documentation" class="md-header__button md-logo" aria-label="WoltLab Suite Documentation" data-md-component="logo">
0c5338dd
TD
83
84 <img src="../../assets/logo.png" alt="logo">
85
86 </a>
87 <label class="md-header__button md-icon" for="__drawer">
88 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2z"/></svg>
89 </label>
90 <div class="md-header__title" data-md-component="header-title">
91 <div class="md-header__ellipsis">
92 <div class="md-header__topic">
93 <span class="md-ellipsis">
94 WoltLab Suite Documentation
95 </span>
96 </div>
97 <div class="md-header__topic" data-md-component="header-topic">
98 <span class="md-ellipsis">
99
100 Database PHP API
101
102 </span>
103 </div>
104 </div>
0c5338dd
TD
105 </div>
106
fb962f09
WG
107
108
a3639e76
WG
109 <label class="md-header__button md-icon" for="__search">
110 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5z"/></svg>
111 </label>
112
113<div class="md-search" data-md-component="search" role="dialog">
114 <label class="md-search__overlay" for="__search"></label>
115 <div class="md-search__inner" role="search">
116 <form class="md-search__form" name="search">
117 <input type="text" class="md-search__input" name="query" aria-label="Search" placeholder="Search" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="search-query" data-md-state="active" required>
118 <label class="md-search__icon md-icon" for="__search">
119 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5z"/></svg>
120 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg>
121 </label>
122 <button type="reset" class="md-search__icon md-icon" aria-label="Clear" tabindex="-1">
fb962f09 123 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"/></svg>
a3639e76
WG
124 </button>
125 </form>
126 <div class="md-search__output">
127 <div class="md-search__scrollwrap" data-md-scrollfix>
128 <div class="md-search-result" data-md-component="search-result">
129 <div class="md-search-result__meta">
130 Initializing search
131 </div>
132 <ol class="md-search-result__list"></ol>
133 </div>
134 </div>
135 </div>
136 </div>
137</div>
138
0c5338dd 139
7124f4cb
WG
140 <div class="md-header__source">
141
142<a href="https://github.com/WoltLab/docs.woltlab.com/" title="Go to repository" class="md-source" data-md-component="source">
143 <div class="md-source__icon md-icon">
144
fb962f09 145 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05 244 40.45a28.87 28.87 0 0 0-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 0 1-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 0 0 0 40.81l195.61 195.6a28.86 28.86 0 0 0 40.8 0l194.69-194.69a28.86 28.86 0 0 0 0-40.81z"/></svg>
7124f4cb
WG
146 </div>
147 <div class="md-source__repository">
148 GitHub
149 </div>
150</a>
151 </div>
152
0c5338dd
TD
153 </nav>
154</header>
155
156 <div class="md-container" data-md-component="container">
157
158
159
160
161 <main class="md-main" data-md-component="main">
162 <div class="md-main__inner md-grid">
163
164
165
166 <div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" >
167 <div class="md-sidebar__scrollwrap">
168 <div class="md-sidebar__inner">
169
170
171
0c5338dd
TD
172<nav class="md-nav md-nav--primary" aria-label="Navigation" data-md-level="0">
173 <label class="md-nav__title" for="__drawer">
fb962f09 174 <a href="../.." title="WoltLab Suite Documentation" class="md-nav__button md-logo" aria-label="WoltLab Suite Documentation" data-md-component="logo">
0c5338dd
TD
175
176 <img src="../../assets/logo.png" alt="logo">
177
178 </a>
179 WoltLab Suite Documentation
180 </label>
181
7124f4cb
WG
182 <div class="md-nav__source">
183
184<a href="https://github.com/WoltLab/docs.woltlab.com/" title="Go to repository" class="md-source" data-md-component="source">
185 <div class="md-source__icon md-icon">
186
fb962f09 187 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05 244 40.45a28.87 28.87 0 0 0-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 0 1-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 0 0 0 40.81l195.61 195.6a28.86 28.86 0 0 0 40.8 0l194.69-194.69a28.86 28.86 0 0 0 0-40.81z"/></svg>
7124f4cb
WG
188 </div>
189 <div class="md-source__repository">
190 GitHub
191 </div>
192</a>
193 </div>
194
0c5338dd
TD
195 <ul class="md-nav__list" data-md-scrollfix>
196
197
198
199
200
201
202
203
204 <li class="md-nav__item">
205 <a href="../../getting-started/" class="md-nav__link">
206 Getting Started
207 </a>
208 </li>
209
210
211
212
213
214
215
216
217
218
219
220 <li class="md-nav__item md-nav__item--nested">
221
222
223 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2" type="checkbox" id="__nav_2" >
224
225 <label class="md-nav__link" for="__nav_2">
226 PHP API
227 <span class="md-nav__icon md-icon"></span>
228 </label>
229 <nav class="md-nav" aria-label="PHP API" data-md-level="1">
230 <label class="md-nav__title" for="__nav_2">
231 <span class="md-nav__icon md-icon"></span>
232 PHP API
233 </label>
234 <ul class="md-nav__list" data-md-scrollfix>
235
236
237
238
239
240 <li class="md-nav__item">
241 <a href="../../php/pages/" class="md-nav__link">
242 Pages
243 </a>
244 </li>
245
246
247
248
249
250
251
252 <li class="md-nav__item">
253 <a href="../../php/database-objects/" class="md-nav__link">
254 Database Objects
255 </a>
256 </li>
257
258
259
260
261
262
263
264 <li class="md-nav__item">
265 <a href="../../php/database-access/" class="md-nav__link">
266 Database Access
267 </a>
268 </li>
269
270
271
272
273
274
275
276 <li class="md-nav__item">
277 <a href="../../php/exceptions/" class="md-nav__link">
278 Exceptions
279 </a>
280 </li>
281
282
283
284
285
286
287
288
289 <li class="md-nav__item md-nav__item--nested">
290
291
292 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2_5" type="checkbox" id="__nav_2_5" >
293
294 <label class="md-nav__link" for="__nav_2_5">
295 API
296 <span class="md-nav__icon md-icon"></span>
297 </label>
298 <nav class="md-nav" aria-label="API" data-md-level="2">
299 <label class="md-nav__title" for="__nav_2_5">
300 <span class="md-nav__icon md-icon"></span>
301 API
302 </label>
303 <ul class="md-nav__list" data-md-scrollfix>
304
305
306
307
308
309 <li class="md-nav__item">
310 <a href="../../php/api/caches/" class="md-nav__link">
311 Caches
312 </a>
313 </li>
314
315
316
317
318
319
320
321 <li class="md-nav__item">
322 <a href="../../php/api/comments/" class="md-nav__link">
323 Comments
324 </a>
325 </li>
326
327
328
329
330
331
332
333 <li class="md-nav__item">
334 <a href="../../php/api/cronjobs/" class="md-nav__link">
335 Cronjobs
336 </a>
337 </li>
338
339
340
341
342
343
344
345 <li class="md-nav__item">
346 <a href="../../php/api/events/" class="md-nav__link">
347 Events
348 </a>
349 </li>
350
351
352
353
354
355
356
357
358 <li class="md-nav__item md-nav__item--nested">
359
360
361 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_2_5_5" type="checkbox" id="__nav_2_5_5" >
362
363 <label class="md-nav__link" for="__nav_2_5_5">
364 Form Builder
365 <span class="md-nav__icon md-icon"></span>
366 </label>
367 <nav class="md-nav" aria-label="Form Builder" data-md-level="3">
368 <label class="md-nav__title" for="__nav_2_5_5">
369 <span class="md-nav__icon md-icon"></span>
370 Form Builder
371 </label>
372 <ul class="md-nav__list" data-md-scrollfix>
373
374
375
376
377
378 <li class="md-nav__item">
379 <a href="../../php/api/form_builder/overview/" class="md-nav__link">
380 Overview
381 </a>
382 </li>
383
384
385
386
387
388
389
390 <li class="md-nav__item">
391 <a href="../../php/api/form_builder/structure/" class="md-nav__link">
392 Structure
393 </a>
394 </li>
395
396
397
398
399
400
401
402 <li class="md-nav__item">
403 <a href="../../php/api/form_builder/form_fields/" class="md-nav__link">
404 Fields
405 </a>
406 </li>
407
408
409
410
411
412
413
414 <li class="md-nav__item">
415 <a href="../../php/api/form_builder/validation_data/" class="md-nav__link">
416 Validation and Data
417 </a>
418 </li>
419
420
421
422
423
424
425
426 <li class="md-nav__item">
427 <a href="../../php/api/form_builder/dependencies/" class="md-nav__link">
428 Dependencies
429 </a>
430 </li>
431
432
433
434 </ul>
435 </nav>
436 </li>
437
438
439
440
441
442
443
444 <li class="md-nav__item">
445 <a href="../../php/api/package_installation_plugins/" class="md-nav__link">
446 Package Installation Plugins
447 </a>
448 </li>
449
450
451
452
453
454
455
456 <li class="md-nav__item">
457 <a href="../../php/api/user_activity_points/" class="md-nav__link">
458 User Activity Points
459 </a>
460 </li>
461
462
463
464
465
466
467
468 <li class="md-nav__item">
469 <a href="../../php/api/user_notifications/" class="md-nav__link">
470 User Notifications
471 </a>
472 </li>
473
474
475
476
477
478
479
480 <li class="md-nav__item">
481 <a href="../../php/api/sitemaps/" class="md-nav__link">
482 Sitemaps
483 </a>
484 </li>
485
486
487
488 </ul>
489 </nav>
490 </li>
491
492
493
494
495
496
497
498 <li class="md-nav__item">
499 <a href="../../php/code-style/" class="md-nav__link">
500 Code Style
501 </a>
502 </li>
503
504
505
506
507
508
509
510 <li class="md-nav__item">
511 <a href="../../php/apps/" class="md-nav__link">
512 Apps
513 </a>
514 </li>
515
516
517
518
519
520
521
522 <li class="md-nav__item">
523 <a href="../../php/gdpr/" class="md-nav__link">
524 GDPR
525 </a>
526 </li>
527
528
529
530 </ul>
531 </nav>
532 </li>
533
534
535
536
537
538
539
540
541
542
543
544 <li class="md-nav__item md-nav__item--nested">
545
546
547 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_3" type="checkbox" id="__nav_3" >
548
549 <label class="md-nav__link" for="__nav_3">
550 Languages, Templates & CSS
551 <span class="md-nav__icon md-icon"></span>
552 </label>
553 <nav class="md-nav" aria-label="Languages, Templates & CSS" data-md-level="1">
554 <label class="md-nav__title" for="__nav_3">
555 <span class="md-nav__icon md-icon"></span>
556 Languages, Templates & CSS
557 </label>
558 <ul class="md-nav__list" data-md-scrollfix>
559
560
561
562
563
564 <li class="md-nav__item">
565 <a href="../../view/languages/" class="md-nav__link">
566 Languages
567 </a>
568 </li>
569
570
571
572
573
574
575
576 <li class="md-nav__item">
577 <a href="../../view/templates/" class="md-nav__link">
578 Templates
579 </a>
580 </li>
581
582
583
584
585
586
587
588 <li class="md-nav__item">
589 <a href="../../view/css/" class="md-nav__link">
590 CSS
591 </a>
592 </li>
593
594
595
596 </ul>
597 </nav>
598 </li>
599
600
601
602
603
604
605
606
607
608
609
610 <li class="md-nav__item md-nav__item--nested">
611
612
613 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_4" type="checkbox" id="__nav_4" >
614
615 <label class="md-nav__link" for="__nav_4">
77efcd46 616 TypeScript and JavaScript API
0c5338dd
TD
617 <span class="md-nav__icon md-icon"></span>
618 </label>
77efcd46 619 <nav class="md-nav" aria-label="TypeScript and JavaScript API" data-md-level="1">
0c5338dd
TD
620 <label class="md-nav__title" for="__nav_4">
621 <span class="md-nav__icon md-icon"></span>
77efcd46 622 TypeScript and JavaScript API
0c5338dd
TD
623 </label>
624 <ul class="md-nav__list" data-md-scrollfix>
625
626
627
628
629
630 <li class="md-nav__item">
631 <a href="../../javascript/general-usage/" class="md-nav__link">
632 General Usage
633 </a>
634 </li>
635
636
637
638
639
640
641
77efcd46
WG
642 <li class="md-nav__item">
643 <a href="../../javascript/typescript/" class="md-nav__link">
644 TypeScript
645 </a>
646 </li>
647
648
649
650
651
652
653
0c5338dd
TD
654
655 <li class="md-nav__item md-nav__item--nested">
656
657
77efcd46 658 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_4_3" type="checkbox" id="__nav_4_3" >
0c5338dd 659
77efcd46 660 <label class="md-nav__link" for="__nav_4_3">
0c5338dd
TD
661 New API
662 <span class="md-nav__icon md-icon"></span>
663 </label>
664 <nav class="md-nav" aria-label="New API" data-md-level="2">
77efcd46 665 <label class="md-nav__title" for="__nav_4_3">
0c5338dd
TD
666 <span class="md-nav__icon md-icon"></span>
667 New API
668 </label>
669 <ul class="md-nav__list" data-md-scrollfix>
670
671
672
673
674
675 <li class="md-nav__item">
676 <a href="../../javascript/new-api_writing-a-module/" class="md-nav__link">
677 Writing a module
678 </a>
679 </li>
680
681
682
683
684
685
686
687 <li class="md-nav__item">
688 <a href="../../javascript/new-api_data-structures/" class="md-nav__link">
689 Data Structures
690 </a>
691 </li>
692
693
694
695
696
697
698
699 <li class="md-nav__item">
700 <a href="../../javascript/new-api_core/" class="md-nav__link">
701 Core Functions
702 </a>
703 </li>
704
705
706
707
708
709
710
711 <li class="md-nav__item">
712 <a href="../../javascript/new-api_dom/" class="md-nav__link">
713 DOM
714 </a>
715 </li>
716
717
718
719
720
721
722
723 <li class="md-nav__item">
724 <a href="../../javascript/new-api_events/" class="md-nav__link">
725 Event Handling
726 </a>
727 </li>
728
729
730
731
732
733
734
735 <li class="md-nav__item">
736 <a href="../../javascript/new-api_ajax/" class="md-nav__link">
737 Ajax
738 </a>
739 </li>
740
741
742
743
744
745
746
747 <li class="md-nav__item">
748 <a href="../../javascript/new-api_dialogs/" class="md-nav__link">
749 Dialogs
750 </a>
751 </li>
752
753
754
755
756
757
758
759 <li class="md-nav__item">
760 <a href="../../javascript/new-api_browser/" class="md-nav__link">
761 Browser and Screen Sizes
762 </a>
763 </li>
764
765
766
767
768
769
770
771 <li class="md-nav__item">
772 <a href="../../javascript/new-api_ui/" class="md-nav__link">
773 User Interface
774 </a>
775 </li>
776
777
778
779 </ul>
780 </nav>
781 </li>
782
783
784
785
786
787
788
789 <li class="md-nav__item">
790 <a href="../../javascript/legacy-api/" class="md-nav__link">
791 Legacy API
792 </a>
793 </li>
794
795
796
797
798
799
800
801 <li class="md-nav__item">
802 <a href="../../javascript/helper-functions/" class="md-nav__link">
803 Helper Functions
804 </a>
805 </li>
806
807
808
809
810
811
812
813 <li class="md-nav__item">
814 <a href="../../javascript/code-snippets/" class="md-nav__link">
815 Code Snippets
816 </a>
817 </li>
818
819
820
821 </ul>
822 </nav>
823 </li>
824
825
826
827
828
829
830
831
832
833
834
835
836
837 <li class="md-nav__item md-nav__item--active md-nav__item--nested">
838
839
840 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5" type="checkbox" id="__nav_5" checked>
841
842 <label class="md-nav__link" for="__nav_5">
843 Package Components
844 <span class="md-nav__icon md-icon"></span>
845 </label>
846 <nav class="md-nav" aria-label="Package Components" data-md-level="1">
847 <label class="md-nav__title" for="__nav_5">
848 <span class="md-nav__icon md-icon"></span>
849 Package Components
850 </label>
851 <ul class="md-nav__list" data-md-scrollfix>
852
853
854
855
856
857 <li class="md-nav__item">
858 <a href="../package-xml/" class="md-nav__link">
859 package.xml
860 </a>
861 </li>
862
863
864
865
866
867
868
869
870 <li class="md-nav__item md-nav__item--nested">
871
872
873 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5_2" type="checkbox" id="__nav_5_2" >
874
875 <label class="md-nav__link" for="__nav_5_2">
876 PIPs
877 <span class="md-nav__icon md-icon"></span>
878 </label>
879 <nav class="md-nav" aria-label="PIPs" data-md-level="2">
880 <label class="md-nav__title" for="__nav_5_2">
881 <span class="md-nav__icon md-icon"></span>
882 PIPs
883 </label>
884 <ul class="md-nav__list" data-md-scrollfix>
885
886
887
888
889
890 <li class="md-nav__item">
891 <a href="../pip/" class="md-nav__link">
892 Overview
893 </a>
894 </li>
895
896
897
898
899
900
901
902 <li class="md-nav__item">
903 <a href="../pip/acl-option/" class="md-nav__link">
904 aclOption
905 </a>
906 </li>
907
908
909
910
911
912
913
914 <li class="md-nav__item">
915 <a href="../pip/acp-menu/" class="md-nav__link">
916 acpMenu
917 </a>
918 </li>
919
920
921
922
923
924
925
926 <li class="md-nav__item">
927 <a href="../pip/acp-search-provider/" class="md-nav__link">
928 acpSearchProvider
929 </a>
930 </li>
931
932
933
934
935
936
937
938 <li class="md-nav__item">
939 <a href="../pip/acp-template/" class="md-nav__link">
940 acpTemplate
941 </a>
942 </li>
943
944
945
946
947
948
949
950 <li class="md-nav__item">
951 <a href="../pip/bbcode/" class="md-nav__link">
952 bbcode
953 </a>
954 </li>
955
956
957
958
959
960
961
962 <li class="md-nav__item">
963 <a href="../pip/box/" class="md-nav__link">
964 box
965 </a>
966 </li>
967
968
969
970
971
972
973
974 <li class="md-nav__item">
975 <a href="../pip/clipboard-action/" class="md-nav__link">
976 clipboardAction
977 </a>
978 </li>
979
980
981
982
983
984
985
986 <li class="md-nav__item">
987 <a href="../pip/core-object/" class="md-nav__link">
988 coreObject
989 </a>
990 </li>
991
992
993
994
995
996
997
998 <li class="md-nav__item">
999 <a href="../pip/cronjob/" class="md-nav__link">
1000 cronjob
1001 </a>
1002 </li>
1003
1004
1005
1006
1007
1008
1009
1010 <li class="md-nav__item">
1011 <a href="../pip/event-listener/" class="md-nav__link">
1012 eventListener
1013 </a>
1014 </li>
1015
1016
1017
1018
1019
1020
1021
1022 <li class="md-nav__item">
1023 <a href="../pip/file/" class="md-nav__link">
1024 file
1025 </a>
1026 </li>
1027
1028
1029
1030
1031
1032
1033
1034 <li class="md-nav__item">
1035 <a href="../pip/language/" class="md-nav__link">
1036 language
1037 </a>
1038 </li>
1039
1040
1041
1042
1043
1044
1045
1046 <li class="md-nav__item">
1047 <a href="../pip/media-provider/" class="md-nav__link">
1048 mediaProvider
1049 </a>
1050 </li>
1051
1052
1053
1054
1055
1056
1057
1058 <li class="md-nav__item">
1059 <a href="../pip/menu/" class="md-nav__link">
1060 menu
1061 </a>
1062 </li>
1063
1064
1065
1066
1067
1068
1069
1070 <li class="md-nav__item">
1071 <a href="../pip/menu-item/" class="md-nav__link">
1072 menuItem
1073 </a>
1074 </li>
1075
1076
1077
1078
1079
1080
1081
1082 <li class="md-nav__item">
1083 <a href="../pip/object-type/" class="md-nav__link">
1084 objectType
1085 </a>
1086 </li>
1087
1088
1089
1090
1091
1092
1093
1094 <li class="md-nav__item">
1095 <a href="../pip/object-type-definition/" class="md-nav__link">
1096 objectTypeDefinition
1097 </a>
1098 </li>
1099
1100
1101
1102
1103
1104
1105
1106 <li class="md-nav__item">
1107 <a href="../pip/option/" class="md-nav__link">
1108 option
1109 </a>
1110 </li>
1111
1112
1113
1114
1115
1116
1117
1118 <li class="md-nav__item">
1119 <a href="../pip/page/" class="md-nav__link">
1120 page
1121 </a>
1122 </li>
1123
1124
1125
1126
1127
1128
1129
1130 <li class="md-nav__item">
1131 <a href="../pip/pip/" class="md-nav__link">
1132 pip
1133 </a>
1134 </li>
1135
1136
1137
1138
1139
1140
1141
1142 <li class="md-nav__item">
1143 <a href="../pip/script/" class="md-nav__link">
1144 script
1145 </a>
1146 </li>
1147
1148
1149
1150
1151
1152
1153
1154 <li class="md-nav__item">
1155 <a href="../pip/smiley/" class="md-nav__link">
1156 smiley
1157 </a>
1158 </li>
1159
1160
1161
1162
1163
1164
1165
1166 <li class="md-nav__item">
1167 <a href="../pip/sql/" class="md-nav__link">
1168 sql
1169 </a>
1170 </li>
1171
1172
1173
1174
1175
1176
1177
1178 <li class="md-nav__item">
1179 <a href="../pip/style/" class="md-nav__link">
1180 style
1181 </a>
1182 </li>
1183
1184
1185
1186
1187
1188
1189
1190 <li class="md-nav__item">
1191 <a href="../pip/template/" class="md-nav__link">
1192 template
1193 </a>
1194 </li>
1195
1196
1197
1198
1199
1200
1201
1202 <li class="md-nav__item">
1203 <a href="../pip/template-listener/" class="md-nav__link">
1204 templateListener
1205 </a>
1206 </li>
1207
1208
1209
1210
1211
1212
1213
1214 <li class="md-nav__item">
1215 <a href="../pip/user-group-option/" class="md-nav__link">
1216 userGroupOption
1217 </a>
1218 </li>
1219
1220
1221
1222
1223
1224
1225
1226 <li class="md-nav__item">
1227 <a href="../pip/user-menu/" class="md-nav__link">
1228 userMenu
1229 </a>
1230 </li>
1231
1232
1233
1234
1235
1236
1237
1238 <li class="md-nav__item">
1239 <a href="../pip/user-notification-event/" class="md-nav__link">
1240 userNotificationEvent
1241 </a>
1242 </li>
1243
1244
1245
1246
1247
1248
1249
1250 <li class="md-nav__item">
1251 <a href="../pip/user-option/" class="md-nav__link">
1252 userOption
1253 </a>
1254 </li>
1255
1256
1257
1258
1259
1260
1261
1262 <li class="md-nav__item">
1263 <a href="../pip/user-profile-menu/" class="md-nav__link">
1264 userProfileMenu
1265 </a>
1266 </li>
1267
1268
1269
1270 </ul>
1271 </nav>
1272 </li>
1273
1274
1275
1276
1277
1278
1279
1280
1281
1282 <li class="md-nav__item md-nav__item--active">
1283
1284 <input class="md-nav__toggle md-toggle" data-md-toggle="toc" type="checkbox" id="__toc">
1285
1286
1287
1288
1289 <label class="md-nav__link md-nav__link--active" for="__toc">
1290 Database PHP API
1291 <span class="md-nav__icon md-icon"></span>
1292 </label>
1293
1294 <a href="./" class="md-nav__link md-nav__link--active">
1295 Database PHP API
1296 </a>
1297
1298
1299<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
1300
1301
1302
1303
1304
1305 <label class="md-nav__title" for="__toc">
1306 <span class="md-nav__icon md-icon"></span>
1307 Table of contents
1308 </label>
1309 <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
1310
1311 <li class="md-nav__item">
1312 <a href="#database-tables" class="md-nav__link">
1313 Database Tables
1314 </a>
1315
1316</li>
1317
1318 <li class="md-nav__item">
1319 <a href="#columns" class="md-nav__link">
1320 Columns
1321 </a>
1322
1323</li>
1324
1325 <li class="md-nav__item">
1326 <a href="#foreign-keys" class="md-nav__link">
1327 Foreign Keys
1328 </a>
1329
1330</li>
1331
1332 <li class="md-nav__item">
1333 <a href="#indices" class="md-nav__link">
1334 Indices
1335 </a>
1336
1337</li>
1338
1339 </ul>
1340
1341</nav>
1342
1343 </li>
1344
1345
1346
1347 </ul>
1348 </nav>
1349 </li>
1350
1351
1352
1353
1354
1355
1356
1357
1358
1359
1360
1361 <li class="md-nav__item md-nav__item--nested">
1362
1363
1364 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6" type="checkbox" id="__nav_6" >
1365
1366 <label class="md-nav__link" for="__nav_6">
1367 Migration
1368 <span class="md-nav__icon md-icon"></span>
1369 </label>
1370 <nav class="md-nav" aria-label="Migration" data-md-level="1">
1371 <label class="md-nav__title" for="__nav_6">
1372 <span class="md-nav__icon md-icon"></span>
1373 Migration
1374 </label>
1375 <ul class="md-nav__list" data-md-scrollfix>
1376
1377
1378
1379
1380
1381
1382 <li class="md-nav__item md-nav__item--nested">
1383
1384
1385 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_1" type="checkbox" id="__nav_6_1" >
1386
1387 <label class="md-nav__link" for="__nav_6_1">
1388 Migrating from WSC 5.3
1389 <span class="md-nav__icon md-icon"></span>
1390 </label>
1391 <nav class="md-nav" aria-label="Migrating from WSC 5.3" data-md-level="2">
1392 <label class="md-nav__title" for="__nav_6_1">
1393 <span class="md-nav__icon md-icon"></span>
1394 Migrating from WSC 5.3
1395 </label>
1396 <ul class="md-nav__list" data-md-scrollfix>
1397
1398
1399
1400
1401
1402 <li class="md-nav__item">
1403 <a href="../../migration/wsc53/php/" class="md-nav__link">
1404 PHP API
1405 </a>
1406 </li>
1407
1408
1409
1410
1411
1412
1413
1414 <li class="md-nav__item">
1415 <a href="../../migration/wsc53/session/" class="md-nav__link">
1416 Session Handling and Authentication
1417 </a>
1418 </li>
1419
1420
1421
1422
1423
1424
1425
1426 <li class="md-nav__item">
1427 <a href="../../migration/wsc53/javascript/" class="md-nav__link">
77efcd46 1428 TypeScript and JavaScript
0c5338dd
TD
1429 </a>
1430 </li>
1431
1432
1433
1434
1435
1436
1437
1438 <li class="md-nav__item">
1439 <a href="../../migration/wsc53/templates/" class="md-nav__link">
1440 Templates
1441 </a>
1442 </li>
1443
1444
1445
1446
1447
1448
1449
1450 <li class="md-nav__item">
1451 <a href="../../migration/wsc53/libraries/" class="md-nav__link">
1452 Third Party Libraries
1453 </a>
1454 </li>
1455
1456
1457
1458 </ul>
1459 </nav>
1460 </li>
1461
1462
1463
1464
1465
1466
1467
1468
1469 <li class="md-nav__item md-nav__item--nested">
1470
1471
1472 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_2" type="checkbox" id="__nav_6_2" >
1473
1474 <label class="md-nav__link" for="__nav_6_2">
1475 Migrating from WSC 5.2
1476 <span class="md-nav__icon md-icon"></span>
1477 </label>
1478 <nav class="md-nav" aria-label="Migrating from WSC 5.2" data-md-level="2">
1479 <label class="md-nav__title" for="__nav_6_2">
1480 <span class="md-nav__icon md-icon"></span>
1481 Migrating from WSC 5.2
1482 </label>
1483 <ul class="md-nav__list" data-md-scrollfix>
1484
1485
1486
1487
1488
1489 <li class="md-nav__item">
1490 <a href="../../migration/wsc52/php/" class="md-nav__link">
1491 PHP API
1492 </a>
1493 </li>
1494
1495
1496
1497
1498
1499
1500
1501 <li class="md-nav__item">
1502 <a href="../../migration/wsc52/templates/" class="md-nav__link">
1503 Templates and Languages
1504 </a>
1505 </li>
1506
1507
1508
1509
1510
1511
1512
1513 <li class="md-nav__item">
1514 <a href="../../migration/wsc52/libraries/" class="md-nav__link">
1515 Third Party Libraries
1516 </a>
1517 </li>
1518
1519
1520
1521 </ul>
1522 </nav>
1523 </li>
1524
1525
1526
1527
1528
1529
1530
1531
1532 <li class="md-nav__item md-nav__item--nested">
1533
1534
1535 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_3" type="checkbox" id="__nav_6_3" >
1536
1537 <label class="md-nav__link" for="__nav_6_3">
1538 Migrating from WSC 3.1
1539 <span class="md-nav__icon md-icon"></span>
1540 </label>
1541 <nav class="md-nav" aria-label="Migrating from WSC 3.1" data-md-level="2">
1542 <label class="md-nav__title" for="__nav_6_3">
1543 <span class="md-nav__icon md-icon"></span>
1544 Migrating from WSC 3.1
1545 </label>
1546 <ul class="md-nav__list" data-md-scrollfix>
1547
1548
1549
1550
1551
1552 <li class="md-nav__item">
1553 <a href="../../migration/wsc31/php/" class="md-nav__link">
1554 PHP API
1555 </a>
1556 </li>
1557
1558
1559
1560 </ul>
1561 </nav>
1562 </li>
1563
1564
1565
1566
1567
1568
1569
1570
1571 <li class="md-nav__item md-nav__item--nested">
1572
1573
1574 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_4" type="checkbox" id="__nav_6_4" >
1575
1576 <label class="md-nav__link" for="__nav_6_4">
1577 Migrating from WSC 3.0
1578 <span class="md-nav__icon md-icon"></span>
1579 </label>
1580 <nav class="md-nav" aria-label="Migrating from WSC 3.0" data-md-level="2">
1581 <label class="md-nav__title" for="__nav_6_4">
1582 <span class="md-nav__icon md-icon"></span>
1583 Migrating from WSC 3.0
1584 </label>
1585 <ul class="md-nav__list" data-md-scrollfix>
1586
1587
1588
1589
1590
1591 <li class="md-nav__item">
1592 <a href="../../migration/wsc30/php/" class="md-nav__link">
1593 PHP API
1594 </a>
1595 </li>
1596
1597
1598
1599
1600
1601
1602
1603 <li class="md-nav__item">
1604 <a href="../../migration/wsc30/javascript/" class="md-nav__link">
1605 JavaScript API
1606 </a>
1607 </li>
1608
1609
1610
1611
1612
1613
1614
1615 <li class="md-nav__item">
1616 <a href="../../migration/wsc30/templates/" class="md-nav__link">
1617 Templates
1618 </a>
1619 </li>
1620
1621
1622
1623
1624
1625
1626
1627 <li class="md-nav__item">
1628 <a href="../../migration/wsc30/css/" class="md-nav__link">
1629 CSS
1630 </a>
1631 </li>
1632
1633
1634
1635
1636
1637
1638
1639 <li class="md-nav__item">
1640 <a href="../../migration/wsc30/package/" class="md-nav__link">
1641 Package Components
1642 </a>
1643 </li>
1644
1645
1646
1647 </ul>
1648 </nav>
1649 </li>
1650
1651
1652
1653
1654
1655
1656
1657
1658 <li class="md-nav__item md-nav__item--nested">
1659
1660
1661 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6_5" type="checkbox" id="__nav_6_5" >
1662
1663 <label class="md-nav__link" for="__nav_6_5">
1664 Migrating from WCF 2.1
1665 <span class="md-nav__icon md-icon"></span>
1666 </label>
1667 <nav class="md-nav" aria-label="Migrating from WCF 2.1" data-md-level="2">
1668 <label class="md-nav__title" for="__nav_6_5">
1669 <span class="md-nav__icon md-icon"></span>
1670 Migrating from WCF 2.1
1671 </label>
1672 <ul class="md-nav__list" data-md-scrollfix>
1673
1674
1675
1676
1677
1678 <li class="md-nav__item">
1679 <a href="../../migration/wcf21/php/" class="md-nav__link">
1680 PHP API
1681 </a>
1682 </li>
1683
1684
1685
1686
1687
1688
1689
1690 <li class="md-nav__item">
1691 <a href="../../migration/wcf21/templates/" class="md-nav__link">
1692 Templates
1693 </a>
1694 </li>
1695
1696
1697
1698
1699
1700
1701
1702 <li class="md-nav__item">
1703 <a href="../../migration/wcf21/css/" class="md-nav__link">
1704 CSS
1705 </a>
1706 </li>
1707
1708
1709
1710
1711
1712
1713
1714 <li class="md-nav__item">
1715 <a href="../../migration/wcf21/package/" class="md-nav__link">
1716 Package Components
1717 </a>
1718 </li>
1719
1720
1721
1722 </ul>
1723 </nav>
1724 </li>
1725
1726
1727
1728 </ul>
1729 </nav>
1730 </li>
1731
1732
1733
1734
1735
1736
1737
1738
1739
1740
1741
1742 <li class="md-nav__item md-nav__item--nested">
1743
1744
1745 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_7" type="checkbox" id="__nav_7" >
1746
1747 <label class="md-nav__link" for="__nav_7">
1748 Tutorials
1749 <span class="md-nav__icon md-icon"></span>
1750 </label>
1751 <nav class="md-nav" aria-label="Tutorials" data-md-level="1">
1752 <label class="md-nav__title" for="__nav_7">
1753 <span class="md-nav__icon md-icon"></span>
1754 Tutorials
1755 </label>
1756 <ul class="md-nav__list" data-md-scrollfix>
1757
1758
1759
1760
1761
1762
1763 <li class="md-nav__item md-nav__item--nested">
1764
1765
1766 <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_7_1" type="checkbox" id="__nav_7_1" >
1767
1768 <label class="md-nav__link" for="__nav_7_1">
1769 Tutorial Series
1770 <span class="md-nav__icon md-icon"></span>
1771 </label>
1772 <nav class="md-nav" aria-label="Tutorial Series" data-md-level="2">
1773 <label class="md-nav__title" for="__nav_7_1">
1774 <span class="md-nav__icon md-icon"></span>
1775 Tutorial Series
1776 </label>
1777 <ul class="md-nav__list" data-md-scrollfix>
1778
1779
1780
1781
1782
1783 <li class="md-nav__item">
1784 <a href="../../tutorial/series/overview/" class="md-nav__link">
1785 Overview
1786 </a>
1787 </li>
1788
1789
1790
1791
1792
1793
1794
1795 <li class="md-nav__item">
1796 <a href="../../tutorial/series/part_1/" class="md-nav__link">
1797 Part 1
1798 </a>
1799 </li>
1800
1801
1802
1803
1804
1805
1806
1807 <li class="md-nav__item">
1808 <a href="../../tutorial/series/part_2/" class="md-nav__link">
1809 Part 2
1810 </a>
1811 </li>
1812
1813
1814
1815
1816
1817
1818
1819 <li class="md-nav__item">
1820 <a href="../../tutorial/series/part_3/" class="md-nav__link">
1821 Part 3
1822 </a>
1823 </li>
1824
1825
1826
1827 </ul>
1828 </nav>
1829 </li>
1830
1831
1832
1833 </ul>
1834 </nav>
1835 </li>
1836
1837
1838
1839 </ul>
1840</nav>
1841 </div>
1842 </div>
1843 </div>
1844
1845
1846
1847 <div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" >
1848 <div class="md-sidebar__scrollwrap">
1849 <div class="md-sidebar__inner">
1850
1851<nav class="md-nav md-nav--secondary" aria-label="Table of contents">
1852
1853
1854
1855
1856
1857 <label class="md-nav__title" for="__toc">
1858 <span class="md-nav__icon md-icon"></span>
1859 Table of contents
1860 </label>
1861 <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
1862
1863 <li class="md-nav__item">
1864 <a href="#database-tables" class="md-nav__link">
1865 Database Tables
1866 </a>
1867
1868</li>
1869
1870 <li class="md-nav__item">
1871 <a href="#columns" class="md-nav__link">
1872 Columns
1873 </a>
1874
1875</li>
1876
1877 <li class="md-nav__item">
1878 <a href="#foreign-keys" class="md-nav__link">
1879 Foreign Keys
1880 </a>
1881
1882</li>
1883
1884 <li class="md-nav__item">
1885 <a href="#indices" class="md-nav__link">
1886 Indices
1887 </a>
1888
1889</li>
1890
1891 </ul>
1892
1893</nav>
1894 </div>
1895 </div>
1896 </div>
1897
1898
1899 <div class="md-content" data-md-component="content">
1900 <article class="md-content__inner md-typeset">
1901
1902
9b8bddda 1903 <a href="https://github.com/WoltLab/docs.woltlab.com/edit/5.4/docs/package/database-php-api.md" title="Edit this page" class="md-content__button md-icon">
7124f4cb
WG
1904 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20.71 7.04c.39-.39.39-1.04 0-1.41l-2.34-2.34c-.37-.39-1.02-.39-1.41 0l-1.84 1.83 3.75 3.75M3 17.25V21h3.75L17.81 9.93l-3.75-3.75L3 17.25z"/></svg>
1905 </a>
1906
0c5338dd
TD
1907
1908 <h1 id="database-php-api">Database PHP API<a class="headerlink" href="#database-php-api" title="Permanent link">#</a></h1>
1909<div class="admonition info">
1910<p class="admonition-title">Available since WoltLab Suite 5.2.</p>
1911</div>
1912<p>While the <a href="../pip/sql/">sql</a> package installation plugin supports adding and removing tables, columns, and indices, it is not able to handle cases where the added table, column, or index already exist.
1913We have added a new PHP-based API to manipulate the database scheme which can be used in combination with the <a href="../pip/script/">script</a> package installation plugin that skips parts that already exist:</p>
1914<div class="highlight"><pre><span></span><code><span class="nv">$tables</span> <span class="o">=</span> <span class="p">[</span>
abd2f18a 1915 <span class="c1">// list of `DatabaseTable` objects</span>
0c5338dd
TD
1916<span class="p">];</span>
1917
1918<span class="p">(</span><span class="k">new</span> <span class="nx">DatabaseTableChangeProcessor</span><span class="p">(</span>
1919 <span class="sd">/** @var ScriptPackageInstallationPlugin $this */</span>
1920 <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">installation</span><span class="o">-&gt;</span><span class="na">getPackage</span><span class="p">(),</span>
1921 <span class="nv">$tables</span><span class="p">,</span>
1922 <span class="nx">WCF</span><span class="o">::</span><span class="na">getDB</span><span class="p">()</span><span class="o">-&gt;</span><span class="na">getEditor</span><span class="p">())</span>
1923<span class="p">)</span><span class="o">-&gt;</span><span class="na">process</span><span class="p">();</span>
1924</code></pre></div>
0c5338dd 1925<p>All of the relevant components can be found in the <code>wcf\system\database\table</code> namespace.</p>
abd2f18a
WG
1926<p>With WoltLab Suite 5.4, you should use the new <a href="../pip/database/">database</a> package installation plugin for which you only have to return the array of affected database tables:</p>
1927<div class="highlight"><pre><span></span><code><span class="k">return</span> <span class="p">[</span>
1928 <span class="c1">// list of `DatabaseTable` objects</span>
1929<span class="p">];</span>
1930</code></pre></div>
0c5338dd
TD
1931<h2 id="database-tables">Database Tables<a class="headerlink" href="#database-tables" title="Permanent link">#</a></h2>
1932<p>There are two classes representing database tables: <code>DatabaseTable</code> and <code>PartialDatabaseTable</code>.
1933If a new table should be created, use <code>DatabaseTable</code>.
1934In all other cases, <code>PartialDatabaseTable</code> should be used as it provides an additional save-guard against accidentally creating a new table by having a typo in the table name:
1935If the tables does not already exist, a table represented by <code>PartialDatabaseTable</code> will cause an exception (while a <code>DatabaseTable</code> table will simply be created).</p>
1936<p>To create a table, a <code>DatabaseTable</code> object with the table's name as to be created and table's columns, foreign keys and indices have to be specified:</p>
1937<div class="highlight"><pre><span></span><code><span class="nx">DatabaseTable</span><span class="o">::</span><span class="na">create</span><span class="p">(</span><span class="s1">&#39;foo1_bar&#39;</span><span class="p">)</span>
1938 <span class="o">-&gt;</span><span class="na">columns</span><span class="p">([</span>
1939 <span class="c1">// columns</span>
1940 <span class="p">])</span>
1941 <span class="o">-&gt;</span><span class="na">foreignKeys</span><span class="p">([</span>
1942 <span class="c1">// foreign keys</span>
1943 <span class="p">])</span>
1944 <span class="o">-&gt;</span><span class="na">indices</span><span class="p">([</span>
1945 <span class="c1">// indices</span>
1946 <span class="p">])</span>
1947</code></pre></div>
0c5338dd
TD
1948<p>To update a table, the same code as above can be used, except for <code>PartialDatabaseTable</code> being used instead of <code>DatabaseTable</code>.</p>
1949<p>To drop a table, only the <code>drop()</code> method has to be called:</p>
1950<div class="highlight"><pre><span></span><code><span class="nx">PartialDatabaseTable</span><span class="o">::</span><span class="na">create</span><span class="p">(</span><span class="s1">&#39;foo1_bar&#39;</span><span class="p">)</span>
1951 <span class="o">-&gt;</span><span class="na">drop</span><span class="p">()</span>
1952</code></pre></div>
0c5338dd
TD
1953<h2 id="columns">Columns<a class="headerlink" href="#columns" title="Permanent link">#</a></h2>
1954<p>To represent a column of a database table, you have to create an instance of the relevant column class found in the <code>wcf\system\database\table\column</code> namespace.
1955Such instances are created similarly to database table objects using the <code>create()</code> factory method and passing the column name as the parameter.</p>
1956<p>Every column type supports the following methods:</p>
1957<ul>
1958<li><code>defaultValue($defaultValue)</code> sets the default value of the column (default: none).</li>
1959<li><code>drop()</code> to drop the column.</li>
1960<li><code>notNull($notNull = true)</code> sets if the value of the column can be <code>NULL</code> (default: <code>false</code>).</li>
1961</ul>
1962<p>Depending on the specific column class implementing additional interfaces, the following methods are also available:</p>
1963<ul>
1964<li><code>IAutoIncrementDatabaseTableColumn::autoIncrement($autoIncrement = true)</code> sets if the value of the colum is auto-incremented.</li>
1965<li><code>IDecimalsDatabaseTableColumn::decimals($decimals)</code> sets the number of decimals the column supports.</li>
1966<li><code>IEnumDatabaseTableColumn::enumValues(array $values)</code> sets the predetermined set of valid values of the column.</li>
1967<li><code>ILengthDatabaseTableColumn::length($length)</code> sets the (maximum) length of the column.</li>
1968</ul>
1969<p>Additionally, there are some additionally classes of commonly used columns with specific properties:</p>
1970<ul>
1971<li><code>DefaultFalseBooleanDatabaseTableColumn</code> (a <code>tinyint</code> column with length <code>1</code>, default value <code>0</code> and whose values cannot be <code>null</code>)</li>
1972<li><code>DefaultTrueBooleanDatabaseTableColumn</code> (a <code>tinyint</code> column with length <code>0</code>, default value <code>0</code> and whose values cannot be <code>null</code>)</li>
1973<li><code>NotNullInt10DatabaseTableColumn</code> (a <code>int</code> column with length <code>10</code> and whose values cannot be <code>null</code>)</li>
1974<li><code>NotNullVarchar191DatabaseTableColumn</code> (a <code>varchar</code> column with length <code>191</code> and whose values cannot be <code>null</code>)</li>
1975<li><code>NotNullVarchar255DatabaseTableColumn</code> (a <code>varchar</code> column with length <code>255</code> and whose values cannot be <code>null</code>)</li>
1976<li><code>ObjectIdDatabaseTableColumn</code> (a <code>int</code> column with length <code>10</code>, whose values cannot be <code>null</code>, and whose values are auto-incremented)</li>
1977</ul>
1978<p>Examples:</p>
1979<div class="highlight"><pre><span></span><code><span class="nx">DefaultFalseBooleanDatabaseTableColumn</span><span class="o">::</span><span class="na">create</span><span class="p">(</span><span class="s1">&#39;isDisabled&#39;</span><span class="p">)</span>
1980
1981<span class="nx">NotNullInt10DatabaseTableColumn</span><span class="o">::</span><span class="na">create</span><span class="p">(</span><span class="s1">&#39;fooTypeID&#39;</span><span class="p">)</span>
1982
1983<span class="nx">SmallintDatabaseTableColumn</span><span class="o">::</span><span class="na">create</span><span class="p">(</span><span class="s1">&#39;bar&#39;</span><span class="p">)</span>
1984 <span class="o">-&gt;</span><span class="na">length</span><span class="p">(</span><span class="mi">5</span><span class="p">)</span>
1985 <span class="o">-&gt;</span><span class="na">notNull</span><span class="p">()</span>
1986</code></pre></div>
0c5338dd
TD
1987<h2 id="foreign-keys">Foreign Keys<a class="headerlink" href="#foreign-keys" title="Permanent link">#</a></h2>
1988<p>Foreign keys are represented by <code>DatabaseTableForeignKey</code> objects: </p>
1989<div class="highlight"><pre><span></span><code><span class="nx">DatabaseTableForeignKey</span><span class="o">::</span><span class="na">create</span><span class="p">()</span>
1990 <span class="o">-&gt;</span><span class="na">columns</span><span class="p">([</span><span class="s1">&#39;fooID&#39;</span><span class="p">])</span>
1991 <span class="o">-&gt;</span><span class="na">referencedTable</span><span class="p">(</span><span class="s1">&#39;wcf1_foo&#39;</span><span class="p">)</span>
1992 <span class="o">-&gt;</span><span class="na">referencedColumns</span><span class="p">([</span><span class="s1">&#39;fooID&#39;</span><span class="p">])</span>
1993 <span class="o">-&gt;</span><span class="na">onDelete</span><span class="p">(</span><span class="s1">&#39;CASCADE&#39;</span><span class="p">)</span>
1994</code></pre></div>
0c5338dd
TD
1995<p>The supported actions for <code>onDelete()</code> and <code>onUpdate()</code> are <code>CASCADE</code>, <code>NO ACTION</code>, and <code>SET NULL</code>.
1996To drop a foreign key, all of the relevant data to create the foreign key has to be present and the <code>drop()</code> method has to be called.</p>
1997<p><code>DatabaseTableForeignKey::create()</code> also supports the foreign key name as a parameter.
1998If it is not present, <code>DatabaseTable::foreignKeys()</code> will automatically set one based on the foreign key's data.</p>
1999<h2 id="indices">Indices<a class="headerlink" href="#indices" title="Permanent link">#</a></h2>
2000<p>Indices are represented by <code>DatabaseTableIndex</code> objects: </p>
2001<div class="highlight"><pre><span></span><code><span class="nx">DatabaseTableIndex</span><span class="o">::</span><span class="na">create</span><span class="p">()</span>
2002 <span class="o">-&gt;</span><span class="na">type</span><span class="p">(</span><span class="nx">DatabaseTableIndex</span><span class="o">::</span><span class="na">UNIQUE_TYPE</span><span class="p">)</span>
2003 <span class="o">-&gt;</span><span class="na">columns</span><span class="p">([</span><span class="s1">&#39;fooID&#39;</span><span class="p">])</span>
2004</code></pre></div>
0c5338dd
TD
2005<p>There are four different types: <code>DatabaseTableIndex::DEFAULT_TYPE</code> (default), <code>DatabaseTableIndex::PRIMARY_TYPE</code>, <code>DatabaseTableIndex::UNIQUE_TYPE</code>, and <code>DatabaseTableIndex::FULLTEXT_TYPE</code>.
2006For primary keys, there is also the <code>DatabaseTablePrimaryIndex</code> class which automatically sets the type to <code>DatabaseTableIndex::PRIMARY_TYPE</code>.
2007To drop a index, all of the relevant data to create the index has to be present and the <code>drop()</code> method has to be called.</p>
2008<p><code>DatabaseTableIndex::create()</code> also supports the index name as a parameter.
2009If it is not present, <code>DatabaseTable::indices()</code> will automatically set one based on the index data.</p>
2010
4a5c32e1
WG
2011
2012
2013
2014<hr>
2015<div class="md-source-date">
2016 <small>
2017
abd2f18a 2018 Last update: 2021-03-16
4a5c32e1
WG
2019
2020 </small>
2021</div>
2022
2023
0c5338dd
TD
2024
2025
2026
2027
2028
2029
2030 </article>
2031 </div>
2032 </div>
fb962f09 2033
0c5338dd
TD
2034 </main>
2035
2036
2037<footer class="md-footer">
2038
2039 <nav class="md-footer__inner md-grid" aria-label="Footer">
2040
2041 <a href="../pip/user-profile-menu/" class="md-footer__link md-footer__link--prev" rel="prev">
2042 <div class="md-footer__button md-icon">
2043 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg>
2044 </div>
2045 <div class="md-footer__title">
2046 <div class="md-ellipsis">
2047 <span class="md-footer__direction">
2048 Previous
2049 </span>
2050 userProfileMenu
2051 </div>
2052 </div>
2053 </a>
2054
2055
2056 <a href="../../migration/wsc53/php/" class="md-footer__link md-footer__link--next" rel="next">
2057 <div class="md-footer__title">
2058 <div class="md-ellipsis">
2059 <span class="md-footer__direction">
2060 Next
2061 </span>
2062 PHP API
2063 </div>
2064 </div>
2065 <div class="md-footer__button md-icon">
2066 <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M4 11v2h12l-5.5 5.5 1.42 1.42L19.84 12l-7.92-7.92L10.5 5.5 16 11H4z"/></svg>
2067 </div>
2068 </a>
2069
2070 </nav>
2071
2072 <div class="md-footer-meta md-typeset">
2073 <div class="md-footer-meta__inner md-grid">
2074 <div class="md-footer-copyright">
2075
2076 <div class="md-footer-copyright__highlight">
2077 Copyright © 2020 WoltLab GmbH
2078 </div>
2079
2080 Made with
2081 <a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
2082 Material for MkDocs
2083 </a>
fb88dc6e 2084
0c5338dd
TD
2085 </div>
2086 <div class="md-footer-copyright">
2087 <a href="https://www.woltlab.com/legal-notice/">Legal Notice</a>
2088 <a href="https://www.woltlab.com/privacy-policy/">Privacy Policy</a>
2089</div>
2090 </div>
2091 </div>
2092</footer>
2093
2094 </div>
2095 <div class="md-dialog" data-md-component="dialog">
2096 <div class="md-dialog__inner md-typeset"></div>
2097 </div>
fb962f09 2098 <script id="__config" type="application/json">{"base": "../..", "features": [], "translations": {"clipboard.copy": "Copy to clipboard", "clipboard.copied": "Copied to clipboard", "search.config.lang": "en", "search.config.pipeline": "trimmer, stopWordFilter", "search.config.separator": "[\\s\\-]+", "search.placeholder": "Search", "search.result.placeholder": "Type to start searching", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.term.missing": "Missing"}, "search": "../../assets/javascripts/workers/search.fe42c31b.min.js", "version": {"provider": "mike"}}</script>
0c5338dd
TD
2099
2100
fb962f09 2101 <script src="../../assets/javascripts/bundle.d892486b.min.js"></script>
0c5338dd
TD
2102
2103
2104 </body>
2105</html>