Startseite
  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche
Startseite › Forum › Drupalcenter.de › Module › Views ›

[gelöst] Views-Block nur anzeigen, wenn Inhalt?

Eingetragen von digganet (33)
am 14.01.2010 - 21:54 Uhr in
  • Views
  • Drupal 6.x

Hallo,

ich hab mir einen View (Block) erstellt, der Nodes anzeigt, sofern die Filter matchen. Nun möchte ich, dass der Block nur angezeigt wird, wenn der View mindestens einen Node gefunden hat & darstellt.

Gibts hierzu eine einfache Lösung?

Bisher hab ich das versucht:
Ich hab mir das SQL-Statement aus dem View kopiert:

<?php
SELECT node
.nid AS nid,
  
node_data_field_news_showfrom.field_news_title_value AS node_data_field_news_showfrom_field_news_title_value,
  
node.type AS node_type,
  
node.vid AS node_vid,
  
node_revisions.body AS node_revisions_body,
  
node_revisions.format AS node_revisions_format,
  
node_data_field_news_showfrom.field_news_showfrom_value AS node_data_field_news_showfrom_field_news_showfrom_value,
  
node_data_field_news_showfrom.field_news_showfrom_value2 AS node_data_field_news_showfrom_field_news_showfrom_value2
FROM pd_v1_node node
LEFT JOIN pd_v1_content_type_news node_data_field_news_showfrom ON node
.vid = node_data_field_news_showfrom.vid
LEFT JOIN pd_v1_node_revisions node_revisions ON node
.vid = node_revisions.vid
WHERE
((node.type in ('news')) AND (UPPER(node_data_field_news_showfrom.field_news_active_value) = UPPER('Ja')))
    AND ((
DATE_FORMAT(STR_TO_DATE(node_data_field_news_showfrom.field_news_showfrom_value, '%Y-%m-%dT%T'), '%Y-%m-%d') <= '2010-01-14') AND (DATE_FORMAT(STR_TO_DATE(node_data_field_news_showfrom.field_news_showfrom_value2, '%Y-%m-%dT%T'), '%Y-%m-%d') >= '2010-01-14'))
  
ORDER BY node_data_field_news_showfrom_field_news_showfrom_value DESC, node_data_field_news_showfrom_field_news_showfrom_value2 DESC
?>

und bei diesem die SELECT-Felder durch ein COUNT(*) ersetzt.

<?php

SELECT COUNT
(*)
FROM pd_v1_node node
LEFT JOIN pd_v1_content_type_news node_data_field_news_showfrom ON node
.vid = node_data_field_news_showfrom.vid
LEFT JOIN pd_v1_node_revisions node_revisions ON node
.vid = node_revisions.vid
WHERE
((node.type in ('news')) AND (UPPER(node_data_field_news_showfrom.field_news_active_value) = UPPER('Ja')))
    AND ((
DATE_FORMAT(STR_TO_DATE(node_data_field_news_showfrom.field_news_showfrom_value, '%Y-%m-%dT%T'), '%Y-%m-%d') <= '2010-01-14') AND (DATE_FORMAT(STR_TO_DATE(node_data_field_news_showfrom.field_news_showfrom_value2, '%Y-%m-%dT%T'), '%Y-%m-%d') >= '2010-01-14'))
?>

Lasse ich dieses neue Statement direkt auf die Datenbank los, erhalte ich das korrekte Ergebnis: 2.

