无法将值插入数据库

时间:2017-07-03 13:23:36

标签: sql postgresql python-2.7

我正在尝试获取网站的一些数据并将其存储在数据库中,但它无法正常工作,我不知道错误是什么。你能救我吗?

错误:

<?php

        require_once __DIR__ . '/vendor/autoload.php';
        use FacebookAds\Api;
        use FacebookAds\Object\AdUser;
        use Facebook\Facebook;
        use Facebook\Exceptions\FacebookResponseException;
        use Facebook\Exceptions\FacebookSDKException;
        use FacebookAds\Object\Campaign;
        use FacebookAds\Object\Fields\AdsInsightsFields;
        use FacebookAds\Object\Ad;
        use FacebookAds\Object\Fields\AdSetFields;
        use FacebookAds\Object\AdCampaign;
        use FacebookAds\Object\Fields\AdFields;
        use FacebookAds\Object\Fields;
        use FacebookAds\Object\Fields\AdImageFields;
        use FacebookAds\Object\AdAccount;
        use FacebookAds\Object\AdSet;
        use FacebookAds\Object\AdCreative;
        use FacebookAds\Object\Fields\AdCreativeFields;
        use FacebookAds\Object\Fields\AdCreativePhotoDataFields;
        use FacebookAds\Object\AdCreativeLinkData;
        use FacebookAds\Object\Fields\AdCreativeLinkDataFields;
        use FacebookAds\Object\Fields\CampaignFields;
        use FacebookAds\Object\Page;
        use FacebookAds\Object\Fields\AdPreviewFields;
        use FacebookAds\Object\Values\AdPreviewAdFormatValues;
        use FacebookAds\Object\AdVideo;
        ?>

Here is the general code I am trying

<?php
        // Init PHP Sessions
        session_start();

        $fb = new Facebook([
          'app_id' => 'xxxxxxxxx',
          'app_secret' => 'xxxxxxxxxxx',
        ]);

        $helper = $fb->getRedirectLoginHelper();

        if (!isset($_SESSION['enter api key here'])) {
          $_SESSION['enter api key here'] = null;
        }

        if (!$_SESSION['enter api key here']) {
          $helper = $fb->getRedirectLoginHelper();
          try {
            $_SESSION['enter api key here'] = (string) $helper->getAccessToken();
          } catch(FacebookResponseException $e) {
            // When Graph returns an error
            echo 'Graph returned an error: ' . $e->getMessage();
            exit;
          } catch(FacebookSDKException $e) {
            // When validation fails or other local issues
            echo 'Facebook SDK returned an error: ' . $e->getMessage();
            exit;
          }
        }

        if ($_SESSION['enter api key here']) {
          //echo "You are logged in!";

        // Initialize a new Session and instantiate an API object
        Api::init(
          'xxxxxxxxx', // App ID
          'xxxxxxxxx', //app_secret
          $_SESSION['enter api key here'] // Your user access token
        );

    ?>
<div id="fbdata"></div> <?php

    $account = new AdAccount('act_xxxxxxxxxx');


        $params = array(

        'date_preset'=> 'last_28d',


            'thumbnail_width' => 200,
            'thumbnail_height' => 150,
            'level' => 'campaign',
            'limit' => '15'

        );

$fields = array(
  AdsInsightsFields::CAMPAIGN_NAME,
  AdsInsightsFields::CAMPAIGN_ID,
  AdsInsightsFields::IMPRESSIONS,
  AdsInsightsFields::CLICKS,
  AdsInsightsFields::REACH,
  AdsInsightsFields::SPEND,
  AdsInsightsFields::CPM,
  AdsInsightsFields::CPC,
  AdsInsightsFields::ACTIONS, 
);

$field = array(
  AdCreativeFields::TITLE,
  AdCreativeFields::THUMBNAIL_URL,
  AdCreativeFields::BODY,
  );

            $params1 = array(
          'time_range' => array(
            'since' => (new \DateTime($beginDate))->format('Y-m-d'),
            'until' => (new \DateTime($lastDate))->format('Y-m-d'),
          ),
            'thumbnail_width' => 200,
            'thumbnail_height' => 150,
            'level' => 'ad',
            'limit' => '5'
        );      

$adcreatives = $account->getAdCreatives($field, $params1);
?>      
        <table class="fbtable">
            <tr>
                <th>Title</th>
                <th>Ad Image</th>
                <th>Ad Body</th>
            </tr>
            <?php
foreach($adcreatives as $t2){

        echo"<tr>
        <td>$t2->title</td>
      <td><img src='$t2->thumbnail_url'/></td>
      <td>$t2->body</td>
    </tr>";
}

        $insights = $account->getInsights($fields, $params);?>

        <table class="fbtable">
            <tr>
                <th>Campaign ID</th>
                <th>Campaign Name</th>
                <th>Impressions</th>
                <th>Clicks</th>
                <th>Reach</th>
                <th>Spend</th>
                <th>Total Actions</th>
                <th>CPM</th>
                <th>CPC</th>
            </tr>

            <?php

foreach($insights as $i) {
    $impress = number_format((float)$i->impressions);
    $reach = number_format((float)$i->reach);
    $totalAction = number_format((float)$i->actions);
    $cpc = number_format($i->cpc, 2, '.', '');
    $cpm = number_format($i->cpm, 2, '.', '');
    echo"<tr class='fbtable'>
      <td>$i->campaign_id</td>
      <td>$i->campaign_name</td>
      <td>$impress</td>
      <td>$i->clicks</td>
      <td>$reach</td>
      <td>$$i->spend</td>
      <td>$totalAction</td>
      <td>$$cpm</td>
      <td>$$cpc</td>
    </tr>";
}
        }else {
          $permissions = ['ads_management'];
          $loginUrl = $helper->getLoginUrl('http://where you want login to be.com', $permissions);
          echo '<a href="' . $loginUrl . '">Log in with Facebook</a>';
        } 


?>

代码(选择的网站只是一个测试):

Error syntax error at or near "INTEGER"
LINE 1: CREATE TABLE test(id SERIAL INTEGER PRIMARY KEY, event_date ...

1 个答案:

答案 0 :(得分:1)

没有SERIAL INTEGER

CREATE TABLE test(id SERIAL PRIMARY KEY, event_date TEXT, event_time VARCHAR)
  

我不知道错误是什么

你是什​​么意思?我只尝试了try块,它在此问题上给出了明确的错误消息。也许前面的代码有其他错误可以杀死程序。

您的INSERT似乎也有问题。为什么不首先CREATE表格并在INSERT的循环中调用table.findAll