MaxComputer-Pyodps之mysql ddl 批量生成odps ddl
系统环境:windows 64 位
python版本:2.7
Maxcomputer(原ODPS)
----- 1、安装python2.7(略过,百度一下就可以)
----- 2、安装MySQLdb模块
windows下个人习惯pip 安装 whl文件,虽然不是所有都能顺利安装,但是大部分还是可以的。
下载地址:
https://www.lfd.uci.edu/~gohlke/pythonlibs/#mysql-python
下载到本地后,cmd进入dos环境,可以直接切换到下载目录,直接使用命令 pip install mysqlclient-1.3.13-cp27-cp27m-win_amd64.whl
或者pip-script.py install mysqlclient-1.3.13-cp27-cp27m-win_amd64.whl
编译方法:
1、创建个xxx.py
的文件,进入dos,切换到py文件路径:python xxx.py
2、使用编译工具:PyCharm、Maxcomputer Studio等工具执行
#!/usr/bin/python # -*- coding: UTF-8 -*- # author:zhy import MySQLdb ##### mysql数据库配置 def exec_sql(sql): conn=MySQLdb.connect(host='数据库地址',user='用户',passwd='密码',db=TABLE_SCHEMA,charset='utf8') cursor = conn.cursor() cursor.execute(sql) rows = cursor.fetchall() cursor.close() conn.close() return rows #### schema TABLE_SCHEMA='mysql' # mysql数据库元数据库 sys_id='s01' # ods入edw规范:表名+前缀 target_schema='odps_project' #odps对应项目名称 ##### 获取mysql表名 sql=''' select table_name from information_schema.`TABLES` where TABLE_SCHEMA='%s' and table_type='BASE TABLE' '''%TABLE_SCHEMA exec_relusts=exec_sql(sql) # sql执行结果为二维 out_comment='' # 定义输出参数 ###以下并不包含所有mysql字段类型的转换 for i in exec_relusts: TABLE_NAME = i[0] print TABLE_NAME sql=''' select TABLE_NAME ,COLUMN_NAME ,case when DATA_TYPE in ('varchar','char','date','longtext','text') then 'string' when DATA_TYPE in ('float') then 'double' when DATA_TYPE = 'tinyint' then 'int' when DATA_TYPE = 'timestamp' then 'datetime' else DATA_TYPE end as DATA_TYPE ,COLUMN_COMMENT from information_schema.`COLUMNS` where TABLE_SCHEMA = '%s' and TABLE_NAME = '%s' order by TABLE_NAME,ORDINAL_POSITION '''%(TABLE_SCHEMA,TABLE_NAME) rows=exec_sql(sql) sql=''' show create table %s.%s '''%(TABLE_SCHEMA,TABLE_NAME) sql_exec_result= exec_sql(sql) ddl_info0= sql_exec_result[0][1] if ddl_info0.find('COMMENT=')>1: ddl_table_common = ddl_info0[ddl_info0.index("COMMENT="):] ddl_table_common= ddl_table_common.replace('=',' ') else: ddl_table_common="COMMENT ''" ddl_info='CREATE TABLE IF NOT EXISTS %s.%s_%s (\n'%(target_schema,sys_id,TABLE_NAME) for row in rows: row3=row[3].replace('\r\n','\\r\\n') row3=row3.replace('\n','\\n') ddl_info=ddl_info+ str(row[1]).upper()+' '+row[2].upper()+' '+"COMMENT'"+ row3+"'\n," ddl_info=ddl_info+')' ddl_info=ddl_info.replace(')',')') ddl_info=ddl_info+'\n'+ddl_table_common+"\nPARTITIONED BY (PT STRING COMMENT '数据日期')".decode('utf-8') #如不需分区,需修改 out_comment= out_comment+'-- '+TABLE_NAME +'\n'+ddl_info +'\n;\n' # print out_comment # 将DDL语句输出到文件 Output_File=r'D:\data\output'+'\\'+sys_id+'_'+TABLE_SCHEMA+'.sql' file_w=file(Output_File,"w") file_w.write(out_comment.encode("utf-8")) file_w.close()

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
JavaScript—日期(21)
简介 JavaScript通过强大的对象为我们提供日期处理功能:日期。 本文确实_不是_谈论 Moment.js ,我认为它是处理日期的最佳库,你应该在处理日期时几乎总是使用它。 Date对象 Date对象实例表示单个时间点。 尽管被命名为Date,它也处理时间。 初始化Date对象我们使用初始化Date对象 new Date() 这将创建一个指向当前时刻的Date对象。 在内部,日期以1970年1月1日(UTC)以来的毫秒数表示。这个日期很重要,因为就计算机而言,这就是一切开始的地方。 您可能熟悉UNIX时间戳:它表示自该着名日期以来经过的seconds数。 重要:UNIX时间戳的原因以秒为单位。JavaScript以毫秒为单位记录原因。 如果我们有UNIX时间戳,我们可以使用实例化JavaScript Date对象 const timestamp = 1530826365 new Date(timestamp * 1000) 如果我们传递0,我们将得到一个Date对象,表示1970年1月1日(UTC)的时间: new Date(0) 如果我们传递一个字符串而不是一个数字,那么Dat...
- 下一篇
JavaScript—Chrome 调试(22)
本文包括浏览器调试,不包括web移动端调试。本文调试均在chrome浏览器进行 alert这个不用多说了,不言自明 console基本输出想必大家都在用console.log在控制台输出点东西,其实console还有其它的方法: console.log("打印字符串");//在控制台打印自定义字符串 console.error("我是个错误");//在控制台打印自定义错误信息 console.info("我是个信息");//在控制台打印自定义信息 console.warn("我是个警告");//在控制台打印自定义警告信息 console.debug("我是个调试");//在控制台打印自定义调试信息 cosole.clear();//清空控制台(这个下方截图中没有) 注意上面输出的error和throw出的error不一样,前者只是输出错误信息,无法捕获,不会冒泡,更不会中止程序运行。 格式化输出除此以外,console还支持自定义样式和类似c语言的printf形式 console.log("%s年",2016);//%s表示字符串 console.log("%d年%d月",2016,1...
相关文章
文章评论
共有0条评论来说两句吧...