PHP somo la 97: Jinsi ya kuchakata data zaidi kwa kutumia ORM

PHP somo la 97: Jinsi ya kuchakata data zaidi kwa kutumia ORM

Katika somo hili utakwenda kujifunz akuchakata data zaidi kw akutumia ORM kama ku join table

Download Post hii hapa

Hapa ni hatua za kuunda somo linalofuata kwa ajili ya kuongeza jedwali la transactions pamoja na faili la transactions.php ili kuonyesha orodha ya wateja na bidhaa walizonunua pamoja na bei zao.

Hatua 1: Kuingiza Jedwali la transactions kwenye Hifadhidata

Kwanza, tutahitaji kuunda jedwali jipya la transactions kwenye hifadhidata yako. Jedwali hili litakuwa na uhusiano (foreign keys) kwa jedwali la customers na products ili kurekodi bidhaa na wateja wanaohusiana.

CREATE TABLE transactions (
    id INT AUTO_INCREMENT PRIMARY KEY,
    customer INT NOT NULL,
    product INT NOT NULL,
    created TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    FOREIGN KEY (customer) REFERENCES customers(id),
    FOREIGN KEY (product) REFERENCES products(id)
);

Maelezo ya Fields:

Hatua 2: Kuunda Faili la transactions.php

Sasa tutaunda faili la transactions.php ambalo litachukua taarifa za wateja na bidhaa walizonunua pamoja na bei zao. Kwenye faili hili, tutachukua taarifa kutoka kwenye jedwali la transactions na kuonyesha orodha ya wateja na bidhaa walizonunua.

<?php
require_once 'dbclass.php';
require_once "model.php";

// Anza ORM kwa ajili ya transactions
$transactionORM = new Model('transactions');
$productORM = new Model('products');
$customerORM = new Model('customers');
$error = "";

// Pata transactions zote
$transactions = $transactionORM->all();

?>

<!DOCTYPE html>
<html lang="sw">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Orodha ya Miamala</title>
</head>
<body>

<h2>Orodha ya Miamala</h2>
<?php if (!empty($transactions)): ?>
    <table border="1">
        <tr>
            <th>ID ya Transaction</th>
            <th>Jina la Mteja</th>
            <th>Jina la Bidhaa</th>
            <th>Bei</th>
            <th>Tarehe</th>
        </tr>
        <?php foreach ($transactions as $transaction): ?>
            <?php
                // Pata mteja na bidhaa kwa kutumia IDs
                $customer = $customerORM->find($transaction['customer']);
                $product = $productORM->find($transaction['product']);
            ?>
            <tr>
                <td><?= htmlspecialchars($transaction['id']); ?></td>
                <td><?= htmlspecialchars($customer['name']); ?></td>
                <td><?= htmlspecialchars($product['name']); ?></td>
                <td><?= htmlspecialchars($product['price']); ?></td>
                <td><?= htmlspecialchars($transaction['created']); ?></td>
            </tr>
        <?php endforeach; ?>
    </table>
<?php else: ?>
    <p>Hakuna miamala iliyorekodiwa.</p>
<?php endif; ?>

</body>
</html>

Maelezo ya Code:

  1. ORM kwa Transactions, Customers, na Products: Tumetumia ORM kwa transactions, customers, na products ili tupate taarifa za wateja na bidhaa zinazohusiana na transaction.

  2. Pata Miamala: Tunachukua taarifa zote za miamala kutoka kwenye jedwali la transactions kwa kutumia $transactionORM->all().

  3. Pata Mteja na Bidhaa kwa ID: Kwa kila transaction, tunatumia IDs za mteja na bidhaa ili kupata majina yao kutoka kwenye jedwali la customers na products.

  4. Onyesha Orodha ya Miamala: Tunatengeneza meza ili kuonyesha ID ya Transaction, Jina la Mteja, Jina la Bidhaa, Bei ya Bidhaa, na Tarehe ya Transaction.

  5. Ujumbe wa Makosa: Ikiwa hakuna miamala iliyorekodiwa, itaonyesha ujumbe wa "Hakuna miamala iliyorekodiwa."

Hatua 3: Kuhakikisha Uhusiano Kati ya Jedwali la transactions, products, na customers

Hakikisha kuwa unatumia foreign keys ili kuunganisha jedwali la transactions na ya products na customers kwa kutumia IDs. Hii itahakikisha kuwa data ya miamala ni sahihi na ina uhusiano na bidhaa na wateja waliopo kwenye hifadhidata yako.

Hatua 4: Kuongeza Miamala

Katika sehemu ya kuongeza miamala, tunaweza kutoa fomu ya kuongeza miamala, ambapo mteja atachagua bidhaa na itarekodiwa kwenye jedwali la transactions.

