Inhaltsverzeichnis
Antwortinhalt:
Heim Backend-Entwicklung PHP-Tutorial Wie sollte ich die Datenspeicherung auswählen, wenn ich eine Website mit einer sehr kleinen Anzahl von Benutzern erstellen möchte?

Wie sollte ich die Datenspeicherung auswählen, wenn ich eine Website mit einer sehr kleinen Anzahl von Benutzern erstellen möchte?

Aug 04, 2016 am 09:19 AM
php sql 数据 数据库

Ich möchte eine Website mit einer sehr kleinen Anzahl von Benutzern erstellen. Die Anzahl der Benutzer liegt zwischen einigen und mehr als einem Dutzend.
Das Backend verwendet PHP und jetzt möchte ich wissen, wie man Daten speichert.

Da die Anzahl der Benutzer sehr gering ist, fühlt sich die Verwendung von MySQL auch sehr niedrig an und kann die Leistung beeinträchtigen, da die Hostkonfiguration zu niedrig ist.

Ich habe darüber nachgedacht, es direkt in einer Datei zu speichern (die Daten haben eine relativ einfache Struktur und JSON kann damit umgehen), aber wenn es eine verwandte Abfrage gibt (z. B. den Join von MySQL), müssen Sie dafür PHP verwenden Die entsprechende Abfrage selbst ist etwas mühsam.

Gibt es einen besseren Weg? Wie eine superleichte Datenbank?

PS: Sie benötigen kein Redis, da die Hostkonfiguration niedrig und der Speicher definitiv knapp ist. Unternehmen wie MySQL und Redis, die hart daran arbeiten, Wunder zu vollbringen, können in einer so schlampigen Umgebung ihre Stärke nicht ausspielen.

Antwortinhalt:

Ich möchte eine Website mit einer sehr kleinen Anzahl von Benutzern erstellen. Die Anzahl der Benutzer liegt zwischen einigen und mehr als einem Dutzend.
Das Backend verwendet PHP und jetzt möchte ich wissen, wie man Daten speichert.

Da die Anzahl der Benutzer sehr gering ist, fühlt sich die Verwendung von MySQL auch sehr niedrig an und kann die Leistung beeinträchtigen, da die Hostkonfiguration zu niedrig ist.

Ich habe darüber nachgedacht, es direkt in einer Datei zu speichern (die Daten haben eine relativ einfache Struktur und JSON kann damit umgehen), aber wenn es eine verwandte Abfrage gibt (z. B. den Join von MySQL), müssen Sie dafür PHP verwenden Die entsprechende Abfrage selbst ist etwas mühsam.

Gibt es einen besseren Weg? Wie eine superleichte Datenbank?

PS: Sie benötigen kein Redis, da die Hostkonfiguration niedrig und der Speicher definitiv knapp ist. Unternehmen wie MySQL und Redis, die hart daran arbeiten, Wunder zu vollbringen, können in einer so schlampigen Umgebung ihre Stärke nicht ausspielen.

Verwenden Sie SQLite oder einfach Dateispeicherung. Wenn Dateispeicherung verwendet wird, sollten die Datendateien außerhalb des Webroots platziert werden.

Die richtige Antwort oben ist SQLite. Es ist leichtgewichtig und erfordert keine Dienste, sondern nur Dateien. Der Kunde des Projekts, an dessen Forschung und Entwicklung ich zuvor teilgenommen habe, ist SQLite

Es ist immer noch MySQL. Die Effizienz beim Lesen und Schreiben von Dateien ist geringer als bei der Verwendung von MySQL und wird beim Entwickeln besonders schwierig. Ich schlage vor, dass Sie es zuerst versuchen. Wird die Host-Konfiguration niedriger sein als die des Raspberry Pi? Wenn die Hostkonfiguration bereits niedrig ist, gibt es natürlich keine Möglichkeit, Windows zu installieren.

Wenn Sie mit ORM entwickeln, müssen Sie die Auswahl einer Datenbank in einem frühen Stadium nicht berücksichtigen.

Wenn Sie eine SQL-Entwicklung schreiben, müssen Sie berücksichtigen, dass die Datenbank in der Zukunft geändert wird. Das von Ihnen geschriebene SQL ist möglicherweise nicht kompatibel

Egal wie niedrig die Host-Konfiguration ist, sie ist nicht so übertrieben, wie Sie denken, MySQL und Postgres können definitiv ausgeführt werden

