Hallo, Gast
Du musst dich registrieren bevor du auf unserer Seite Beiträge schreiben kannst.

Benutzername
  

Passwort
  





Durchsuche Foren

(Erweiterte Suche)

Foren-Statistiken
» Mitglieder: 1
» Neuestes Mitglied: Joopi
» Foren-Themen: 500
» Foren-Beiträge: 696

Komplettstatistiken

Benutzer Online
Momentan sind 8 Benutzer online
» 0 Mitglieder
» 4 Gäste
AhrefsBot, Crawl, DotBot, bot

Aktive Themen
Tuesday - 22:00 CST: Not ...
Forum: Wetter in Little Rock
Letzter Beitrag: Joopi
Vor 2 Stunden
» Antworten: 0
» Ansichten: 2
Tuesday - 14:00 CST: Not ...
Forum: Wetter in Little Rock
Letzter Beitrag: Joopi
Vor 10 Stunden
» Antworten: 0
» Ansichten: 2
Tuesday - 09:00 CST: Not ...
Forum: Wetter in Little Rock
Letzter Beitrag: Joopi
Gestern, 07:17
» Antworten: 0
» Ansichten: 3
Tuesday - 02:00 CST: Not ...
Forum: Wetter in Little Rock
Letzter Beitrag: Joopi
Gestern, 12:33
» Antworten: 0
» Ansichten: 6
Monday - 17:00 CST: Not a...
Forum: Wetter in Little Rock
Letzter Beitrag: Joopi
Gestern, 02:40
» Antworten: 0
» Ansichten: 5
Monday - 09:00 CST: Not a...
Forum: Wetter in Little Rock
Letzter Beitrag: Joopi
20-01-2025, 06:47
» Antworten: 0
» Ansichten: 7
Sunday - 22:00 CST: Not a...
Forum: Wetter in Little Rock
Letzter Beitrag: Joopi
20-01-2025, 07:41
» Antworten: 0
» Ansichten: 7
Sunday - 14:00 CST: Not a...
Forum: Wetter in Little Rock
Letzter Beitrag: Joopi
19-01-2025, 11:44
» Antworten: 0
» Ansichten: 7
Saturday - 23:00 CST: Not...
Forum: Wetter in Little Rock
Letzter Beitrag: Joopi
19-01-2025, 08:38
» Antworten: 0
» Ansichten: 5
Saturday - 14:00 CST: Not...
Forum: Wetter in Little Rock
Letzter Beitrag: Joopi
19-01-2025, 12:19
» Antworten: 0
» Ansichten: 8

 
  DB-Abfragen in Funktionen auslagern
Geschrieben von: Joopi - 07-01-2023, 10:44 - Forum: Programmieren - Keine Antworten

Endlich habe ich es nicht nur geschafft, dass ich Datenbankabfragen in externe Scripte auslagere, sondern ich habe es zudem auch endlich mal begriffen.

Bislang schreibe ich immer alles in ein PHP-Script. Nur die Zugangsdaten für die Datenbankabfrage habe ich bereits vor Jahren ausgelagert und greife über eine include-Anweisung darauf zu.

Nun habe ich zwei weitere Scripte, neben dem DB-Include, erstellt. Im ersten Script wird die Datenbankverbindung aufgebaut, im zweiten Script werden die Datenbankabfragen innerhalb von Funktionen durchgeführt.

Die Funktionsergebnisse kann ich dann im Hauptscript nutzen. Dadurch wird das Hauptscript übersichtlicher.

Mein Vorgehen kommt aus der prozdualen Ecke. Die liegt mir mehr als die objektorientierte Methode. Mir liegt es nicht an Geschwindigkeit, sondern eher am einfachen Erstellen weiterer Script in anderen Projekten.

Und ich bin mir sicher, dass ich noch mehr auslagern kann und der geneigte Fachmann mal wieder einen Schenkelklopfer loslässt. Das ist mir aber egal. Ich habe endlich das, was ich seit langer Zeit brauche. Erweiterungen und Verfeinerungen können irgendwann angeflanscht werden.

Insgesamt gibt es also 4 Scriptdateien:

Datenbankzugangsparameter

PHP-Code:
<?php
    
/* Zugangsparameter */
    $host "localhost";
    $user "user";
    $pwd "passwort";
    /* Datenbanken */
    $dbname001="datenbank";
    /* Tabellen */
    $tblname001="user";
    $tblname002="userdetail";
    $tblname003="session";
?>

Datenbankverbindungsaufbau

