Sin descripción
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

mosql.py 1.3KB

12345678910111213141516171819202122232425262728293031
  1. # -*- coding: utf-8 -*-
  2. ## @package Lodel.utils.mosql
  3. # @brief Helper function to use mosql library
  4. #
  5. # define create_database and drop_database Query to manipulate databases
  6. # define create, drop and alter Query to manipulate tables
  7. # define create_user, delete_user and grant to manipulate user and rights
  8. from mosql.util import Clause, Statement, Query, value, identifier, concat_by_comma, paren
  9. # chain definitions
  10. column_list = (identifier, concat_by_comma, paren)
  11. # Clauses
  12. create_clause = Clause('create table', alias='create', no_argument=True)
  13. if_not_exists = Clause('if not exists', alias='if_not_exists', no_argument=True, default=True)
  14. table_clause = Clause('table', (identifier, ), alias='table', hidden=True)
  15. character_clause = Clause('CHARACTER SET', (value, ), alias='character')
  16. column_clause = Clause('column', column_list, alias='column', hidden=True)
  17. alter_clause = Clause('alter table', (identifier, ), alias='table')
  18. add_clause = Clause('add column', (identifier, ), alias='column')
  19. # Statements
  20. create_statement = Statement([create_clause, if_not_exists, table_clause, column_clause, character_clause])
  21. alter_add_statement = Statement([alter_clause, add_clause])
  22. # queries
  23. create = Query(create_statement, ('table', 'column', 'if_not_exists'), {'create':True})
  24. alter_add = Query(alter_add_statement, ('table', 'column'))