SQLite wird mit Erweiterungen geliefert. Obwohl die Funktionen und Datentypen viel einfacher sind als bei MySQL, sind die häufig verwendeten in Ordnung und die Leistung ist ebenfalls sehr gut.

Wenn Sie SQLite verwenden, platzieren Sie die Datendatei am besten nicht im Stammverzeichnis der Website, da die Leute sie sonst herunterladen, wenn sie die URL kennen.

Natürlich können Sie Apache/Nginx so konfigurieren, dass Anfragen abgelehnt werden um auf bestimmte Dateien zuzugreifen, aber es stellt immer noch eine versteckte Gefahr dar,
Deshalb ist es besser, es außerhalb des Stammverzeichnisses der Website zu platzieren.
Außerdem müssen Sie, wenn Sie SQLite verwenden, SQL-Sprache schreiben und verwenden Sie den PDO-Funktionssatz, um Folgendes auszuführen:

<code><?php

function db() {
    static $db;
    if ($db) {
        return $db;
    } else {
        try {
            $db = new PDO('sqlite:'.$_SERVER['DOCUMENT_ROOT'].'/../data.db3');
        } catch (PDOException $e) {
            echo $e->getMessage();
            exit();
        }
        return $db;
    }
}

function insert($title = '', $content = '') {
    global $app;
    $db = db();
    $stmt = $db->prepare('INSERT INTO posts (post_title, post_content) VALUES (?, ?)');
    $stmt->bindParam(1, $title,   PDO::PARAM_STR);
    $stmt->bindParam(2, $content, PDO::PARAM_STR);
    $stmt->execute();
    return ($stmt->rowCount() !== 0) ? 
        array(true,  'lastInsertId' => $db->lastInsertId()) : 
        array(false, 'lastInsertId' => $db->lastInsertId());
}

function select($id = '') {
    global $app;
    $db = db();
    if (!empty($id)) {
        return $db->query('SELECT * FROM posts WHERE id = '.intval($id))->fetchAll(PDO::FETCH_ASSOC);
    } else {
        return $db->query('SELECT * FROM posts')->fetchAll(PDO::FETCH_ASSOC);
    }
}

function select_v2($id = '') {
    global $app;
    $db = db();
    if (!empty($id)) {
        $stmt = $db->prepare('SELECT * FROM posts WHERE id = ?');
        $stmt->bindParam(1, $id, PDO::PARAM_INT);
    } else {
        $stmt = $db->prepare('SELECT * FROM posts');
    }
    $stmt->execute();
    return $stmt->fetchAll(PDO::FETCH_ASSOC);
}

function update($id, $title = '', $content = '') {
    global $app;
    $db = db();
    
    //echo PDO::ATTR_AUTOCOMMIT; //返回0可见PDO默认禁用自动提交事务.
    //echo $db->getAttribute(PDO::ATTR_AUTOCOMMIT); exit(); //返回1可见MySQL默认会自动提交事务.
    
    //SQLite不支持设置PDO::ATTR_AUTOCOMMIT:
    //SQLite: Uncaught exception 'PDOException' with message 'The auto-commit mode cannot be changed for this driver'
    //$db->setAttribute(PDO::ATTR_AUTOCOMMIT, false);
    $db->beginTransaction();
    $stmt = $db->prepare('UPDATE posts SET post_title = ?, post_content = ? WHERE id = ?');
    
    $stmt->execute(array($title,$content,$id)); //所有值视作PDO::PARAM_STR处理
    //$stmt->execute(array(':title' => $title,':content' => $content,':id' => $id));
    //$stmt->bind_param('ssi', $title, $content, $id); //对比mysqli
    
    echo 'sleep(3);'."\n";
    sleep(3);
    
    $db->commit();
    //$db->setAttribute(PDO::ATTR_AUTOCOMMIT, true); //commit提交事务后autocommit记得重新设为true
    return ($stmt->rowCount() !== 0) ? true : false;
}

function delete($id) {
    global $app;
    $db = db();
    return ($db->query('DELETE FROM posts WHERE id = '.intval($id))->rowCount() !== 0) ? true : false;
}

function delete_v2($id) {
    global $app;
    $db = db();
    $stmt = $db->prepare('DELETE FROM posts WHERE id = ?');
    $stmt->bindParam(1, $id, PDO::PARAM_INT);
    $stmt->execute();
    return ($stmt->rowCount() !== 0) ? true : false;
}

header('Content-Type: text/plain; charset=utf-8');

