php.de

Zurück   php.de > Webentwicklung > Datenbanken

Datenbanken SQL und Co

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 22.07.2011, 17:03  
Neuer Benutzer
 
Registriert seit: 11.09.2009
Beiträge: 13
PHP-Kenntnisse:
Anfänger
Clueso befindet sich auf einem aufstrebenden Ast
Standard Nur bestimmte Zeichenlänge aus Feld auslesen

Hallo,
ich möchte gerne nur eine bestimmte Zeichenlänge aus einem Feld auslesen.
Viele kennen das bestimmt aus verschiedenen Newsseiten, wo es eine Vorschau auf der Hauptseite gibt und mit einem Klick auf z.B. „Mehr“ gelangt man auf die komplette News.
Prinzipiell möchte ich nun das Selbe haben.

Mein Feldname heisst z.B. „Kommentar“ und ist momentan vom Typ text. Ich möchte gleichzeitig noch mehrere Felder innerhalb der Abfrage abfragen.

Ich habe folgenden Code implementiert, der so nicht funktioniert und ich wüsste gerne warum?:

PHP-Code:
$abfrage "SELECT IF(LENGTH(`Kommentar`) > 250, LEFT(`Kommentar`, 300), `Kommentar`) as teaser 
FROM tabelle WHERE Ort = '$Ort' ORDER BY Wertung DESC"

$ergebnis mysql_query($abfrage);
while(
$row mysql_fetch_object($ergebnis))
    {
    
$Name $row->Name;
    
$Wertung $row->Wertung;
    
$Kommentar $row->Kommentar;
    
$Datum date("d.m.Y "$row->Datum);
    
   
echo 
"$Name";
echo
"Eingetragen am $Datum ";

 echo 
"<p>" .substr$row->teaser0strpos$row->teaser"."180 )+). "</p>"

Folgende Ausgabefehlermeldung bekomme ich:
Warning: strpos() [function.strpos]: Offset not contained in string in …..
Clueso ist offline   Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 22.07.2011, 17:10  
Moderator¹
 
Registriert seit: 28.03.2010
Beiträge: 7.470
PHP-Kenntnisse:
Fortgeschritten
ChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer Anblick
Standard

Zitat:
Zitat von Clueso Beitrag anzeigen
Ich habe folgenden Code implementiert, der so nicht funktioniert und ich wüsste gerne warum?
Das sagt dir doch die Fehlermeldung:
Zitat:
Warning: strpos() [function.strpos]: Offset not contained in string in …..
Du versuchst mit strpos auf mehr Zeichen zuzugreifen, als der String überhaupt enthält.
__________________
RGB is totally confusing - I mean, at least #C0FFEE should be brown, right?
ChrisB ist offline   Mit Zitat antworten
Alt 22.07.2011, 17:22  
Neuer Benutzer
 
Registriert seit: 11.09.2009
Beiträge: 13
PHP-Kenntnisse:
Anfänger
Clueso befindet sich auf einem aufstrebenden Ast
Standard

Ja da hast Du Recht, es war eine Fehlermeldung. Ich hätte evtl. weiter ausführen sollen.
Es funktioniert nichts. Selbst die anderen Variablen die ich aus der Tabelle hole, wie Name oder Datum werden nicht oder falsch angezeigt (Datum z.B. 01.01.1970)
Ausserdem wird nur der erste Buchstabe des Textes jetzt ausgegeben, wenn ich die Zeichenlänge verringere.
Clueso ist offline   Mit Zitat antworten
Alt 22.07.2011, 17:27  
Moderator¹
 
Registriert seit: 28.03.2010
Beiträge: 7.470
PHP-Kenntnisse:
Fortgeschritten
ChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer Anblick
Standard

Zitat:
Zitat von Clueso Beitrag anzeigen
Es funktioniert nichts.

