Odniesienie API Criteria
Kompletna dokumentacja API dla systemu budowania zapytań XOOPS Criteria.
Architektura Systemu Criteria
Dział zatytułowany „Architektura Systemu Criteria”classDiagram class CriteriaElement { <<abstract>> #string $order #string $sort #int $limit #int $start +setSort(sort) +getSort() +setOrder(order) +getOrder() +setLimit(limit) +getLimit() +setStart(start) +getStart() +setGroupby(groupby) +getGroupby() +render() +renderWhere() +renderLdap() }
class Criteria { -string $prefix -string $function -string $column -string $operator -mixed $value +__construct(column, value, operator, prefix, function) +render() +renderWhere() }
class CriteriaCompo { -array $criterias -array $conditions +__construct(criteria) +add(criteria, condition) +render() +renderWhere() }
CriteriaElement <|-- Criteria CriteriaElement <|-- CriteriaCompo CriteriaCompo o-- CriteriaElement : containsKlasa Criteria
Dział zatytułowany „Klasa Criteria”Konstruktor
Dział zatytułowany „Konstruktor”public function __construct( string $column, // Nazwa kolumny mixed $value = '', // Wartość do porównania string $operator = '=', // Operator porównania string $prefix = '', // Prefiks tabeli string $function = '' // Opakowanie funkcji SQL)Operatory
Dział zatytułowany „Operatory”| Operator | Przykład | Wyjście SQL |
|---|---|---|
= | new Criteria('status', 1) | status = 1 |
!= | new Criteria('status', 0, '!=') | status != 0 |
<> | new Criteria('status', 0, '<>') | status <> 0 |
< | new Criteria('age', 18, '<') | age < 18 |
<= | new Criteria('age', 18, '<=') | age <= 18 |
> | new Criteria('age', 18, '>') | age > 18 |
>= | new Criteria('age', 18, '>=') | age >= 18 |
LIKE | new Criteria('title', '%php%', 'LIKE') | title LIKE '%php%' |
NOT LIKE | new Criteria('title', '%spam%', 'NOT LIKE') | title NOT LIKE '%spam%' |
IN | new Criteria('id', '(1,2,3)', 'IN') | id IN (1,2,3) |
NOT IN | new Criteria('id', '(1,2,3)', 'NOT IN') | id NOT IN (1,2,3) |
IS NULL | new Criteria('deleted', null, 'IS NULL') | deleted IS NULL |
IS NOT NULL | new Criteria('email', null, 'IS NOT NULL') | email IS NOT NULL |
BETWEEN | new Criteria('created', '1000 AND 2000', 'BETWEEN') | created BETWEEN 1000 AND 2000 |
Przykłady Użycia
Dział zatytułowany „Przykłady Użycia”// Prosta równość$criteria = new Criteria('status', 'published');
// Porównanie liczbowe$criteria = new Criteria('views', 100, '>=');
// Dopasowanie wzorca$criteria = new Criteria('title', '%XOOPS%', 'LIKE');
// Z prefiksem tabeli$criteria = new Criteria('uid', 1, '=', 'u');// Renders: u.uid = 1
// Z funkcją SQL$criteria = new Criteria('title', '', '!=', '', 'LOWER');// Renders: LOWER(title) != ''Klasa CriteriaCompo
Dział zatytułowany „Klasa CriteriaCompo”Konstruktor i Metody
Dział zatytułowany „Konstruktor i Metody”// Utwórz puste compo$criteria = new CriteriaCompo();
// Lub z początkową kryteriami$criteria = new CriteriaCompo(new Criteria('status', 'active'));
// Dodaj kryteria (domyślnie AND)$criteria->add(new Criteria('views', 10, '>='));
// Dodaj z OR$criteria->add(new Criteria('featured', 1), 'OR');
// Zagnieżdżanie$subCriteria = new CriteriaCompo();$subCriteria->add(new Criteria('author', 1));$subCriteria->add(new Criteria('author', 2), 'OR');$criteria->add($subCriteria); // (author = 1 OR author = 2)Sortowanie i Paginacja
Dział zatytułowany „Sortowanie i Paginacja”$criteria = new CriteriaCompo();$criteria->add(new Criteria('status', 'published'));
// Jedno sortowanie$criteria->setSort('created');$criteria->setOrder('DESC');
// Wiele kolumn sortowania$criteria->setSort('category_id, created');$criteria->setOrder('ASC, DESC');
// Paginacja$criteria->setLimit(10); // Elementy na stronę$criteria->setStart(0); // Przesunięcie (strona * limit)
// Grupuj po$criteria->setGroupby('category_id');Przepływ Budowania Zapytań
Dział zatytułowany „Przepływ Budowania Zapytań”flowchart TD A[Utwórz CriteriaCompo] --> B[Dodaj Criteria] B --> C{Więcej Warunków?} C -->|Tak| B C -->|Nie| D[Ustaw Sort/Order] D --> E[Ustaw Limit/Start] E --> F[Przekaż do Handler] F --> G[Handler wywołuje render] G --> H[Generuj SQL WHERE] H --> I[Wykonaj Zapytanie] I --> J[Zwróć Wyniki]Złożone Przykłady Zapytań
Dział zatytułowany „Złożone Przykłady Zapytań”Wyszukiwanie z Wieloma Warunkami
Dział zatytułowany „Wyszukiwanie z Wieloma Warunkami”$criteria = new CriteriaCompo();
// Status musi być opublikowany$criteria->add(new Criteria('status', 'published'));
// Kategoria to 1, 2, lub 3$criteria->add(new Criteria('category_id', '(1, 2, 3)', 'IN'));
// Utworzony w ostatnich 30 dniach$thirtyDaysAgo = time() - (30 * 24 * 60 * 60);$criteria->add(new Criteria('created', $thirtyDaysAgo, '>='));
// Termin wyszukiwania w tytule LUB zawartości$searchCriteria = new CriteriaCompo();$searchCriteria->add(new Criteria('title', '%' . $searchTerm . '%', 'LIKE'));$searchCriteria->add(new Criteria('content', '%' . $searchTerm . '%', 'LIKE'), 'OR');$criteria->add($searchCriteria);
// Sortuj po wyświetleniach malejąco$criteria->setSort('views');$criteria->setOrder('DESC');
// Paginuj$criteria->setLimit($perPage);$criteria->setStart($page * $perPage);
// Wykonaj$items = $itemHandler->getObjects($criteria);$total = $itemHandler->getCount($criteria);Zapytanie Zakresu Dat
Dział zatytułowany „Zapytanie Zakresu Dat”$criteria = new CriteriaCompo();
// Między dwiema datami$startDate = strtotime('2024-01-01');$endDate = strtotime('2024-12-31');
$criteria->add(new Criteria('created', $startDate, '>='));$criteria->add(new Criteria('created', $endDate, '<='));
// Lub używając BETWEEN$criteria->add(new Criteria('created', "$startDate AND $endDate", 'BETWEEN'));Filtr Uprawnień Użytkownika
Dział zatytułowany „Filtr Uprawnień Użytkownika”$criteria = new CriteriaCompo();$criteria->add(new Criteria('status', 'published'));
// Jeśli nie admin, pokazuj tylko własne elementy lub publiczneif (!$xoopsUser || !$xoopsUser->isAdmin()) { $permCriteria = new CriteriaCompo(); $permCriteria->add(new Criteria('visibility', 'public'));
if (is_object($xoopsUser)) { $permCriteria->add(new Criteria('author_id', $xoopsUser->getVar('uid')), 'OR'); }
$criteria->add($permCriteria);}Zapytanie Podobne do Join
Dział zatytułowany „Zapytanie Podobne do Join”// Pobierz elementy gdzie kategoria jest aktywna// (Używając podejścia podzapytania)$categoryHandler = xoops_getHandler('category');$activeCatCriteria = new Criteria('status', 'active');$activeCategories = $categoryHandler->getIds($activeCatCriteria);
if (!empty($activeCategories)) { $criteria->add(new Criteria('category_id', '(' . implode(',', $activeCategories) . ')', 'IN'));}Wizualizacja Criteria na SQL
Dział zatytułowany „Wizualizacja Criteria na SQL”graph LR subgraph "Kod PHP" A["new Criteria('status', 'published')"] B["new Criteria('views', 100, '>=')"] C["CriteriaCompo with A + B"] end
subgraph "Wygenerowane SQL" D["status = 'published'"] E["views >= 100"] F["WHERE status = 'published' AND views >= 100"] end
A --> D B --> E C --> FIntegracja Handler
Dział zatytułowany „Integracja Handler”// Standardowe metody handlera, które akceptują Criteria
// Pobierz wiele obiektów$objects = $handler->getObjects($criteria);$objects = $handler->getObjects($criteria, true); // Jako tablica$objects = $handler->getObjects($criteria, true, true); // Jako tablica, id jako klucz
// Pobierz liczbę$count = $handler->getCount($criteria);
// Pobierz listę (id => identifier)$list = $handler->getList($criteria);
// Usuń pasujące$deleted = $handler->deleteAll($criteria);
// Aktualizuj pasujące$handler->updateAll('status', 'archived', $criteria);Rozważania Wydajności
Dział zatytułowany „Rozważania Wydajności”graph TB subgraph "Porady Optymalizacji" A[Użyj Indeksów] --> E[Szybsze Zapytania] B[Ogranicz Wyniki] --> E C[Unikaj LIKE '%...'] --> E D[Użyj Konkretnych Kolumn] --> E end
subgraph "Antywzorce" F[Brak Indeksów] --> G[Powolne Zapytania] H[SELECT *] --> G I[Brak LIMIT] --> G J[Znaki Wodne na Początku] --> G endNajlepsze Praktyki
Dział zatytułowany „Najlepsze Praktyki”- Zawsze ustaw LIMIT dla dużych tabel
- Używaj indeksów na kolumnach używanych w kryteriach
- Unikaj poprzedzających znaków wieloznacznych w LIKE (
'%term'jest powolny) - Pre-filtruj w PHP gdy to możliwe dla złożonej logiki
- Używaj COUNT ostrożnie - cachuj wyniki gdy to możliwe
Powiązana Dokumentacja
Dział zatytułowany „Powiązana Dokumentacja”- Warstwa Bazy Danych
- API XoopsObjectHandler
- Zapobieganie Wstrzykiwaniu SQL
#xoops #api #criteria #database #query #reference