|
| 1 | +-- Create test database and tables for Hoptimator MySQL integration |
| 2 | +-- This script runs automatically when the MySQL container starts |
| 3 | + |
| 4 | +USE testdb; |
| 5 | + |
| 6 | +-- Create a users table |
| 7 | +CREATE TABLE IF NOT EXISTS users ( |
| 8 | + user_id INT PRIMARY KEY AUTO_INCREMENT, |
| 9 | + username VARCHAR(50) NOT NULL UNIQUE, |
| 10 | + email VARCHAR(100) NOT NULL, |
| 11 | + created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP, |
| 12 | + is_active BOOLEAN DEFAULT TRUE |
| 13 | +); |
| 14 | + |
| 15 | +-- Create an orders table |
| 16 | +CREATE TABLE IF NOT EXISTS orders ( |
| 17 | + order_id INT PRIMARY KEY AUTO_INCREMENT, |
| 18 | + user_id INT NOT NULL, |
| 19 | + product_name VARCHAR(100) NOT NULL, |
| 20 | + quantity INT NOT NULL, |
| 21 | + price DECIMAL(10, 2) NOT NULL, |
| 22 | + order_date TIMESTAMP DEFAULT CURRENT_TIMESTAMP, |
| 23 | + status VARCHAR(20) DEFAULT 'pending', |
| 24 | + FOREIGN KEY (user_id) REFERENCES users(user_id) |
| 25 | +); |
| 26 | + |
| 27 | +-- Create a products table |
| 28 | +CREATE TABLE IF NOT EXISTS products ( |
| 29 | + product_id INT PRIMARY KEY AUTO_INCREMENT, |
| 30 | + product_name VARCHAR(100) NOT NULL, |
| 31 | + category VARCHAR(50), |
| 32 | + price DECIMAL(10, 2) NOT NULL, |
| 33 | + stock_quantity INT DEFAULT 0, |
| 34 | + description TEXT |
| 35 | +); |
| 36 | + |
| 37 | +-- Insert sample data into users |
| 38 | +INSERT INTO users (username, email, is_active) VALUES |
| 39 | + ( 'alice', '[email protected]', TRUE), |
| 40 | + ( 'bob', '[email protected]', TRUE), |
| 41 | + ( 'charlie', '[email protected]', FALSE), |
| 42 | + ( 'diana', '[email protected]', TRUE); |
| 43 | + |
| 44 | +-- Insert sample data into products |
| 45 | +INSERT INTO products (product_name, category, price, stock_quantity, description) VALUES |
| 46 | + ('Laptop', 'Electronics', 999.99, 50, 'High-performance laptop'), |
| 47 | + ('Mouse', 'Electronics', 29.99, 200, 'Wireless mouse'), |
| 48 | + ('Desk Chair', 'Furniture', 199.99, 30, 'Ergonomic office chair'), |
| 49 | + ('Coffee Mug', 'Kitchen', 12.99, 100, 'Ceramic coffee mug'); |
| 50 | + |
| 51 | +-- Insert sample data into orders |
| 52 | +INSERT INTO orders (user_id, product_name, quantity, price, status) VALUES |
| 53 | + (1, 'Laptop', 1, 999.99, 'completed'), |
| 54 | + (1, 'Mouse', 2, 29.99, 'completed'), |
| 55 | + (2, 'Desk Chair', 1, 199.99, 'pending'), |
| 56 | + (3, 'Coffee Mug', 3, 12.99, 'shipped'), |
| 57 | + (4, 'Laptop', 1, 999.99, 'pending'); |
| 58 | + |
| 59 | +-- Create a second schema for testing multi-schema support |
| 60 | +CREATE DATABASE IF NOT EXISTS analytics; |
| 61 | + |
| 62 | +USE analytics; |
| 63 | + |
| 64 | +-- Create a metrics table in the analytics schema |
| 65 | +CREATE TABLE IF NOT EXISTS daily_metrics ( |
| 66 | + metric_id INT PRIMARY KEY AUTO_INCREMENT, |
| 67 | + metric_date DATE NOT NULL, |
| 68 | + metric_name VARCHAR(50) NOT NULL, |
| 69 | + metric_value DECIMAL(15, 2) NOT NULL, |
| 70 | + created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP |
| 71 | +); |
| 72 | + |
| 73 | +-- Insert sample metrics data |
| 74 | +INSERT INTO daily_metrics (metric_date, metric_name, metric_value) VALUES |
| 75 | + (CURDATE(), 'revenue', 5000.00), |
| 76 | + (CURDATE(), 'orders', 150.00), |
| 77 | + (CURDATE(), 'active_users', 1200.00), |
| 78 | + (DATE_SUB(CURDATE(), INTERVAL 1 DAY), 'revenue', 4800.00), |
| 79 | + (DATE_SUB(CURDATE(), INTERVAL 1 DAY), 'orders', 145.00); |
| 80 | + |
| 81 | +-- Grant permissions to hoptimator user on both databases |
| 82 | +GRANT ALL PRIVILEGES ON testdb.* TO 'hoptimator'@'%'; |
| 83 | +GRANT ALL PRIVILEGES ON analytics.* TO 'hoptimator'@'%'; |
| 84 | +FLUSH PRIVILEGES; |
0 commit comments