#sql #oracle #database

app fake-sql

generate create table, alter table, drop table, insert, update, delete and select sql

2 releases

0.1.1 Nov 12, 2024
0.1.0 Nov 12, 2024

#115 in Testing

Apache-2.0

29KB
340 lines

sql-fake

This program generates random SQL statements and writes them to a file named output.sql. The number of SQL statements to generate is determined by the NUM_RECORDS environment variable, defaulting to 30 if the variable is not set.

The program defines three tables: orders, customers, and products, and generates random SQL statements for these tables, including CREATE TABLE, ALTER TABLE, DROP TABLE, INSERT, SELECT, UPDATE, and DELETE operations.

Usage

Set the NUM_RECORDS environment variable to specify the number of SQL statements to generate. If not set, the program defaults to generating 30 SQL statements.

export NUM_RECORDS=50
cargo run

api

The generated SQL statements are appended to the output.sql file in the current directory. Initializes a new Table with the given name and columns.

Example

let columns = vec![
   Column {
       name: "id".to_string(),
       column_type: "number".to_string(),
       length: Some(10),
       decimal_places: None,
       is_nullable: false,
       is_pkey: true,
       ref_table: None,
       ref_column: None,
   },
   Column {
       name: "name".to_string(),
       column_type: "varchar".to_string(),
       length: Some(255),
       decimal_places: None,
       is_nullable: true,
       is_pkey: false,
       ref_table: None,
       ref_column: None,
   },
];

test

let table = Table::init("test_table".to_string(), columns);
assert_eq!(table.name, "test_table");
assert_eq!(table.columns.len(), 2);

To Run simple test

// Initialize tables let order: Table = Table::init_via_sql("create table orders(order_id number(10) primary key, order_date date, customer_id number(10))"); let sql = order.generate(SqlType::CreateTable);

main

use for main.rs

mod models;
 
use models::{Table, SqlType};
use rand::seq::SliceRandom;
use rand::thread_rng;
use std::fs::OpenOptions;
use std::io::Write;
 
fn main() {
    // Get the number of records to generate from the environment variable `NUM_RECORDS`
    let num_records = std::env::var("NUM_RECORDS").unwrap_or("30".to_string()).parse::<i32>().unwrap();
 
    // Open the output file in append mode, creating it if it doesn't exist
    let mut file = OpenOptions::new()
        .append(true)
        .create(true)
        .open("output.sql")
        .expect("Unable to open file");
 
    // Initialize tables
    let order: Table = Table::init_via_sql("create table orders(order_id number(10) primary key, order_date date, customer_id number(10))");
    let customers: Table = Table::init_via_sql("create table customers(customer_id number(10) primary key, customer_name varchar(255), customer_email varchar(255))");
    let products: Table = Table::init_via_sql("create table products(product_id number(10) primary key, product_name varchar(255), product_price number(10, 2))");
 
    let tables = vec![order, customers, products];
 
    // Define SQL types
    let sql_types = vec![
        SqlType::CreateTable,
        SqlType::AlterTable,
        SqlType::DropTable,
        SqlType::Insert,
        SqlType::Select,
        SqlType::Update,
        SqlType::Delete,
    ];
 
    // Generate and write SQL statements to the file
    for _ in 0..num_records {
        let mut rng = thread_rng();
        let random_sql_type = sql_types.choose(&mut rng).unwrap();
        let random_table = tables.choose(&mut rng).unwrap();
 
        let sql = random_table.generate(*random_sql_type);
        writeln!(file, "{}", sql).expect("Unable to write to file");
    }
}

Dependencies

~3.5–4.5MB
~77K SLoC