mirror of
https://github.com/postgresml/pgcat.git
synced 2026-03-23 01:16:30 +00:00
* Refactor query routing into its own module * commments; tests; dead code * error message * safer startup * hm * dont have to be public * wow * fix ci * ok * nl * no more silent errors
62 lines
1.3 KiB
SQL
62 lines
1.3 KiB
SQL
|
|
DROP DATABASE IF EXISTS shard0;
|
|
DROP DATABASE IF EXISTS shard1;
|
|
DROP DATABASE IF EXISTS shard2;
|
|
|
|
CREATE DATABASE shard0;
|
|
CREATE DATABASE shard1;
|
|
CREATE DATABASE shard2;
|
|
|
|
\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);
|
|
|
|
DROP ROLE IF EXISTS sharding_user;
|
|
CREATE ROLE sharding_user ENCRYPTED PASSWORD 'sharding_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;
|
|
|
|
\c shard0
|
|
GRANT ALL ON SCHEMA public TO sharding_user;
|
|
GRANT ALL ON TABLE data TO sharding_user;
|
|
|
|
\c shard1
|
|
GRANT ALL ON SCHEMA public TO sharding_user;
|
|
GRANT ALL ON TABLE data TO sharding_user;
|
|
|
|
\c shard2
|
|
GRANT ALL ON SCHEMA public TO sharding_user;
|
|
GRANT ALL ON TABLE data TO sharding_user;
|