PHP-Code:
<?php
    
include("db_connect.inc.php");

    $db mysqli_connect($host$user$pwd$dbname004);

    if(!$db) {
        exit("Verbindungsfehler: ".mysqli_connect_error());
    }
?>

Datenbankfunktionen

PHP-Code:
<?php
    
// Der spätere Aufruf ist: php php_test_funktion_slave.php

    $query_vg 0;

    // Definition der Funktion, wobei die DB-Verbindung ausgelagert wurde.
    function vorgang($db){
        include("php_test_funktion_db.php");
        $query_vg mysqli_query($db"SELECT id, mailadresse, vorname FROM $tblname021 WHERE id >= 35");
        return $query_vg;
    }
?>

Mainscript mit Nutzung der Funktionsergebnissen

PHP-Code:
<?php
    error_reporting
(E_ALL);

    include("php_test_dbfunktion.php");

    // Aufnahme des Funktionsergebnisses
    $result_vg vorgang($query_vg);

    // Ausgabe des Funktionsergebnisses
    while($row_vg mysqli_fetch_row($result_vg)) {
        echo "<p>Das ist die ID: " $row_vg[0] . "</p>\n";
    }
?>

Ich bin derzeit sehr zufrieden, dass ich nun endlich die Datenbeschaffung und die Datenverwendung trennen kann. Immer alles in einem Script abzuhandeln ist besonders bei umfangreichen Projekten und Scripten sehr anstrengend. Hier kann ich nun sehr viel Übersicht gewinnen und die Pflege des Programmcodes optimieren.

Diese Funktionen setze ich nur auf dem lokalen Rechner ein. Auf meinen externen Webspaces habe ich Datenbanken und damit verbundene Abfragen auf ein Minimum reduziert. Das Umschreiben dieser Script spare ich mir derzeit, bis ich mehr weiß und mehr Sicherheit im Umgang mit derartigem Vorgehen habe.

Drucke diesen Beitrag

  Auswertung von stdClass
Geschrieben von: Joopi - 07-01-2023, 10:36 - Forum: Programmieren - Keine Antworten

Über eine foreach-Schleife ist es relativ einfach ein assoziatives Array auszugeben. Standardmäßig könnte es so aussehen:


PHP-Code:
<?php
    
// Aufnahme der Daten einer IMAP-Verbindung in eine Variable, die ein assoziatives Array speichert
    
$imap imap_check($mbox);

    
// Ausgabe des assoziativen Array mit seinen Properties für key und value
    
foreach ($imap as $detailkey => $detailwert) {
        echo $detailkey .": " $detailwert "\n";
    }
?>

Die Ausgabe von var_dump() sieht so aus:

Zitat:object(stdClass)#1 (5) {
  ["Date"]=>
  string(37) "Tue, 11 Jan 2022 16:36:02 +0100 (CET)"
  ["Driver"]=>
  string(4) "imap"
  ["Mailbox"]=>
  string(94) "{das sind die Verbindungsinformationen und daher nicht für die Öffentlichkeit bestimmt}INBOX"
  ["Nmsgs"]=>
  int(10)
  ["Recent"]=>
  int(0)
}

Mein Problem war nun, dass mich im Grunde genommen nur die Anzahl der im Postfach vorhandenen Mails interessiert hat. Kann man auf anderem Wege ebenfalls ermitteln, aber mit imap_check wollte ich es einfach versuchen. Das Schlüsselfeld dazu ist: Nmsgs

Es hat einige Zeit gedauert, bis mir klar war, wie ich diesen einen Wert herausholen kann, ohne alle anderen Werte auch aufzulisten oder zu erhalten. Die Anzahl der Mails brauche ich für eine for-Schleife, also muss ich diesen Wert separieren. Das ganze Array nützt mir nichts und ist hinderlich.

Letztlich ist es recht einfach, wenn man weiß, mit was man es zu tun hat. Die Codezeile, die mir den gewünschten Wert präsentiert, ist.

PHP-Code:
<?php echo "Das ist die Anzahl der enthaltenen Mails: " $imap->Nmsgs "\n"?>

Da es sich, soweit ich das verstanden habe, bei stdClass um ein Objekt handelt, muss ich hier anders vorgehen als ich es eigentlich gewohnt bin. Objekte sind auch in anderer Hinsicht und in anderen Vorhaben noch nicht meine Freunde - es wird aber so langsam.

Als Ergebnis der obigen Codezeile wird dann folgendes ausgegeben.

Zitat:Das ist die Anzahl der enthaltenen Mails: 10