Zitat:
Selbst die anderen Variablen die ich aus der Tabelle hole, wie Name oder Datum werden nicht oder falsch angezeigt (Datum z.B. 01.01.1970)
Dann ist dein Datum vermutlich kein Unix-Timestamp.
Zitat:
Ausserdem wird nur der erste Buchstabe des Textes jetzt ausgegeben, wenn ich die Zeichenlänge verringere.
Dann betreibe Debugging.
http://www.php.de/wiki-php/index.php...ging:Leitfaden
__________________
RGB is totally confusing - I mean, at least #C0FFEE should be brown, right?
ChrisB ist offline   Mit Zitat antworten
Alt 22.07.2011, 17:30  
Neuer Benutzer
 
Registriert seit: 11.09.2009
Beiträge: 13
PHP-Kenntnisse:
Anfänger
Clueso befindet sich auf einem aufstrebenden Ast
Standard

Am Datum liegt es nicht

Wenn ich diesen Code:

PHP-Code:
$abfrage "SELECT IF(LENGTH(`Kommentar`) > 250, LEFT(`Kommentar`, 300), `Kommentar`) as teaser 
FROM tabelle WHERE Ort = '$Ort' ORDER BY Wertung DESC"

In diesem ändere:
PHP-Code:
$abfrage "SELECT * 
FROM tabelle WHERE Ort = '$Ort' ORDER BY Wertung DESC"

Dann gehen die anderen Variablen. Ich denke hier liegt irgendwo der Hund begraben.
Clueso ist offline   Mit Zitat antworten
Alt 22.07.2011, 17:33  
Moderator¹
 
Registriert seit: 28.03.2010
Beiträge: 7.470
PHP-Kenntnisse:
Fortgeschritten
ChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer AnblickChrisB ist ein wunderbarer Anblick
Standard

Stelle bitte als allererstes das error_reporting vernünftig ein!
http://www.php.de/wiki-php/index.php..._Fehlerausgabe

Und dann überleg mal, welche Spalten du mit deinem gezeigten Select-Statement eigentlich ausliest.
__________________
RGB is totally confusing - I mean, at least #C0FFEE should be brown, right?
ChrisB ist offline   Mit Zitat antworten
Alt 22.07.2011, 18:12  
Neuer Benutzer
 
Registriert seit: 11.09.2009
Beiträge: 13
PHP-Kenntnisse:
Anfänger
Clueso befindet sich auf einem aufstrebenden Ast
Standard

Ja anscheinend ist die Abfrage und das select falsch.

Bekomme die Meldungen:

Notice: Undefined property: stdClass

Und dann für alle Variablen.

Jemand eine Idee wie es funktionieren könnte? Bin da momentan überfreugt, alle Variablen auszuwählen und gleichzeitig ein Feld auf eine Zeichenmenge zu beschränken.

Hab schon überlegt, ob ich nicht einfach ein weiteres Feld in die Tabelle einfüge, und in diesem Feld einfach den Teaser beim Eintragen auf eine bestimmte Zeichenanzahl beschränke. Dann habe ich ein Feld für den Teaser beim Eintragen in die Datenbank und ein Feld für den gesamten Text. Allerdings denke ich, ist das die unschönere Lösung, auch weil die Datenmenge größer wird. Aber das würde ich im Gegensatz zu dieser Variante hinbekommen....
Clueso ist offline   Mit Zitat antworten
Alt 22.07.2011, 20:08  
Erfahrener Benutzer
 
Benutzerbild von lstegelitz
 
Registriert seit: 07.09.2009
Beiträge: 4.005
PHP-Kenntnisse:
Fortgeschritten
lstegelitz ist einfach richtig nettlstegelitz ist einfach richtig nettlstegelitz ist einfach richtig nettlstegelitz ist einfach richtig nett
Standard

Dein SELECT enthält nur ein Feld aus der Datenbank, namentlich "Kommentar" ALIAS "teaser"

