|
| 1 | +-- Drop tables in correct order to avoid foreign key constraints |
| 2 | +DROP TABLE IF EXISTS blocks; |
| 3 | +DROP TABLE IF EXISTS pools; |
| 4 | +DROP TABLE IF EXISTS statistics; |
| 5 | +DROP TABLE IF EXISTS elements_pegs; |
| 6 | +DROP TABLE IF EXISTS prices; |
| 7 | +DROP TABLE IF EXISTS state; |
| 8 | + |
| 9 | +-- Create state table first |
| 10 | +CREATE TABLE state ( |
| 11 | + name varchar(25) NOT NULL, |
| 12 | + number int NULL, |
| 13 | + string varchar(100) NULL, |
| 14 | + CONSTRAINT name_unique UNIQUE (name) |
| 15 | +) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci; |
| 16 | + |
| 17 | +-- Insert initial state values |
| 18 | +INSERT INTO state VALUES('schema_version', 83, NULL); |
| 19 | +INSERT INTO state VALUES('last_elements_block', 0, NULL); |
| 20 | + |
| 21 | +-- Create pools table with all required columns |
| 22 | +CREATE TABLE pools ( |
| 23 | + id int NOT NULL AUTO_INCREMENT, |
| 24 | + unique_id varchar(100) NOT NULL, |
| 25 | + name varchar(50) NOT NULL, |
| 26 | + link varchar(255) NOT NULL, |
| 27 | + addresses json NOT NULL, |
| 28 | + regexes json NOT NULL, |
| 29 | + slug varchar(100) NOT NULL, |
| 30 | + PRIMARY KEY (id), |
| 31 | + UNIQUE KEY unique_id_idx (unique_id) |
| 32 | +) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci; |
| 33 | + |
| 34 | +-- Insert default pool with all required fields |
| 35 | +INSERT INTO pools (id, unique_id, name, link, addresses, regexes, slug) |
| 36 | +VALUES ( |
| 37 | + -1, |
| 38 | + 'unknown', |
| 39 | + 'Unknown', |
| 40 | + 'https://learnmeabitcoin.com/technical/coinbase-transaction', |
| 41 | + '[]', |
| 42 | + '[]', |
| 43 | + 'unknown' |
| 44 | +); |
| 45 | + |
| 46 | +-- Create blocks table with updated schema |
| 47 | +CREATE TABLE blocks ( |
| 48 | + height int unsigned NOT NULL, |
| 49 | + hash varchar(65) NOT NULL, |
| 50 | + blockTimestamp timestamp NOT NULL, |
| 51 | + size int unsigned NOT NULL, |
| 52 | + weight int unsigned NOT NULL, |
| 53 | + tx_count smallint unsigned NOT NULL, |
| 54 | + coinbase_raw text, |
| 55 | + difficulty double NOT NULL, |
| 56 | + pool_id int DEFAULT -1, |
| 57 | + fees double unsigned NOT NULL, |
| 58 | + reward double unsigned NOT NULL DEFAULT 0, |
| 59 | + fee_span json NOT NULL, |
| 60 | + median_fee double unsigned NOT NULL, |
| 61 | + PRIMARY KEY (height), |
| 62 | + INDEX pool_idx (pool_id), |
| 63 | + CONSTRAINT blocks_pool_fk FOREIGN KEY (pool_id) REFERENCES pools(id) |
| 64 | +) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci; |
| 65 | + |
| 66 | +-- Create other required tables |
| 67 | +CREATE TABLE statistics ( |
| 68 | + id int AUTO_INCREMENT PRIMARY KEY, |
| 69 | + added datetime NOT NULL, |
| 70 | + unconfirmed_transactions int unsigned NOT NULL, |
| 71 | + tx_per_second float unsigned NOT NULL, |
| 72 | + vbytes_per_second int unsigned NOT NULL, |
| 73 | + mempool_byte_weight int unsigned NOT NULL, |
| 74 | + fee_data longtext NOT NULL, |
| 75 | + total_fee double unsigned NOT NULL, |
| 76 | + INDEX added_idx (added) |
| 77 | +) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci; |
| 78 | + |
| 79 | +-- Create prices table |
| 80 | +CREATE TABLE prices ( |
| 81 | + id SERIAL PRIMARY KEY, |
| 82 | + time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP, |
| 83 | + USD DECIMAL(24,8) NOT NULL DEFAULT 0, |
| 84 | + EUR DECIMAL(24,8) NOT NULL DEFAULT 0, |
| 85 | + GBP DECIMAL(24,8) NOT NULL DEFAULT 0, |
| 86 | + CAD DECIMAL(24,8) NOT NULL DEFAULT 0, |
| 87 | + CHF DECIMAL(24,8) NOT NULL DEFAULT 0, |
| 88 | + AUD DECIMAL(24,8) NOT NULL DEFAULT 0, |
| 89 | + JPY DECIMAL(24,8) NOT NULL DEFAULT 0, |
| 90 | + INDEX time_idx (time) |
| 91 | +) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci; |
| 92 | + |
| 93 | +-- Add initial price data |
| 94 | +INSERT INTO prices (time, USD, EUR, GBP, CAD, CHF, AUD, JPY) |
| 95 | +VALUES (CURRENT_TIMESTAMP, 0, 0, 0, 0, 0, 0, 0); |
0 commit comments