Füge ich dies nun in die Sichtbarkeits-Einstellung des Blockes via PHP ein, erhalte ich als Ergebnis 0, d. h. der Block wird nicht angezeigt. :(

<?php
$query
= "SELECT COUNT(*)
FROM pd_v1_node node
LEFT JOIN pd_v1_content_type_news node_data_field_news_showfrom ON node.vid = node_data_field_news_showfrom.vid
LEFT JOIN pd_v1_node_revisions node_revisions ON node.vid = node_revisions.vid
WHERE ((node.type in ('news')) AND (UPPER(node_data_field_news_showfrom.field_news_active_value) = UPPER('Ja')))
    AND ((DATE_FORMAT(STR_TO_DATE(node_data_field_news_showfrom.field_news_showfrom_value, '%Y-%m-%dT%T'), '%Y-%m-%d') <= '2010-01-14') AND (DATE_FORMAT(STR_TO_DATE(node_data_field_news_showfrom.field_news_showfrom_value2, '%Y-%m-%dT%T'), '%Y-%m-%d') >= '2010-01-14'))"
;
$erg = db_query($query);
$h = db_fetch_array($erg);
if(
$h['cnt'] > 0) { return TRUE; }
else { return
FALSE; }
?>

Testweise hab ich das gleiche mal in ein Node im Eingabeformat PHP gesetzt und mir $h['cnt'] ausgeben lassen: 0.

Was ist hier also los?
Das selbe Statement auf der Datenbank gibt 2 aus, via Drupal jedoch 0?!

‹ [gelöst] News-Ansicht mit Views realisieren Fußballergebnisse mit Views ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Ich habe mir den ganzen

Eingetragen von tobi-berlin (857)
am 17.01.2010 - 20:59 Uhr

Ich habe mir den ganzen Quellcode jetzt mal nicht angesehen... aber wieso diese Frage? Bei mir werden Block-Views nie angezeigt, wenn die Filter keinen Node finden. Hast Du vielleicht den Kopfbereich der Ansicht definiert oder die Fußzeile? Hier kannst Du ein Häkchen setzen bei "Auch anzeigen, wenn die Ansicht keine Ergebnisse liefert" (oder so ähnlich), dann wird der Block mit dem Kopf- bzw. Fußbereich immer angezeigt, sonst eigentlich nicht.

Präsentiert voller Stolz sein erstes Drupal-Projekt: http://www.diaet-clique.de

  • Anmelden oder Registrieren um Kommentare zu schreiben

OH GOTT, ist das peinlich.

Eingetragen von digganet (33)
am 17.01.2010 - 21:12 Uhr

OH GOTT, ist das peinlich. Ja. Das hatte ich gar nicht probiert. Du hast recht. Oh weh. Dann tut mir die blöde Frage leid! :D

Aber unabhängig davon wüsst ich gern, warum ein und dieselbe Abfrage via MySQL-Administrator ein Ergebnis bringt, via Drupal jedoch nicht.

  • Anmelden oder Registrieren um Kommentare zu schreiben

Kein Ding, manchmal sieht

Eingetragen von tobi-berlin (857)
am 17.01.2010 - 22:00 Uhr

Kein Ding, manchmal sieht man den Wald vor lauter Bäumen nicht :-)

Bei Deiner Frage kann ich Dir aber nicht helfen, bin kein Fachmann für SQL-Abfragen und dergleichen. Da bin ich überfragt...

Präsentiert voller Stolz sein erstes Drupal-Projekt: http://www.diaet-clique.de

  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • für drupal11 ein Slider Modul
  • [gelöst] W3CSS Paragraphs Views
  • Drupal 11 neu aufsetzen und Bereiche aus 10 importieren
  • Wie erlaubt man neuen Benutzern auf die Resetseite zugreifen zu dürfen.
  • [gelöst] Anzeigeformat Text mit Bild in einem Artikel, Drupal 11
  • Social Media Buttons um Insteragram erweitern
  • Nach Installation der neuesten D10-Version kein Zugriff auf Website
  • Composer nach Umzug
  • [gelöst] Taxonomie Begriffe zeigt nicht alle Nodes an
  • Drupal 11 + Experience Builder (Canvas) + Layout Builder
  • Welche KI verwendet ihr?
  • Update Manger läst sich nicht Installieren
Weiter

Neue Kommentare

  • melde mich mal wieder, da ich
    vor 2 Wochen 5 Tagen
  • Hey danke
    vor 2 Wochen 6 Tagen
  • Update: jetzt gibt's ein
    vor 3 Wochen 12 Stunden
  • Hallo, im Prinzip habe ich
    vor 3 Wochen 4 Tagen
  • Da scheint die Terminologie
    vor 3 Wochen 5 Tagen
  • Kannst doch auch alles direkt
    vor 4 Wochen 2 Tagen
  • In der entsprechenden View
    vor 4 Wochen 2 Tagen
  • Dazu müsstest Du vermutlich
    vor 4 Wochen 2 Tagen
  • gelöst
    vor 6 Wochen 5 Tagen
  • Ja natürlich. Dass ist etwas,
    vor 6 Wochen 6 Tagen

Statistik

Beiträge im Forum: 250233
Registrierte User: 20466

Neue User:

  • Znogsnernoimb
  • ByteScrapers
  • Mroppoofpaync

» Alle User anzeigen

User nach Punkten sortiert:
wla9461
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3857
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 0 User und 16 Gäste online.

Hauptmenü

  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche

Quicklinks I

  • Infos
  • Drupal Showcase
  • Installation
  • Update
  • Forum
  • Team
  • Verhaltensregeln

Quicklinks II

  • Drupal Jobs
  • FAQ
  • Drupal-Kochbuch
  • Best Practice - Drupal Sites - Guidelines
  • Drupal How To's

Quicklinks III

  • Tipps & Tricks
  • Drupal Theme System
  • Theme Handbuch
  • Leitfaden zur Entwicklung von Modulen

RSS & Twitter

  • Drupal Planet deutsch
  • RSS Feed News
  • RSS Feed Planet
  • Twitter Drupalcenter
Drupalcenter Team | Impressum & Datenschutz | Kontakt
Angetrieben von Drupal | Drupal is a registered trademark of Dries Buytaert.
Drupal Initiative - Drupal Association