regress/sql/age_load.sql (72 lines of code) (raw):

/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ \! cp -r regress/age_load/data regress/instance/data/age_load LOAD 'age'; SET search_path TO ag_catalog; -- Create a country using CREATE clause SELECT create_graph('agload_test_graph'); SELECT * FROM cypher('agload_test_graph', $$CREATE (n:Country {__id__:1}) RETURN n$$) as (n agtype); -- -- Load countries with id -- SELECT load_labels_from_file('agload_test_graph', 'Country', 'age_load/countries.csv', true); -- A temporary table should have been created with 54 ids; 1 from CREATE and 53 from file SELECT COUNT(*)=54 FROM "_agload_test_graph_ag_vertex_ids"; -- Sequence should be equal to max entry id i.e. 248 SELECT currval('agload_test_graph."Country_id_seq"')=248; -- Should error out on loading the same file again due to duplicate id SELECT load_labels_from_file('agload_test_graph', 'Country', 'age_load/countries.csv', true); -- -- Load cities with id -- -- Should create City label automatically and load cities SELECT load_labels_from_file('agload_test_graph', 'City', 'age_load/cities.csv', true); -- Temporary table should have 54+72485 rows now SELECT COUNT(*)=54+72485 FROM "_agload_test_graph_ag_vertex_ids"; -- Sequence should be equal to max entry id i.e. 146941 SELECT currval('agload_test_graph."City_id_seq"')=146941; -- Should error out on loading the same file again due to duplicate id SELECT load_labels_from_file('agload_test_graph', 'City', 'age_load/cities.csv', true); -- -- Load edges -- Connects cities to countries -- -- Should error out for using vertex label SELECT load_edges_from_file('agload_test_graph', 'Country', 'age_load/edges.csv'); SELECT create_elabel('agload_test_graph','has_city'); SELECT load_edges_from_file('agload_test_graph', 'has_city', 'age_load/edges.csv'); -- Sequence should be equal to number of edges loaded i.e. 72485 SELECT currval('agload_test_graph."has_city_id_seq"')=72485; -- Should error out for using edge label SELECT load_labels_from_file('agload_test_graph', 'has_city', 'age_load/cities.csv'); SELECT table_catalog, table_schema, lower(table_name) as table_name, table_type FROM information_schema.tables WHERE table_schema = 'agload_test_graph' ORDER BY table_name ASC; SELECT COUNT(*) FROM agload_test_graph."Country"; SELECT COUNT(*) FROM agload_test_graph."City"; SELECT COUNT(*) FROM agload_test_graph."has_city"; SELECT COUNT(*) FROM cypher('agload_test_graph', $$MATCH(n) RETURN n$$) as (n agtype); SELECT COUNT(*) FROM cypher('agload_test_graph', $$MATCH (a)-[e]->(b) RETURN e$$) as (n agtype); -- -- Load countries and cities without id -- -- Should load countries in Country label without error since it should use sequence now SELECT load_labels_from_file('agload_test_graph', 'Country', 'age_load/countries.csv', false); SELECT create_vlabel('agload_test_graph','Country2'); SELECT load_labels_from_file('agload_test_graph', 'Country2', 'age_load/countries.csv', false); SELECT create_vlabel('agload_test_graph','City2'); SELECT load_labels_from_file('agload_test_graph', 'City2', 'age_load/cities.csv', false); SELECT COUNT(*) FROM agload_test_graph."Country2"; SELECT COUNT(*) FROM agload_test_graph."City2"; SELECT id FROM agload_test_graph."Country" LIMIT 10; SELECT id FROM agload_test_graph."Country2" LIMIT 10; -- Should return 2 rows for Country with same properties, but different ids SELECT * FROM cypher('agload_test_graph', $$MATCH(n:Country {iso2 : 'BE'}) RETURN id(n), n.name, n.iso2 $$) as ("id(n)" agtype, "n.name" agtype, "n.iso2" agtype); -- Should return 1 row SELECT * FROM cypher('agload_test_graph', $$MATCH(n:Country2 {iso2 : 'BE'}) RETURN id(n), n.name, n.iso2 $$) as ("id(n)" agtype, "n.name" agtype, "n.iso2" agtype); -- Should return 2 rows for Country with same properties, but different ids SELECT * FROM cypher('agload_test_graph', $$MATCH(n:Country {iso2 : 'AT'}) RETURN id(n), n.name, n.iso2 $$) as ("id(n)" agtype, "n.name" agtype, "n.iso2" agtype); -- Should return 1 row SELECT * FROM cypher('agload_test_graph', $$MATCH(n:Country2 {iso2 : 'AT'}) RETURN id(n), n.name, n.iso2 $$) as ("id(n)" agtype, "n.name" agtype, "n.iso2" agtype); -- Should return 2 rows for Country with same properties, but different ids SELECT * FROM cypher('agload_test_graph', $$ MATCH (u:Country {region : "Europe"}) WHERE u.name =~ 'Cro.*' RETURN id(u), u.name, u.region $$) AS ("id(u)" agtype, result_1 agtype, result_2 agtype); -- There shouldn't be any duplicates SELECT * FROM cypher('agload_test_graph', $$return graph_stats('agload_test_graph')$$) as (a agtype); SELECT drop_graph('agload_test_graph', true); -- -- Test property type conversion -- -- vertex: load as agtype -- Should create graph and label automatically SELECT load_labels_from_file('agload_conversion', 'Person1', 'age_load/conversion_vertices.csv', true, true); SELECT * FROM cypher('agload_conversion', $$ MATCH (n:Person1) RETURN properties(n) $$) as (a agtype); -- vertex: load as string SELECT create_vlabel('agload_conversion','Person2'); SELECT load_labels_from_file('agload_conversion', 'Person2', 'age_load/conversion_vertices.csv', true, false); SELECT * FROM cypher('agload_conversion', $$ MATCH (n:Person2) RETURN properties(n) $$) as (a agtype); -- edge: load as agtype SELECT create_elabel('agload_conversion','Edges1'); SELECT load_edges_from_file('agload_conversion', 'Edges1', 'age_load/conversion_edges.csv', true); SELECT * FROM cypher('agload_conversion', $$ MATCH ()-[e:Edges1]->() RETURN properties(e) $$) as (a agtype); -- edge: load as string SELECT create_elabel('agload_conversion','Edges2'); SELECT load_edges_from_file('agload_conversion', 'Edges2', 'age_load/conversion_edges.csv', false); SELECT * FROM cypher('agload_conversion', $$ MATCH ()-[e:Edges2]->() RETURN properties(e) $$) as (a agtype); SELECT drop_graph('agload_conversion', true);