124 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			124 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/python
 | |
| import sys
 | |
| import re
 | |
| import os
 | |
| import getopt
 | |
| import mysql.connector
 | |
| import argparse
 | |
| from mysql.connector import errorcode
 | |
| 
 | |
| class SrsDataImporter:
 | |
|     def get_args(self):
 | |
|         parser = argparse.ArgumentParser(conflict_handler='resolve')
 | |
|         parser.add_argument("-h", "--host", help="Connect to host", required=True)
 | |
|         parser.add_argument("-P", "--port", help="Port number to use for connection", required=True)
 | |
|         parser.add_argument("-p", "--password", default = '', help="Password of sys tenant")
 | |
|         parser.add_argument("-f", "--file", help="The sql script for loading default spatial reference system data", required=True)
 | |
|         parser.add_argument("-t", "--tenant", default='sys', help="Tenant for import data if not sys")
 | |
|         args = parser.parse_args()
 | |
|         self.host=args.host
 | |
|         self.port=args.port
 | |
|         self.pwd=args.password
 | |
|         self.file_name=args.file
 | |
|         self.tenant=args.tenant
 | |
|         self.old_result_cnt = [0, 0]
 | |
|         self.new_result_cnt = [0, 0]
 | |
|         self.print_srs_sql = False;
 | |
|         print "host:{0} port:{1} pwd:{2} file:{3}".format(self.host, self.port, self.pwd, self.file_name)
 | |
| 
 | |
|     def generate_sql(self):
 | |
|         self.sql_list = []
 | |
|         with open(self.file_name) as f_read:
 | |
|             for line in f_read:
 | |
|                 if not line.isspace():
 | |
|                     self.sql_list.append(line)
 | |
| 
 | |
|     def connect_server(self):
 | |
|         try:
 | |
|             self.conn = mysql.connector.connect(user='root', password=self.pwd, host=self.host, port=self.port, database='mysql', connection_timeout=10)
 | |
|         except mysql.connector.Error as err:
 | |
|             print(err)
 | |
|             exit("ERROR: failed to connect host")
 | |
|         self.cur = self.conn.cursor(buffered=True)
 | |
|         print "INFO: sucess to connect server {0}:{1}".format(self.host, self.port)
 | |
|         try:
 | |
|             sql = "select value from oceanbase.__all_sys_parameter where name = 'enable_upgrade_mode';"
 | |
|             self.cur.execute(sql)
 | |
|             print "INFO: execute sql -- {0}".format(sql)
 | |
|             result = self.cur.fetchall()
 | |
|             if 1 == len(result) and 1 == result[0][0]:
 | |
|                 self.upgrade_mode = True
 | |
|             else:
 | |
|                 self.upgrade_mode = False
 | |
|                 sql = "select tenant_id from oceanbase.__all_tenant where tenant_name = '{0}';".format(str(self.tenant))
 | |
|                 print "INFO: execute sql -- {0}".format(sql)
 | |
|                 self.cur.execute(sql)
 | |
|                 result = self.cur.fetchall()
 | |
|                 if 1 == len(result):
 | |
|                     print "tenant_id = {0}".format(str(result[0][0]))
 | |
|                     self.tenant_id = result[0][0]
 | |
|                 else:
 | |
|                     print "multiple tenants with the same name, tenant_name: '{0}'".format(self.tenant)
 | |
|             if False == self.upgrade_mode and self.tenant_id != 1:
 | |
|                 sql = "commit"
 | |
|                 self.cur.execute(sql)
 | |
|                 sql = "alter system change tenant " + str(self.tenant)
 | |
|                 print "INFO: execute sql -- {0}".format(sql)
 | |
|                 self.cur.execute(sql)
 | |
|         except mysql.connector.Error as err:
 | |
|             print("ERROR: " + sql)
 | |
|             print(err);
 | |
|             exit("ERROR: failed to import srs data")
 | |
|     def execute_sql(self):
 | |
|         try:
 | |
|             for sql in self.sql_list:
 | |
|                 if self.print_srs_sql == True:
 | |
|                     print "INFO: execute sql -- {0}".format(sql)
 | |
|                 self.cur.execute(sql)
 | |
|         except mysql.connector.Error as err:
 | |
|             print("ERROR: " + sql)
 | |
|             print(err);
 | |
|             self.conn.rollback()
 | |
|             print("ERROR: failed to import srs data")
 | |
|         else:
 | |
|             print("INFO: succeed to import srs data")
 | |
| 
 | |
| 
 | |
|     def execute_prepare_execute(self, table_name, idx):
 | |
|         try:
 | |
|             self.cur.execute("select count(*) from {0}".format(table_name))
 | |
|             result = self.cur.fetchone()
 | |
|             self.old_result_cnt[idx] = result[0]
 | |
|             print "INFO: {0} old result rows -- {1}".format(table_name, self.old_result_cnt[idx])
 | |
|         except mysql.connector.Error as err:
 | |
|             print(err);
 | |
|             exit("ERROR: failed to import srs data")
 | |
| 
 | |
|     def prepare_execute(self):
 | |
|         self.execute_prepare_execute("oceanbase.__all_spatial_reference_systems", 0)
 | |
| 
 | |
|     def execute_check_sql(self, table_name, idx):
 | |
|         self.cur.execute("select count(*) from {0}".format(table_name))
 | |
|         result = self.cur.fetchone()
 | |
|         self.new_result_cnt[idx] = result[0]
 | |
|         print "INFO: {0} old result rows -- {1}".format(table_name, self.old_result_cnt[idx])
 | |
|         print "INFO: {0} new result rows -- {1}".format(table_name, self.new_result_cnt[idx])
 | |
| 
 | |
|     def check_result(self):
 | |
|         self.execute_check_sql("oceanbase.__all_spatial_reference_systems", 0)
 | |
| 
 | |
| def main():
 | |
|     srs_data_importer = SrsDataImporter()
 | |
|     srs_data_importer.get_args()
 | |
|     srs_data_importer.connect_server()
 | |
|     if False == srs_data_importer.upgrade_mode:
 | |
|         srs_data_importer.generate_sql()
 | |
|         srs_data_importer.prepare_execute()
 | |
|         srs_data_importer.execute_sql()
 | |
|         srs_data_importer.check_result()
 | |
|     else:
 | |
|         print("ERROR: cannot import srs data when upgrade_mode is true")
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|     main()
 | 