Und damit ist der Wert für die Anzahl der Mails im Postfach ermittelt und kann im nachfolgenden Programmcode genutzt werden. Die Übernahme in eine Variable ist dann auch für mich recht einfach.

Drucke diesen Beitrag

  PHP auf Konsole ausführen
Geschrieben von: Joopi - 07-01-2023, 10:32 - Forum: Programmieren - Keine Antworten

Es ist mögich, ein PHP-Script (oder eine PHP-Befehlszeile) auf der Konsole bzw. in einem Shellscript auszuführen.

Das ist der Inhalt des PHP-Scripts:

PHP-Code:
<?php echo "Hallo Welt auf der Konsole!\n"?>

Folgender Befehl auf der Konsole führt ein PHP-Script aus:

Code:
php hallo_welt_konsole.php

Das Ergebnis ist wie folgt (steht so im PHP-Script):

Zitat:Hallo Welt auf der Konsole!

Drucke diesen Beitrag

  Array ausgeben
Geschrieben von: Joopi - 07-01-2023, 10:31 - Forum: Programmieren - Keine Antworten

Wer sich mit der Programmierung beschäftigt, kommt über kurz oder lang mit dem Datentyp ARRAY in Berührung. Egal in welcher Programmiersprache man unterwegs ist, das Array ist ein sehr wichtiges Instrument. Und ich tue mich damit von Anbeginn an schwer - also seit Jahrzehnten.

Ich habe immer Arrays genutzt, aber nie wirklich verstanden und einfach nur aus Vorlagen abgeschrieben. Oftmals musste ich lange daran herumfummeln, um die Syntax für mich gängig zu machen und ein brauchbares sowie richtiges Ergebnis zu erzielen.

Nun habe ich in PHP ein bisschen probiert. Dieses Ausprobieren hat nicht im Browser stattgefunden, sondern ich habe kleine PHP-Scripte geschrieben und diese auf der Konsole ausführen lassen. Somit musste ich mich nicht mit der Ausgabe via PHP-/HTML-Auszeichnungen befassen, sondern konnte mich auf die reine Syntax und die selbstgestellte Aufgabe konzentrieren.

Als erstes ist es wichtig zu wissen, in welcher Schreibweise ein bereits gefülltes Array im Programmcode zu nutzen ist. Es gibt verschiedene Möglichkeiten, um ein Array zu deklarieren und mit Werten zu füllen bzw. hart programmiert zu füllen.

Da ich die Werte im Array später weiter nutzen möchte, habe ich das Array in eine Variable übernommen:

PHP-Code:
<?php
    $vornamen 
= array("Hans""Dieter""Horst");
?>

Auf dieses Array kann ich dann zugreifen, indem ich die Variable sowie ein Element aus dem Array in der Konsole ausgeben lasse:

PHP-Code:
<?php
    
echo "Das ist der Vorname im ersten Element des Arrays: " $vornamen[0] . "\n";
?>

Das ist die Ausgabe in der Konsole dazu:

Zitat:Das ist der Vorname im ersten Element des Arrays: Hans

Möchte ich alle Elemente eines Arrays verarbeiten, z.B. in der Konsole ausgeben lassen, dann komme ich nicht um eine Schleife umhin. Mit einer foreach-Schleife ist die Ausgabe in der Konsole (oder später auch in einer Datei oder Datenbank) machbar:

PHP-Code:
<?php
    
foreach($vornamen as $vorname) {
        echo $vorname ."\n";
    }
?>

Das ist die Ausgabe in der Konsole dazu:

Zitat:Hans
Dieter
Horst

Für meine Vorhaben brauche ich später die Anzahl der im Array enthaltenen Elemente. Es gibt viele Lösungsansätze. Aber der wohl einfachste geht über die count-Funktion, ohne das weitere Zählschleifen oder ähnliches programmiert werden müssen.

PHP-Code:
<?php
    
echo "Das ist die Anzahl der Elemente im Array der Vornamen: " count($vornamen) . "\n";
?>

Das ist die Ausgabe in der Konsole dazu:

Zitat:Das ist die Anzahl der Elemente im Array der Vornamen: 3

Für mich ist es sehr verwunderlich, dass ich das Prinzip des Array zwar immer verstanden habe, aber nie wirklich anwenden konnte. Wenn ich mir die obigen Programmzeilen ansehe, dann muss ich mir an den Kopf fassen. Es ist eigentlich in den Grundfunktion sehr einfach.

