เกณฑ์ API อ้างอิง
กรอกเอกสาร API สำหรับระบบการสร้างแบบสอบถามเกณฑ์ XOOPS
สถาปัตยกรรมระบบเกณฑ์
หัวข้อที่มีชื่อว่า “สถาปัตยกรรมระบบเกณฑ์”mermaidclassDiagram 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 : containsระดับเกณฑ์
หัวข้อที่มีชื่อว่า “ระดับเกณฑ์”ตัวสร้าง
หัวข้อที่มีชื่อว่า “ตัวสร้าง”public function __construct( string $column, // Column name mixed $value = '', // Value to compare string $operator = '=', // Comparison operator string $prefix = '', // Table prefix string $function = '' // SQL function wrapper)ผู้ประกอบการ
หัวข้อที่มีชื่อว่า “ผู้ประกอบการ”| ตัวดำเนินการ | ตัวอย่าง | 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 |
ตัวอย่างการใช้งาน
หัวข้อที่มีชื่อว่า “ตัวอย่างการใช้งาน”// Simple equality$criteria = new Criteria('status', 'published');
// Numeric comparison$criteria = new Criteria('views', 100, '>=');
// Pattern matching$criteria = new Criteria('title', '%XOOPS%', 'LIKE');
// With table prefix$criteria = new Criteria('uid', 1, '=', 'u');// Renders: u.uid = 1
// With SQL function$criteria = new Criteria('title', '', '!=', '', 'LOWER');// Renders: LOWER(title) != ''คลาส CriteriaCompo
หัวข้อที่มีชื่อว่า “คลาส CriteriaCompo”ตัวสร้างและวิธีการ
หัวข้อที่มีชื่อว่า “ตัวสร้างและวิธีการ”// Create empty compo$criteria = new CriteriaCompo();
// Or with initial criteria$criteria = new CriteriaCompo(new Criteria('status', 'active'));
// Add criteria (AND by default)$criteria->add(new Criteria('views', 10, '>='));
// Add with OR$criteria->add(new Criteria('featured', 1), 'OR');
// Nesting$subCriteria = new CriteriaCompo();$subCriteria->add(new Criteria('author', 1));$subCriteria->add(new Criteria('author', 2), 'OR');$criteria->add($subCriteria); // (author = 1 OR author = 2)การเรียงลำดับและการแบ่งหน้า
หัวข้อที่มีชื่อว่า “การเรียงลำดับและการแบ่งหน้า”$criteria = new CriteriaCompo();$criteria->add(new Criteria('status', 'published'));
// Single sort$criteria->setSort('created');$criteria->setOrder('DESC');
// Multiple sort columns$criteria->setSort('category_id, created');$criteria->setOrder('ASC, DESC');
// Pagination$criteria->setLimit(10); // Items per page$criteria->setStart(0); // Offset (page * limit)
// Group by$criteria->setGroupby('category_id');แบบสอบถามการสร้างโฟลว์
หัวข้อที่มีชื่อว่า “แบบสอบถามการสร้างโฟลว์”mermaidflowchart TD A[Create CriteriaCompo] --> B[Add Criteria] B --> C{More Conditions?} C -->|Yes| B C -->|No| D[Set Sort/Order] D --> E[Set Limit/Start] E --> F[Pass to Handler] F --> G[Handler calls render] G --> H[Generate SQL WHERE] H --> I[Execute Query] I --> J[Return Results]ตัวอย่างแบบสอบถามที่ซับซ้อน
หัวข้อที่มีชื่อว่า “ตัวอย่างแบบสอบถามที่ซับซ้อน”ค้นหาด้วยเงื่อนไขหลายข้อ
หัวข้อที่มีชื่อว่า “ค้นหาด้วยเงื่อนไขหลายข้อ”$criteria = new CriteriaCompo();
// Status must be published$criteria->add(new Criteria('status', 'published'));
// Category is 1, 2, or 3$criteria->add(new Criteria('category_id', '(1, 2, 3)', 'IN'));
// Created in last 30 days$thirtyDaysAgo = time() - (30 * 24 * 60 * 60);$criteria->add(new Criteria('created', $thirtyDaysAgo, '>='));
// Search term in title OR content$searchCriteria = new CriteriaCompo();$searchCriteria->add(new Criteria('title', '%' . $searchTerm . '%', 'LIKE'));$searchCriteria->add(new Criteria('content', '%' . $searchTerm . '%', 'LIKE'), 'OR');$criteria->add($searchCriteria);
// Sort by views descending$criteria->setSort('views');$criteria->setOrder('DESC');
// Paginate$criteria->setLimit($perPage);$criteria->setStart($page * $perPage);
// Execute$items = $itemHandler->getObjects($criteria);$total = $itemHandler->getCount($criteria);แบบสอบถามช่วงวันที่
หัวข้อที่มีชื่อว่า “แบบสอบถามช่วงวันที่”$criteria = new CriteriaCompo();
// Between two dates$startDate = strtotime('2024-01-01');$endDate = strtotime('2024-12-31');
$criteria->add(new Criteria('created', $startDate, '>='));$criteria->add(new Criteria('created', $endDate, '<='));
// Or using BETWEEN$criteria->add(new Criteria('created', "$startDate AND $endDate", 'BETWEEN'));ตัวกรองการอนุญาตของผู้ใช้
หัวข้อที่มีชื่อว่า “ตัวกรองการอนุญาตของผู้ใช้”$criteria = new CriteriaCompo();$criteria->add(new Criteria('status', 'published'));
// If not admin, only show own items or publicif (!$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);}แบบสอบถามแบบเข้าร่วม
หัวข้อที่มีชื่อว่า “แบบสอบถามแบบเข้าร่วม”// Get items where category is active// (Using subquery approach)$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'));}เกณฑ์สำหรับ SQL การแสดงภาพ
หัวข้อที่มีชื่อว่า “เกณฑ์สำหรับ SQL การแสดงภาพ”mermaidgraph LR subgraph "PHP Code" A["new Criteria('status', 'published')"] B["new Criteria('views', 100, '>=')"] C["CriteriaCompo with A + B"] end
subgraph "Generated SQL" D["status = 'published'"] E["views >= 100"] F["WHERE status = 'published' AND views >= 100"] end
A --> D B --> E C --> Fบูรณาการตัวจัดการ
หัวข้อที่มีชื่อว่า “บูรณาการตัวจัดการ”// Standard handler methods that accept Criteria
// Get multiple objects$objects = $handler->getObjects($criteria);$objects = $handler->getObjects($criteria, true); // As array$objects = $handler->getObjects($criteria, true, true); // As array, id as key
// Get count$count = $handler->getCount($criteria);
// Get list (id => identifier)$list = $handler->getList($criteria);
// Delete matching$deleted = $handler->deleteAll($criteria);
// Update matching$handler->updateAll('status', 'archived', $criteria);ข้อควรพิจารณาด้านประสิทธิภาพ
หัวข้อที่มีชื่อว่า “ข้อควรพิจารณาด้านประสิทธิภาพ”mermaidgraph TB subgraph "Optimization Tips" A[Use Indexes] --> E[Faster Queries] B[Limit Results] --> E C[Avoid LIKE '%...'] --> E D[Use Specific Columns] --> E end
subgraph "Anti-Patterns" F[No Indexes] --> G[Slow Queries] H[SELECT *] --> G I[No LIMIT] --> G J[Leading Wildcards] --> G endแนวทางปฏิบัติที่ดีที่สุด
หัวข้อที่มีชื่อว่า “แนวทางปฏิบัติที่ดีที่สุด”- ตั้งค่า LIMIT เสมอสำหรับตารางขนาดใหญ่
- ใช้ดัชนี ในคอลัมน์ที่ใช้ในเกณฑ์
- หลีกเลี่ยงการใช้ไวด์การ์ดนำหน้า ใน LIKE (
'%term'ช้า) - กรองล่วงหน้าใน PHP เมื่อเป็นไปได้สำหรับตรรกะที่ซับซ้อน
- ใช้ COUNT เท่าที่จำเป็น - แคชผลลัพธ์เมื่อเป็นไปได้
เอกสารที่เกี่ยวข้อง
หัวข้อที่มีชื่อว่า “เอกสารที่เกี่ยวข้อง”- ชั้นฐานข้อมูล
- XoopsObjectHandler API
- SQL การป้องกันการฉีด
#xoops #api #criteria #database #query #reference