行の UTF-8 エンコードされた MySQL テーブルから簡単な抽出を試み、それらからノードを作成しています。「Country House Café」という名前のエントリで行にヒットするまでは正常に動作します。
REST API 用に neo4jphp ラッパー ライブラリを使用しています。
基本的な PDO 選択を使用して行をプルします。
$results = $db->query("SELECT * FROM table WHERE name is not null");
$rows = $results->fetchAll(PDO::FETCH_ASSOC);
次に、行をループします。
foreach($rows as $row){
try {
$node = $client->makeNode($row);
$node->save();
} catch (Exception $e) {
var_dump($row); exit;
}
}
プロパティ「name」が文字列「Country House Café」であるノードにヒットするまで、ノードの作成と保存を繰り返します。これにより、次のような例外がトリガーされます
Headers: Array
(
[Content-Type] => application/json; charset=UTF-8; stream=true
[Access-Control-Allow-Origin] => *
[Transfer-Encoding] => chunked
[Server] => Jetty(9.0.5.v20130815)
)
Body: Array
(
[message] => Could not set property "name", unsupported type: null
[exception] => PropertyValueException
[fullname] => org.neo4j.server.rest.web.PropertyValueException
[stacktrace] => Array
(
[0] => org.neo4j.server.rest.domain.PropertySettingStrategy.setProperty(PropertySettingStrategy.java:141)
[1] => org.neo4j.server.rest.domain.PropertySettingStrategy.setProperties(PropertySettingStrategy.java:88)
[2] => org.neo4j.server.rest.web.DatabaseActions.createNode(DatabaseActions.java:214)
[3] => org.neo4j.server.rest.web.RestfulGraphDatabase.createNode(RestfulGraphDatabase.java:238)
[4] => java.lang.reflect.Method.invoke(Method.java:483)
[5] => org.neo4j.server.rest.transactional.TransactionalRequestDispatcher.dispatch(TransactionalRequestDispatcher.java:139)
[6] => org.neo4j.server.rest.security.SecurityFilter.doFilter(SecurityFilter.java:112)
[7] => java.lang.Thread.run(Thread.java:745)
)
)
ここで、PHP でこのように明示的に何かを手動で行うと、すべてが機能します。
$node = $client->makeNode(array("name" => "Country House Café"));
$node->save();
ここで何が犯人なのか、誰にも手がかりがありますか?