Metadata-Version: 2.1
Name: simple-ddl-generator
Version: 0.2.0
Summary: Library to generate DDL for different dialects
Author: Iuliia Volkova
Author-email: xnuinside@gmail.com
Requires-Python: >=3.8,<4.0
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.8
Classifier: Topic :: Software Development
Classifier: Topic :: Software Development :: Libraries
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: Topic :: Utilities
Requires-Dist: jinja2 (>=3.0.3,<4.0.0)
Requires-Dist: table-meta (>=0.2.1,<0.3.0)
Description-Content-Type: text/x-rst


Simple DDL Generator
--------------------


.. image:: https://img.shields.io/pypi/v/simple-ddl-generator
   :target: https://img.shields.io/pypi/v/simple-ddl-generator
   :alt: badge1
 
.. image:: https://img.shields.io/pypi/l/simple-ddl-generator
   :target: https://img.shields.io/pypi/l/simple-ddl-generator
   :alt: badge2
 
.. image:: https://img.shields.io/pypi/pyversions/simple-ddl-generator
   :target: https://img.shields.io/pypi/pyversions/simple-ddl-generator
   :alt: badge3
 
.. image:: https://github.com/xnuinside/simple-ddl-generator/actions/workflows/main.yml/badge.svg
   :target: https://github.com/xnuinside/simple-ddl-generator/actions/workflows/main.yml/badge.svg
   :alt: workflow


What is it?
-----------

Simple DDL Generator generate SQL DDL from 3 different inputs. Idea of the generator same as for parser to support as much as possible DDLs in future.

Simple DDL Generator generate SQL DDL from 3 input formats - 1st from output Simple DDL Parser (https://github.com/xnuinside/simple-ddl-parser), 2nd from py-models-parser - https://github.com/xnuinside/py-models-parser. Or you can directly pass TableMeta classes (https://github.com/xnuinside/table-meta) to generator

Generate DDL from Django, SQLAlchemy, Dataclasses, Pydantic models and other
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Generator can generate DDL from all models that supported & parsed by https://github.com/xnuinside/py-models-parser.

If you need DDL generation from another Python Model types - open issue request to add support for this models in parser. 

How to use
----------

As usually - more samples in tests/ 

.. code-block:: bash


       pip install simple-ddl-generator

Generate / Modify using existed DDL with Simple-DDL-Parser
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Sample how you can modify your DDL using Simple DDL Parser & Simple DDL Parser

.. code-block:: python


       from simple_ddl_generator import DDLGenerator
       from simple_ddl_parser import DDLParser

       # take initial DDL
       ddl = """CREATE EXTERNAL TABLE IF NOT EXISTS database.table_name
           (
               day_long_nm     string,
               calendar_dt     date,
               source_batch_id string,
               field_qty       decimal(10, 0),
               field_bool      boolean,
               field_float     float,
               create_tmst     timestamp,
               field_double    double,
               field_long      bigint
           ) PARTITIONED BY (batch_id int);"""
       # get result from parser
       data = DDLParser(ddl).run(group_by_type=True, output_mode="bigquery")

       # rename, for example, table name

       data["tables"][0]["table_name"] = "new_table_name"
       g = DDLGenerator(data)
       g.generate()
       print(g.result)

       # and result will be:

       """
       CREATE EXTERNAL TABLE "database.new_table_name" (
       day_long_nm string,
       calendar_dt date,
       source_batch_id string,
       field_qty decimal(10, 0),
       field_bool boolean,
       field_float float,
       create_tmst timestamp,
       field_double double,
       field_long bigint)
       PARTITIONED BY (batch_id int);
       """

Generate DDL from various Python Models with py-models-parser
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

.. code-block:: python


       from simple_ddl_generator import DDLGenerator
       from py_models_parser import parse

       # you can also read them from file
       model_from = """
           class Material(BaseModel):

               id: int
               title: str
               description: Optional[str]
               link: str = 'http://'
               type: Optional[MaterialType]
               additional_properties: Optional[Json]
               created_at: Optional[datetime.datetime] = datetime.datetime.now()
               updated_at: Optional[datetime.datetime]
           """
       # get data with parser
       result = parse(model_from)

       # pass data to DDL Generator
       g = DDLGenerator(result)
       g.generate()
       print(g.result)  

       # resul will be

       """CREATE TABLE "Material" (
   id INTEGER,
   title VARCHAR,
   description VARCHAR,
   link VARCHAR DEFAULT 'http://',
   type MaterialType,
   additional_properties JSON,
   created_at DATETIME DEFAULT now(),
   updated_at DATETIME);
   """

Changelog
---------

**v0.2.0**


#. Updated parser version in tests.
#. Added support for EXTERNAL & IF NOT EXISTS statetements.
#. Added support for using py-models-parser output as input and added sample in README.md:

DDL Generation from Pydantic, SQLAlchemy and other python models.

**v0.1.0**

Base Generator Functionality with several test cases.