$sqlite = "CREATE TABLE IF NOT EXISTS posts (
    id           INTEGER PRIMARY KEY,
    post_title   VARCHAR(255) NOT NULL,
    post_content TEXT         NOT NULL
)";

db()->query('DROP TABLE IF EXISTS posts;') or exit();
db()->query($sqlite) or exit();

//并发时,SQLite在insert时因为库文件被其他请求锁住而导致阻塞
echo "var_export(insert('标题1', '内容1'));\n";
var_export(insert('标题1', '内容1'));
echo "\n\n";

echo "var_export(insert('标题2', '内容2'));\n";
var_export(insert('标题2', '内容2'));
echo "\n\n";

echo "var_export(select());\n";
var_export(select());
echo "\n\n";

echo "var_export(update(2, '标题2_更新','内容2_更新'));\n";
var_export(update(2, '标题2_更新','内容2_更新'));
echo "\n\n";

echo "var_export(select(2));\n";
var_export(select(2));
echo "\n\n";

echo "var_export(delete(2));\n";
var_export(delete(2));
echo "\n\n";

echo "var_export(select());\n";
var_export(select());
echo "\n\n";</code>
Nach dem Login kopieren
Ich frage mich, ob Sie über eine solche Erfahrung verfügen. PHP ist eigentlich eine Array-orientierte Programmiersprache.

Tatsächlich können Sie erwägen, PHP-Arrays direkt in Dateien zu exportieren, um Daten zu speichern.

<code><?php
header('Content-Type: text/plain; charset=utf-8');
$file = __DIR__.'/data.php'; //数据文件,别人直接URL访问也下载不了
if(!file_exists($file)) {
    file_put_contents($file, '<?php return array();'); //file_put_contents($file, '');
}
$fp = fopen($file, 'r+'); //读写方式打开,将文件指针指向文件头
if(flock($fp, LOCK_EX)) { //阻塞到获取排它锁
    //锁定数据文件后再进行读写
    $arr = require $file; //$arr = unserialize(file_get_contents($file));
    $arr[] = date('Y-m-d H:i:s');
    ftruncate($fp, 0); //清空文件
    fwrite($fp, '<?php return '.var_export($arr, true).';'); //fwrite($fp, serialize($arr));
    fflush($fp); //在释放锁之前刷新输出
    //sleep(10); //睡眠10秒,在此期间其他工作进程的请求将被阻塞
    flock($fp, LOCK_UN); //释放锁定
    echo file_get_contents($file)."\n";
}
fclose($fp);</code>
Nach dem Login kopieren
Die Kommentare bieten auch Methoden zum Serialisieren/Unserialisieren von serialisiertem Speicher wie PHP-Sitzungen.

Es ist erwähnenswert, dass die Leistung von Serialize/Unserialize viel besser ist als die von var_export/require.
Aber var_export/ Der Vorteil von require ist, dass es keine Angst vor dem direkten Zugriff durch andere hat, die Datei im Stammverzeichnis ablegen kann und besser lesbar ist.

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Java-Tutorial
1662
14
PHP-Tutorial
1261
29
C#-Tutorial
1234
24
PHP und Python: Vergleich von zwei beliebten Programmiersprachen PHP und Python: Vergleich von zwei beliebten Programmiersprachen Apr 14, 2025 am 12:13 AM

PHP und Python haben jeweils ihre eigenen Vorteile und wählen nach den Projektanforderungen. 1.PHP ist für die Webentwicklung geeignet, insbesondere für die schnelle Entwicklung und Wartung von Websites. 2. Python eignet sich für Datenwissenschaft, maschinelles Lernen und künstliche Intelligenz mit prägnanter Syntax und für Anfänger.

PHP in Aktion: Beispiele und Anwendungen in realer Welt PHP in Aktion: Beispiele und Anwendungen in realer Welt Apr 14, 2025 am 12:19 AM

PHP wird in E-Commerce, Content Management Systems und API-Entwicklung häufig verwendet. 1) E-Commerce: Wird für die Einkaufswagenfunktion und Zahlungsabwicklung verwendet. 2) Content -Management -System: Wird für die Erzeugung der dynamischen Inhalte und die Benutzerverwaltung verwendet. 3) API -Entwicklung: Wird für die erholsame API -Entwicklung und die API -Sicherheit verwendet. Durch Leistungsoptimierung und Best Practices werden die Effizienz und Wartbarkeit von PHP -Anwendungen verbessert.

Php gegen andere Sprachen: Ein Vergleich Php gegen andere Sprachen: Ein Vergleich Apr 13, 2025 am 12:19 AM