Die von mir angedachten Programmteile zur Nutzung von Arrays haben künftig damit zu tun, dass ich eine unbekannte Anzahl Dateien in einem Verzeichnis verarbeiten und spezielle Inhalte aus den Dateien in eine Datenbanktabelle einfügen möchte. Hier ist ein Array auf jeden Fall von Nöten. Und das natürlich kombiniert mit Schleifen. Im Gegensatz zum obigen Beispiel muss ich dann während der Programmlaufzeit das Array füllen. Auch das habe ich getestet. Dazu schreibe ich noch einen anderen Artikel. Denn das ist aufwendiger und spezieller. Hier wollte ich nur die Grundfunktion beschrieben wissen.

Ein assoziatives Array hat einen Schlüssel (Key) und einen Wert (Value). Wenn ein solches Array durchlaufen wird, wird normalerweise der Wert ausgegeben. Das könnte wie folge aussehen.

PHP-Code:
<?php
    
foreach ($imap as $detail) {
        echo $detail "\n";
    }
?>

Die Ausgabe.

Zitat:Sun, 9 Jan 2022 17:11:08 +0100 (CET)
imap
{domain.zzz:993/imap/notls/ssl/novalidate-cert/user="xxx@yyy.zzz"}INBOX
9
0

Bei dieser Art der Ausgabe weiß man aber nicht immer direkt, was mit dem Wert gemeint ist. Also macht es Sinn, den Schlüssel mitzugeben, denn dieser ist für gewöhnlich lesbar und zeigt, um was es sich bei dem Wert handelt. Das sieht dann so aus.

PHP-Code:
<?php
    
foreach ($imap as $detailkey => $detailwert) {
        echo $detailkey .": " $detailwert "\n";
    }
?>

Die Ausgabe.

Zitat:Date: Sun, 9 Jan 2022 17:17:44 +0100 (CET)
Driver: imap
Mailbox: {domain.zzz:993/imap/notls/ssl/novalidate-cert/user="xxx@yyy.zzz"}INBOX
Nmsgs: 9
Recent: 0

Nun ist ziemlich klar, dass es sich hier um Informationen zu einem IMAP-Konto handelt. Jeder fachkundige Dritte kann also mit dem Ergebnis etwas anfangen bzw. dieses interpretieren.

Oh, Schleifen!

Tja, wann wende ich *While*- und wann wende ich *For*-Schleifen an? Noch so eine Sache, die ich nie wirklich verstanden habe.

Drucke diesen Beitrag

  MySQLDump - nur neue Daten abfragen
Geschrieben von: Joopi - 07-01-2023, 10:21 - Forum: Programmieren - Keine Antworten

Ich stand vor dem Problem, dass ich eine relativ große Datenbank habe und diese vom lokalen Rechner regelmäßig auf einen externen Webspace transportiert und dort in die Datenbank eingespielt werden muss.

Realisiert habe ich bislang dieses Aufgabe mit mysqldump. Das bedeutet aber, wenn man keine Optionen mitgibt, dass mit der Dumpdatei zunächst alle Tabellen gelöscht werden (drop table), um sie anschließend wieder zu erstellen (create table). Danach werden alle Daten in die Tabelle bzw. Tabellen eingefügt (insert).

Und irgendwann kommt man an einem Punkt, an dem die Datei, auch wenn sie gezippt ist, sehr groß wird und der Import mehr als 30 Minuten dauert.

Also musste eine Lösung her, dass aus der Quelldatenbank des lokalen Rechners nur die ab einem bestimmt Zeitpunkt neu hinzugekommenen Datensätze abfragt werden sowie das Löschen und Erstellen der betroffenen Tabelle unterlassen wird. Es dürfen einfach nur die neuen Datensätze ab Zeitpunkt **X** in die bestehenden Tabellen eingefügt werden.

Und es gibt eine Lösung dazu. Ich habe mich dazu entschieden, diese Lösung mittels Erfassungsdatum, dass in allen Tabellen ein Standardfeld ist, zu versuchen.

Nach einigen Versuchen hatte ich dann die richtige Syntax gefunden, die wie folgt aussieht:

Code:
mysqldump --no-create-info --user=user --password="password" datenbank tabelle --where="erfasst>='2022-02-11 19:19:48'" > test.sql

Mit der Option --no-create-info wird sowohl das Löschen als auch das Erstellen von Tabellen verhindert. Ansonsten ist der Befehl zum normalen Befehl von mysqldump nur noch dahingehend abweichend, dass hinter dem Tabellennamen angegeben werden muss, welches Feld und welcher Wert abgefragt werden sollen - --where="erfasst>='2022-02-11 19:19:48'".

