Please Disable Your Browser Adblock Extension for our site and Refresh This Page!

our ads are user friendly, we do not serve popup ads. We serve responsible ads!

Refresh Page
Skip to main content
On . By CodimTh

Code snippet that can be used to load programmatically webform submissions in Drupal 8.

$webform = \Drupal\webform\Entity\Webform::load('WEBFORM_ID');  
if ($webform->hasSubmissions()) {
  $query = \Drupal::entityQuery('webform_submission')
    ->condition('webform_id', 'WEBFORM_ID');
  $result = $query->execute();
  $submission_data = [];
  foreach ($result as $item) {
    $submission = \Drupal\webform\Entity\WebformSubmission::load($item);
    $submission_data = $submission->getData();

if Entity query of webform submissions returns no results try to add accessCheck(FALSE) to the query like this 



Submitted by Akhil (not verified) on Thu, 03/04/2021 - 19:24 Permalink

How can I add a date created filter to this query? I am attempting to query all the submissions from yesterday. However, the below query is returning all the submissions for me. $dte = date('Y-m-d', strtotime("-1 days")); $query = \Drupal::entityQuery('webform_submission') ->condition('webform_id', 'account_settings') ->condition('created', $dte, '>=');
Submitted by codimth on Tue, 03/09/2021 - 19:54 Permalink

@Akhil here is an example how to add conditions with created field:

$lastDayTimestamp = strtotime('-1 day');

    $query = \Drupal::entityQuery('webform_submission')
        ->condition('webform_id', 'contact')
        ->condition('created', $lastDayTimestamp, '>=')

    $result = $query->execute();
    foreach ($result as $item) {
        $submission = \Drupal\webform\Entity\WebformSubmission::load($item);
Add new comment

Restricted HTML


Page Facebook

Become a patron

If you need some help or you search a Drupal freelancer don't hesitate to contact us.


Contact Us

All the content is FREE but I still need your help


Become a patreon