Du willst aber aus dem Ergebnis folgendes herausquetschen:
$row->Name;
$row->Wertung;
$row->Kommentar;
$row->Datum;

Woher nehmen und nicht stehlen?
Zitat:
Bin da momentan überfreugt, alle Variablen auszuwählen und gleichzeitig ein Feld auf eine Zeichenmenge zu beschränken.
Aufzählung, genau wie im deutschen: feld1,feld2,feld3, IF(geraffel)

Ansonsten schau in die SQL Doku

Zitat:
Hab schon überlegt, ob ich nicht einfach ein weiteres Feld in die Tabelle einfüge,
Komm erstmal mit denen klar, die schon da sind, bevor dur Erweiterungen planst.
__________________
Über 90% aller Gewaltverbrechen passieren innerhalb von 24 Stunden nach dem Konsum von Brot.
lstegelitz ist offline   Mit Zitat antworten
Antwort


Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an
Gehe zu

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
fgets bestimmte Zeile auslesen ketchup PHP Einsteiger 16 04.04.2011 15:35
MSSQL Feld vom Type Image auslesen ohne Info über Inhalt Schiedsrichter PHP-Fortgeschrittene 4 19.02.2010 11:13
[Erledigt] nur bestimmte anzahl an bildern aus ordner auslesen maboe PHP Tipps 2009 20 01.09.2009 01:06
Aus AD per LDAP das lastlogon Feld auslesen und korrekt anzeigen. bjoern.anger PHP-Fortgeschrittene 2 06.05.2009 15:05
[Erledigt] Textfeld auslesen und nur bestimmte Werte übernehmen LB1981 PHP Tipps 2009 26 27.01.2009 21:24
[Erledigt] bestimmte zeile aus csv auslesen wiked PHP Tipps 2008 25 08.10.2008 13:23
bestimmte Textblöcke aus einer Textdatei auslesen Canni PHP Tipps 2007 7 10.08.2007 17:12
Mehr als ein Feld mit Distinct in einem Query auslesen ?? Bouni PHP-Fortgeschrittene 9 19.12.2005 12:43
[Erledigt] bestimmte ID's auslesen als array PHP Tipps 2007 2 31.10.2005 20:23
beim auslesen von mysql datenbank bestimmte id nicht auslsen djrace PHP Tipps 2005-2 3 10.09.2005 13:32
Bestimmte Werte aus cvs Datei auslesen PHP Tipps 2005-2 1 20.06.2005 13:11
[Erledigt] .reg Datei auslesen und bestimmte Zeile ändern PHP-Fortgeschrittene 19 27.10.2004 10:39
Bestimmte Zeilen aus einer datei auslesen Stinger PHP-Fortgeschrittene 3 06.10.2004 08:54
kann man text feld wert ohne post auslesen? PHP Tipps 2004 5 22.07.2004 12:27
ein feld aus datenbank auslesen ohne while PHP Tipps 2004 6 10.06.2004 15:58

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
bestimmte zeichen aus tabelle auslesen, php bestimmte zeichen länge ausgeben, nur eine bestimmte anzahl von zeichen auslesen db, stellen auslesen sql, nur bestimmte zeichen einer variable auslesen, bestimmte stellen eines feldes sql, html nur bestimmte zeichen in einer tabelle anzeigen, order by nur auf bestimmenten stellen des feldes, nur bestimmter text aus wert lesen sql, php bestimmte zeichen auslesen, sql order by bestimmte anzahl zeichen, order by gewisse zeichen, sql nur bestimmte zeichen vom datum darstellen, bestimmtes zeichen aus array php auslesen, php bestimmte zeichen anzahl aus tabelle auslesen, php zeichen aus formularfeld auslesen, buchstaben im datum abfragen php, offset not contained in string abfangen, textbox bis bestimmtes zeichen auslesen, php nur bestimmte zeichen aus einem textfeld auslesen

Alle Zeitangaben in WEZ +2. Es ist jetzt 13:11 Uhr.




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum