mirror of
https://github.com/postgresml/pgcat.git
synced 2026-03-23 17:36:28 +00:00
* Ruby integration tests * forgot a file * refactor * refactoring * more refactoring * remove config helper * try multiple databases * fix * more databases * Use pg stats * ports * speed * Fix tests * preload library * comment
105 lines
2.9 KiB
SQL
105 lines
2.9 KiB
SQL
DROP DATABASE IF EXISTS shard0;
|
|
DROP DATABASE IF EXISTS shard1;
|
|
DROP DATABASE IF EXISTS shard2;
|
|
DROP DATABASE IF EXISTS some_db;
|
|
|
|
CREATE DATABASE shard0;
|
|
CREATE DATABASE shard1;
|
|
CREATE DATABASE shard2;
|
|
CREATE DATABASE some_db;
|
|
|
|
\c shard0
|
|
|
|
DROP TABLE IF EXISTS data CASCADE;
|
|
|
|
CREATE TABLE data (
|
|
id BIGINT,
|
|
value VARCHAR
|
|
) PARTITION BY HASH (id);
|
|
|
|
CREATE TABLE data_shard_0 PARTITION OF data FOR VALUES WITH (MODULUS 3, REMAINDER 0);
|
|
|
|
\c shard1
|
|
|
|
DROP TABLE IF EXISTS data CASCADE;
|
|
|
|
CREATE TABLE data (
|
|
id BIGINT,
|
|
value VARCHAR
|
|
) PARTITION BY HASH (id);
|
|
|
|
CREATE TABLE data_shard_1 PARTITION OF data FOR VALUES WITH (MODULUS 3, REMAINDER 1);
|
|
|
|
|
|
\c shard2
|
|
|
|
DROP TABLE IF EXISTS data CASCADE;
|
|
|
|
CREATE TABLE data (
|
|
id BIGINT,
|
|
value VARCHAR
|
|
) PARTITION BY HASH (id);
|
|
|
|
CREATE TABLE data_shard_2 PARTITION OF data FOR VALUES WITH (MODULUS 3, REMAINDER 2);
|
|
|
|
|
|
\c some_db
|
|
|
|
DROP TABLE IF EXISTS data CASCADE;
|
|
|
|
CREATE TABLE data (
|
|
id BIGINT,
|
|
value VARCHAR
|
|
);
|
|
|
|
DROP ROLE IF EXISTS sharding_user;
|
|
DROP ROLE IF EXISTS other_user;
|
|
DROP ROLE IF EXISTS simple_user;
|
|
CREATE ROLE sharding_user ENCRYPTED PASSWORD 'sharding_user' LOGIN;
|
|
CREATE ROLE other_user ENCRYPTED PASSWORD 'other_user' LOGIN;
|
|
CREATE ROLE simple_user ENCRYPTED PASSWORD 'simple_user' LOGIN;
|
|
|
|
GRANT CONNECT ON DATABASE shard0 TO sharding_user;
|
|
GRANT CONNECT ON DATABASE shard1 TO sharding_user;
|
|
GRANT CONNECT ON DATABASE shard2 TO sharding_user;
|
|
|
|
GRANT CONNECT ON DATABASE shard0 TO other_user;
|
|
GRANT CONNECT ON DATABASE shard1 TO other_user;
|
|
GRANT CONNECT ON DATABASE shard2 TO other_user;
|
|
|
|
GRANT CONNECT ON DATABASE some_db TO simple_user;
|
|
|
|
\c shard0
|
|
CREATE EXTENSION IF NOT EXISTS pg_stat_statements;
|
|
GRANT EXECUTE ON FUNCTION pg_stat_statements_reset TO sharding_user;
|
|
GRANT ALL ON SCHEMA public TO sharding_user;
|
|
GRANT ALL ON TABLE data TO sharding_user;
|
|
GRANT ALL ON SCHEMA public TO other_user;
|
|
GRANT ALL ON TABLE data TO other_user;
|
|
GRANT EXECUTE ON FUNCTION pg_stat_statements_reset TO other_user;
|
|
|
|
\c shard1
|
|
CREATE EXTENSION IF NOT EXISTS pg_stat_statements;
|
|
GRANT EXECUTE ON FUNCTION pg_stat_statements_reset TO sharding_user;
|
|
GRANT ALL ON SCHEMA public TO sharding_user;
|
|
GRANT ALL ON TABLE data TO sharding_user;
|
|
GRANT ALL ON SCHEMA public TO other_user;
|
|
GRANT ALL ON TABLE data TO other_user;
|
|
GRANT EXECUTE ON FUNCTION pg_stat_statements_reset TO other_user;
|
|
|
|
|
|
\c shard2
|
|
CREATE EXTENSION IF NOT EXISTS pg_stat_statements;
|
|
GRANT EXECUTE ON FUNCTION pg_stat_statements_reset TO sharding_user;
|
|
GRANT ALL ON SCHEMA public TO sharding_user;
|
|
GRANT ALL ON TABLE data TO sharding_user;
|
|
GRANT ALL ON SCHEMA public TO other_user;
|
|
GRANT ALL ON TABLE data TO other_user;
|
|
GRANT EXECUTE ON FUNCTION pg_stat_statements_reset TO other_user;
|
|
|
|
\c some_db
|
|
CREATE EXTENSION IF NOT EXISTS pg_stat_statements;
|
|
GRANT EXECUTE ON FUNCTION pg_stat_statements_reset TO simple_user;
|
|
GRANT ALL ON SCHEMA public TO simple_user;
|
|
GRANT ALL ON TABLE data TO simple_user;
|