Dieser Befehl funktioniert auch mit mehreren Tabellen, die natürlich alle das entsprechend Feld erfasst haben müssen.

Code:
mysqldump --no-create-info --user=user --password="password" datenbank tabelle1 tabelle2 tabelle3  --where="erfasst>='2022-02-11 19:19:48'" > test.sql

Und nun geht das Updaten der Datenbank auf dem externen Webspace in Sekundenschnelle. Über diese Lösung habe ich mich riesig gefreut, denn sie bietet mir für andere Sachverhalte viel mehr Spielraum.

Drucke diesen Beitrag

  Zeichen ersetzen
Geschrieben von: Joopi - 07-01-2023, 10:15 - Forum: Programmieren - Keine Antworten

In MySQL ist es möglich, in den einzelnen Feldern Zeichen zu suchen und zu ersetzen. Das kann sich auf ganze Worte, Wortteile oder einzelne Buchstaben beziehen.

Im nachfolgenden Beispiel wird in der Tabelle autos im Feld baujahr das Wort alt durch das Wort neu ersetzt.

Ändern von Zeichen innerhalb der Datensätze in einer MySQL-Tabelle.

Code:
UPDATE autos SET baujahr = replace(baujahr, 'alt', 'neu');

Drucke diesen Beitrag

  Volltextsuche
Geschrieben von: Joopi - 07-01-2023, 10:13 - Forum: Programmieren - Keine Antworten

Es ist schonmal notwendig, innerhalb einer Tabelle nach Text zu suchen. Dieses ist mit ganz einfachen Mitteln möglich. Ein SQL-Statement könnte wie folgt aussehen:

Code:
SELECT mailtext FROM tabelle WHERE mailtext LIKE "%Herzliche Grüße%";

Damit habe ich ein Tabellenfeld durchforstet und mir damit sehr viel manuelles Arbeiten erspart, um zu wissen, in welchen Datensätze die obige Floskel enthalten ist.

Wichtig dabei sind die Prozentzeichen, die den Suchtext eingrenzen. Nur dieses wird dann entsprechend der Vorgaben des Statements gesucht. Hierbei scheint es keine Rolle zu spielen, ob Groß- oder Kleinschreibung vorhanden ist.

In einem HTML-Formular könnte so eine Volltextsuche ausgestaltet werden. Prima Sache!

Drucke diesen Beitrag

  unique key hinzufügen
Geschrieben von: Joopi - 07-01-2023, 10:12 - Forum: Programmieren - Keine Antworten

Um Doppelerfassung zu vermeiden, bietet es sich an, dass entsprechende Feld auf unique zu setzen. Wird es bei der Erstellung der Tabelle noch nicht erledigt, so kann das nachträglich wie folgt gemacht werden:

Code:
ALTER TABLE tabelle ADD UNIQUE ("id");

Drucke diesen Beitrag

  Tabelle kopieren
Geschrieben von: Joopi - 07-01-2023, 10:08 - Forum: Programmieren - Keine Antworten

Mit nachstehenden MySQL-Befehlen lässt sich eine Tabelle recht einfach in eine andere Datenbank kopieren. In diesem Beispiel werden die Daten von db1 in db2 kopiert.

Zunächst muss die neue Tabelle (mit gleicher Struktur) erstellt werden:

Code:
CREATE TABLE db2.newTable LIKE db1.oldTable;

Danach können die Daten in die neue Tabelle kopiert werden:

Code:
ALTER TABLE db2.newTable DISABLE KEYS;

Code:
INSERT INTO db2.newTable SELECT * FROM db1.oldTable;

Code:
ALTER TABLE db2.newTable ENABLE KEYS;

Drucke diesen Beitrag

  Tabelle create
Geschrieben von: Joopi - 07-01-2023, 10:07 - Forum: Programmieren - Keine Antworten

Sofern ich Tabellen auf der Konsole anlege, benutze ich folgenden Befehl:

Code:
CREATE TABLE tabelle (
id integer NOT NULL auto_increment,
text varchar(30) NOT NULL,
beschreibung text NOT NULL,
erfasst datetime NOT NULL,
geaendert timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
primary key(id)) ENGINE=MyISAM DEFAULT CHARSET=utf8;

Diese Darstellung ist nur exemplarisch. Wichtig sind für mich die beiden Felder mit Datumsangaben.

Drucke diesen Beitrag