質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
87.20%
phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

解決済

wordpress$wpdbを使用したinsert文

akar
akar

総合スコア5

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

1回答

0評価

0クリップ

1294閲覧

投稿2019/12/04 16:41

前提・実現したいこと

wordpressの自作tabletestから定期的にwp_poststableにinsertを行いたいです。
phpMyadminのSQLの項目から直接SQL文を実行する場合は

SQL

INSERT IGNORE INTO wp_posts(post_date, post_title, code, product, count) SELECT intime, title, code, product, count FROM test

のSQL文で実行できるのですが、これをcronで行いたく、
PHPで$wpdbを使用して実行しようと考えているのですが、エラーに悩まされてしまい
どなたかご存知の方がいらっしゃいましたらご教授いただければと思いますm(__)m

発生している問題・エラーメッセージ

PHP Fatal error: Uncaught Error: Call to a member function query() on null in `ディレクトリパス`:5 Stack trace: #0 {main} thrown in `ディレクトリパス` on line 5

該当のソースコード

cronPHP

#!/usr/local/php/7.1/bin/php <?php global $wpdb; $wpdb->query("INSERT IGNORE INTO {$wpdb->posts}(post_date, post_title, code, product, count) SELECT intime, title, code, product, count FROM {$wpdb->test}"); $wpdb->print_error(); ?>

CreateTable

CREATE TABLE wp_posts (
ID bigint(20) unsigned NOT NULL AUTO_INCREMENT,
post_date datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
post_title text COLLATE utf8mb4_unicode_520_ci NOT NULL,
post_status varchar(20) COLLATE utf8mb4_unicode_520_ci NOT NULL DEFAULT 'publish',
post_name varchar(200) COLLATE utf8mb4_unicode_520_ci NOT NULL DEFAULT '',
post_type varchar(20) COLLATE utf8mb4_unicode_520_ci NOT NULL DEFAULT 'post',
product varchar(255) DEFAULT NULL,
code varchar(255) NOT NULL,
count int(11) DEFAULT NULL,
PRIMARY KEY (ID),
UNIQUE KEY code (code),
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;


CREATE TABLE test (
id int(11) NOT NULL AUTO_INCREMENT,
title varchar(255) DEFAULT NULL,
product varchar(255) DEFAULT NULL,
code varchar(255) NOT NULL,
count int(11) DEFAULT NULL,
intime datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (id)
UNIQUE KEY code (code),
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
87.20%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。