PHP eignet sich für die Webentwicklung, insbesondere für die schnelle Entwicklung und Verarbeitung dynamischer Inhalte, ist jedoch nicht gut in Anwendungen auf Datenwissenschaft und Unternehmensebene. Im Vergleich zu Python hat PHP mehr Vorteile in der Webentwicklung, ist aber nicht so gut wie Python im Bereich der Datenwissenschaft. Im Vergleich zu Java wird PHP in Anwendungen auf Unternehmensebene schlechter, ist jedoch flexibler in der Webentwicklung. Im Vergleich zu JavaScript ist PHP in der Back-End-Entwicklung präziser, ist jedoch in der Front-End-Entwicklung nicht so gut wie JavaScript.

Die dauerhafte Relevanz von PHP: Ist es noch am Leben? Die dauerhafte Relevanz von PHP: Ist es noch am Leben? Apr 14, 2025 am 12:12 AM

PHP ist immer noch dynamisch und nimmt immer noch eine wichtige Position im Bereich der modernen Programmierung ein. 1) Einfachheit und leistungsstarke Unterstützung von PHP machen es in der Webentwicklung weit verbreitet. 2) Seine Flexibilität und Stabilität machen es ausstehend bei der Behandlung von Webformularen, Datenbankoperationen und Dateiverarbeitung; 3) PHP entwickelt sich ständig weiter und optimiert, geeignet für Anfänger und erfahrene Entwickler.

PHP und Python: Code Beispiele und Vergleich PHP und Python: Code Beispiele und Vergleich Apr 15, 2025 am 12:07 AM

PHP und Python haben ihre eigenen Vor- und Nachteile, und die Wahl hängt von den Projektbedürfnissen und persönlichen Vorlieben ab. 1.PHP eignet sich für eine schnelle Entwicklung und Wartung großer Webanwendungen. 2. Python dominiert das Gebiet der Datenwissenschaft und des maschinellen Lernens.

Zweck von PHP: Erstellen dynamischer Websites Zweck von PHP: Erstellen dynamischer Websites Apr 15, 2025 am 12:18 AM

PHP wird verwendet, um dynamische Websites zu erstellen. Zu den Kernfunktionen gehören: 1. Dynamische Inhalte generieren und Webseiten in Echtzeit generieren, indem Sie eine Verbindung mit der Datenbank herstellen; 2. Verarbeiten Sie Benutzerinteraktions- und Formulareinreichungen, überprüfen Sie Eingaben und reagieren Sie auf Operationen. 3. Verwalten Sie Sitzungen und Benutzerauthentifizierung, um eine personalisierte Erfahrung zu bieten. 4. Optimieren Sie die Leistung und befolgen Sie die Best Practices, um die Effizienz und Sicherheit der Website zu verbessern.

PHP und Python: Verschiedene Paradigmen erklärt PHP und Python: Verschiedene Paradigmen erklärt Apr 18, 2025 am 12:26 AM

PHP ist hauptsächlich prozedurale Programmierung, unterstützt aber auch die objektorientierte Programmierung (OOP). Python unterstützt eine Vielzahl von Paradigmen, einschließlich OOP, funktionaler und prozeduraler Programmierung. PHP ist für die Webentwicklung geeignet, und Python eignet sich für eine Vielzahl von Anwendungen wie Datenanalyse und maschinelles Lernen.

PHP: Datenbanken und serverseitige Logik bearbeiten PHP: Datenbanken und serverseitige Logik bearbeiten Apr 15, 2025 am 12:15 AM

PHP verwendet MySQLI- und PDO-Erweiterungen, um in Datenbankvorgängen und serverseitiger Logikverarbeitung zu interagieren und die serverseitige Logik durch Funktionen wie Sitzungsverwaltung zu verarbeiten. 1) Verwenden Sie MySQLI oder PDO, um eine Verbindung zur Datenbank herzustellen und SQL -Abfragen auszuführen. 2) Behandeln Sie HTTP -Anforderungen und Benutzerstatus über Sitzungsverwaltung und andere Funktionen. 3) Verwenden Sie Transaktionen, um die Atomizität von Datenbankvorgängen sicherzustellen. 4) Verhindern Sie die SQL -Injektion, verwenden Sie Ausnahmebehandlung und Schließen von Verbindungen zum Debuggen. 5) Optimieren Sie die Leistung durch Indexierung und Cache, schreiben Sie hochlesbarer Code und führen Sie die Fehlerbehandlung durch.

See all articles