<?php
// Kushughulikia fomu ya kuongeza transaction
if ($_SERVER["REQUEST_METHOD"] === "POST" && isset($_POST['action']) && $_POST['action'] === 'create') {
    $customer_id = $_POST['customer_id'];
    $product_id = $_POST['product_id'];

    if (!empty($customer_id) && !empty($product_id)) {
        $data = [
            'customer' => $customer_id,
            'product' => $product_id
        ];

        if ($transactionORM->create($data)) {
            header("Location: transactions.php");
            exit();
        } else {
            $error = "Imeshindikana kuongeza transaction.";
        }
    } else {
        $error = "Tafadhali chagua mteja na bidhaa.";
    }
}
">
...

Download Post hii hapa

Jiunge nasi WhatsApp
Upate Update zetu

Download App Yetu

Jifunze zaidi, na wasiliana nasi ukiwa na App yetu. Bofya link hapo chini kuweza kuipakua.

Download Now Bongoclass Zoezi la Maswali

Nyuma Endelea


Umeionaje Makala hii.. ?

Nzuri            Mbaya            Save
Author: Rajabu image Tarehe: 1970-01-01 03:33:45 Topic: PHP Main: ICT File: Download PDF Views 168

Share On:

Facebook WhatsApp
Sponsored links
👉1 Kitau cha Fiqh    👉2 Simulizi za Hadithi Audio    👉3 Sira ya Mtume Muhammad (s.a.w)    👉4 Kitabu cha Afya    👉5 kitabu cha Simulizi    👉6 Madrasa kiganjani   

Post zinazofanana:

PHP somo la 50: Jinsi ya kutengeneza CLASS na OBJECT kwenye PHP OOP
PHP somo la 50: Jinsi ya kutengeneza CLASS na OBJECT kwenye PHP OOP

Katika somo hili utakwenda kujifunza jinsi ya kutengeneza class na object. Tunakwenda kutumia mfano wetu wa hapo juu kwa ajili ya kukamilisha somo hili.

Soma Zaidi...
PHP - somo la 43: Jinsi ya kutuma email kwa kutumia PHP
PHP - somo la 43: Jinsi ya kutuma email kwa kutumia PHP

Katika somo hili utajifunza jinsi ya kutuma email kwa kutumia email() function ya PHP. Hii ni njia rahisi zaidi ya kutuma email. Ila hufanya kazi kwenye hosting.

Soma Zaidi...
PHP - somo la 35: Jinsi ya ku upload mafaili kwa kutumia PHP
PHP - somo la 35: Jinsi ya ku upload mafaili kwa kutumia PHP

Katika somo hili utakwenda kujifunza jinsi ya ku upload mafaili kwenye server kwa kutumia PHP

Soma Zaidi...
PHP somo la 83: Server Variables
PHP somo la 83: Server Variables

Katika somo hili utakwend akujifunza kuhusu server variables

Soma Zaidi...
PHP - somo la 22: Kutafuta jumla, wastani na idani ya vitu kwenye database kw akutumia PHP
PHP - somo la 22: Kutafuta jumla, wastani na idani ya vitu kwenye database kw akutumia PHP

Katika somo hili utakwenda jifunza jinsi ya kuhesabu row kwenye database, kutafuta wastani wa taarifa kwenye database na kutafuta idadi yake.

Soma Zaidi...
PHP somo la 90: Jinsi ya kutumia json data kama blog post
PHP somo la 90: Jinsi ya kutumia json data kama blog post

Katika somo hili utaweza kujifunza ni kwa nambna gani utaweza kutengeneza blog post na kuisoma kwa kutumia data za json

Soma Zaidi...
PHP somo la 96: Jinsi ya kutengeneza ORM inayofanya CDRUDE operation
PHP somo la 96: Jinsi ya kutengeneza ORM inayofanya CDRUDE operation

Katika somo hili utakwenda Jinsi ya kutengeneza ORM inayofanya CDRUDE operation.

Soma Zaidi...
PHP - somo la 46: Nini maana ya cronjob na matumizi yake
PHP - somo la 46: Nini maana ya cronjob na matumizi yake

Katika somo hili utajifunza kuhusu cronjob na matumizi yake kwenye PHP

Soma Zaidi...
PHP -somo la 33: Matumizi ya while loop kwenye PHP
PHP -somo la 33: Matumizi ya while loop kwenye PHP

Katika somo hili utajifunza jinsi ya kuandika while loop kwenye PHP

Soma Zaidi...
PHP somo la 79: Custom header
PHP somo la 79: Custom header

Katika somo hili utakwenda kuhifunza kuhusu Custom header na aina zake

Soma Zaidi...