Hide keyboard shortcuts

Hot-keys on this page

r m x p   toggle line displays

j k   next/prev highlighted chunk

0   (zero) top of page

1   (one) first highlighted chunk

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

# -*- coding: utf-8 -*- 

# 

# Licensed under the Apache License, Version 2.0 (the "License"); 

# you may not use this file except in compliance with the License. 

# You may obtain a copy of the License at 

# 

# http://www.apache.org/licenses/LICENSE-2.0 

# 

# Unless required by applicable law or agreed to in writing, software 

# distributed under the License is distributed on an "AS IS" BASIS, 

# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 

# See the License for the specific language governing permissions and 

# limitations under the License. 

 

import logging 

 

from airflow.hooks.mysql_hook import MySqlHook 

from airflow.models import BaseOperator 

from airflow.utils.decorators import apply_defaults 

 

 

class MySqlOperator(BaseOperator): 

""" 

Executes sql code in a specific MySQL database 

 

:param mysql_conn_id: reference to a specific mysql database 

:type mysql_conn_id: string 

:param sql: the sql code to be executed 

: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' 

""" 

 

template_fields = ('sql',) 

template_ext = ('.sql',) 

ui_color = '#ededed' 

 

@apply_defaults 

def __init__( 

self, sql, mysql_conn_id='mysql_default', parameters=None, 

autocommit=False, *args, **kwargs): 

super(MySqlOperator, self).__init__(*args, **kwargs) 

self.mysql_conn_id = mysql_conn_id 

self.sql = sql 

self.autocommit = autocommit 

self.parameters = parameters 

 

def execute(self, context): 

logging.info('Executing: ' + str(self.sql)) 

hook = MySqlHook(mysql_conn_id=self.mysql_conn_id) 

hook.run( 

self.sql, 

autocommit=self.autocommit, 

parameters=self.parameters)