예제 #1
0
 def execute(self, context: 'Context'):
     self.log.info('Executing: %s', self.sql)
     hook = JdbcHook(jdbc_conn_id=self.jdbc_conn_id)
     if self.do_xcom_push:
         return hook.run(self.sql,
                         self.autocommit,
                         parameters=self.parameters,
                         handler=self.handler)
     else:
         return hook.run(self.sql,
                         self.autocommit,
                         parameters=self.parameters)
예제 #2
0
 def execute(self, context: 'Context') -> None:
     self.log.info('Executing: %s', self.sql)
     hook = JdbcHook(jdbc_conn_id=self.jdbc_conn_id)
     return hook.run(self.sql,
                     self.autocommit,
                     parameters=self.parameters,
                     handler=fetch_all_handler)
예제 #3
0
class JdbcOperator(BaseOperator):
    """
    Executes sql code in a database using jdbc driver.

    Requires jaydebeapi.

    :param sql: the sql code to be executed. (templated)
    :type sql: Can receive a str representing a sql statement,
        a list of str (sql statements), or reference to a template file.
        Template reference are recognized by str ending in '.sql'
    :param jdbc_conn_id: reference to a predefined database
    :type jdbc_conn_id: str
    :param autocommit: if True, each command is automatically committed.
        (default value: False)
    :type autocommit: bool
    :param parameters: (optional) the parameters to render the SQL query with.
    :type parameters: mapping or iterable
    """

    template_fields = ('sql', )
    template_ext = ('.sql', )
    ui_color = '#ededed'

    @apply_defaults
    def __init__(self,
                 sql: str,
                 jdbc_conn_id: str = 'jdbc_default',
                 autocommit: bool = False,
                 parameters: Optional[Union[Mapping, Iterable]] = None,
                 *args,
                 **kwargs) -> None:
        super().__init__(*args, **kwargs)
        self.parameters = parameters
        self.sql = sql
        self.jdbc_conn_id = jdbc_conn_id
        self.autocommit = autocommit

    def execute(self, context):
        self.log.info('Executing: %s', self.sql)
        self.hook = JdbcHook(jdbc_conn_id=self.jdbc_conn_id)
        self.hook.run(self.sql, self.autocommit, parameters=self.parameters)
예제 #4
0
 def execute(self, context):
     self.log.info('Executing: %s', self.sql)
     hook = JdbcHook(jdbc_conn_id=self.jdbc_conn_id)
     hook.run(self.sql, self.autocommit, parameters=self.parameters)