pull/522/head
Mr Chen 1 year ago
parent b4acb2942f
commit 1983d02107
  1. 136
      plugins/data_query/sql_mysql.py
  2. 2
      plugins/data_query/static/html/index.html
  3. 124
      plugins/data_query/static/js/app.js

@ -27,10 +27,11 @@ class nosqlMySQL():
__DB_PASS = None __DB_PASS = None
__DB_USER = None __DB_USER = None
__DB_PORT = 6379 __DB_PORT = 3306
__DB_HOST = '127.0.0.1' __DB_HOST = '127.0.0.1'
__DB_CONN = None __DB_CONN = None
__DB_ERR = None __DB_ERR = None
__DB_SOCKET = None
__DB_LOCAL = None __DB_LOCAL = None
@ -38,41 +39,69 @@ class nosqlMySQL():
self.__config = self.get_options(None) self.__config = self.get_options(None)
def mgdb_conn(self): def conn(self):
if self.__DB_HOST in ['127.0.0.1', 'localhost']: if self.__DB_HOST in ['127.0.0.1', 'localhost']:
my_path = "{}/mysql".format(mw.getServerDir()) my_path = "{}/mysql".format(mw.getServerDir())
if not os.path.exists(my_path): return False if not os.path.exists(my_path): return False
if not self.__DB_LOCAL: if not self.__DB_LOCAL:
# print(self.__config)
self.__DB_PORT = int(self.__config['port']) self.__DB_PORT = int(self.__config['port'])
self.__DB_USER = self.__config['username']
self.__DB_PASS = self.__config['password']
self.__DB_SOCKET = self.__config['socket']
# print(self.__DB_HOST,self.__DB_PORT, self.__DB_PASS)
try: try:
self.__DB_CONN = pymongo.MongoClient(host=self.__DB_HOST, port=self.__DB_PORT, maxPoolSize=10)
self.__DB_CONN.admin.command('ping') db = mw.getMyORM()
return self.__DB_CONN db.setPort(self.__DB_PORT)
except pymongo.errors.ConnectionFailure: db.setPwd(self.__DB_PASS)
return False db.setUser(self.__DB_USER)
if self.__DB_SOCKET != '':
db.setSocket(self.__DB_SOCKET)
return db
except Exception: except Exception:
self.__DB_ERR = mw.get_error_info() self.__DB_ERR = mw.get_error_info()
return False return False
def sqliteDb(self,dbname='databases'):
my_root_path = mw.getServerDir() +'/mysql'
name = 'mysql'
conn = mw.M(dbname).dbPos(my_root_path, name)
return conn
# 获取配置项 # 获取配置项
def get_options(self, get=None): def get_options(self, get=None):
result = {} result = {}
mgdb_content = mw.readFile("{}/mysql/my.conf".format(mw.getServerDir()))
if not mgdb_content: return False
my_cnf_path = "{}/mysql/etc/my.cnf".format(mw.getServerDir())
my_content = mw.readFile(my_cnf_path)
if not my_content: return False
mysql_pass = self.sqliteDb('config').where('id=?', (1,)).getField('mysql_root')
result['password'] = mysql_pass
result['username'] = 'root'
keys = ["bind_ip", "port"] keys = ["bind_ip", "port"]
result['host'] = '127.0.0.1' result['host'] = '127.0.0.1'
rep = 'port\s*=\s*(.*)' rep = 'port\s*=\s*(.*)'
ip_re = re.search(rep, mgdb_content)
if ip_re: port_re = re.search(rep, my_content)
result['port'] = int(ip_re.groups()[0].strip()) if port_re:
result['port'] = int(port_re.groups()[0].strip())
else:
result['port'] = 3306
socket_rep = 'socket\s*=\s*(.*)'
socket_re = re.search(socket_rep, my_content)
if socket_re:
result['socket'] = socket_re.groups()[0].strip()
else: else:
result['port'] = 27017 result['socket'] = ''
return result return result
def set_host(self, host, port, name, username, password, prefix=''): def set_host(self, host, port, name, username, password, prefix=''):
@ -101,36 +130,43 @@ class nosqlMySQLCtr():
def getDbList(self, args): def getDbList(self, args):
sid = args['sid'] sid = args['sid']
mgdb_instance = self.getInstanceBySid(sid).mgdb_conn() my_instance = self.getInstanceBySid(sid).conn()
if mgdb_instance is False: if my_instance is False:
return mw.returnData(False,'无法链接') return mw.returnData(False,'无法链接')
result = {} result = {}
doc_list = mgdb_instance.list_database_names() db_list = my_instance.query('show databases')
rlist = [] rlist = []
for x in doc_list: for x in db_list:
if not x in ['admin', 'config', 'local']: if not x['Database'] in ['information_schema', 'mysql', 'performance_schema','sys']:
rlist.append(x) rlist.append(x['Database'])
result['list'] = rlist result['list'] = rlist
return mw.returnData(True,'ok', result) return mw.returnData(True,'ok', result)
def getCollectionsList(self, args): def getTableList(self, args):
sid = args['sid'] sid = args['sid']
name = args['name'] db = args['db']
mgdb_instance = self.getInstanceBySid(sid).mgdb_conn() my_instance = self.getInstanceBySid(sid).conn()
if mgdb_instance is False: if my_instance is False:
return mw.returnData(False,'无法链接') return mw.returnData(False,'无法链接')
sql = "select * from information_schema.tables where table_schema = '"+db+"'"
table_list = my_instance.query(sql)
# print(table_list)
rlist = []
for x in table_list:
# print(x['TABLE_NAME'])
rlist.append(x['TABLE_NAME'])
result = {} result = {}
collections = mgdb_instance[name].list_collection_names() result['list'] = rlist
result['collections'] = collections
return mw.returnData(True,'ok', result) return mw.returnData(True,'ok', result)
def getDataList(self, args): def getDataList(self, args):
sid = args['sid'] sid = args['sid']
db = args['db'] db = args['db']
collection = args['collection'] table = args['table']
p = 1 p = 1
size = 10 size = 10
if 'p' in args: if 'p' in args:
@ -139,42 +175,32 @@ class nosqlMySQLCtr():
if 'size' in args: if 'size' in args:
size = args['size'] size = args['size']
mgdb_instance = self.getInstanceBySid(sid).mgdb_conn() start_index = (p - 1) * size
if mgdb_instance is False:
return mw.returnData(False,'无法链接')
db_instance = mgdb_instance[db]
collection_instance = db_instance[collection]
start_index = (p - 1) * size args_where = {}
end_index = p * size if 'where' in args:
args_where = args['where'] args_where = args['where']
where = {} my_instance = self.getInstanceBySid(sid).conn()
if 'field' in args_where: if my_instance is False:
mg_field = args_where['field'] return mw.returnData(False,'无法链接')
if mg_field == '_id': my_instance.setDbName(db)
mg_value = ObjectId(args_where['value']) sql = 'select count(*) as num from ' + table
where[mg_field] = mg_value count_result = my_instance.query(sql)
else: count = count_result[0]['num']
mg_value = args_where['value']
where[mg_field] = re.compile(mg_value)
# print(where)
result = collection_instance.find(where).skip(start_index).limit(size).sort({'_id':-1})
count = collection_instance.count_documents(where)
d = []
for document in result:
d.append(document)
doc_str_json = dumps(d) sql = 'select * from ' + table + ' limit '+str(start_index)+',10';
result = json.loads(doc_str_json)
# print(sql)
result = my_instance.query(sql)
# print(result)
page_args = {} page_args = {}
page_args['count'] = count page_args['count'] = count
page_args['tojs'] = 'mongodbDataList' page_args['tojs'] = 'mysqlGetDataList'
page_args['p'] = p page_args['p'] = p
page_args['row'] = size page_args['row'] = size
@ -198,9 +224,9 @@ def get_db_list(args):
return t.getDbList(args) return t.getDbList(args)
# 获取 mysql 列表 # 获取 mysql 列表
def get_collections_list(args): def get_table_list(args):
t = nosqlMySQLCtr() t = nosqlMySQLCtr()
return t.getCollectionsList(args) return t.getTableList(args)
def get_data_list(args): def get_data_list(args):
t = nosqlMySQLCtr() t = nosqlMySQLCtr()

@ -20,7 +20,7 @@
<!-- show w-full --> <!-- show w-full -->
<div class="tab-con hide" id="mysql" style="padding: 0px;"> <div class="tab-con hide" id="mysql" style="padding: 0px;">
<div class="col-md-9" style="padding: 0px;"> <div class="col-md-9" style="padding: 0px;overflow: hidden;">
<div class="tootls_group tootls_top"> <div class="tootls_group tootls_top">
<div class="pull-left"> <div class="pull-left">
<div class="server_list" style="float:left;"> <div class="server_list" style="float:left;">

@ -231,35 +231,143 @@ function mysqlGetSid(){
return 0; return 0;
} }
function mysqlGetDbName(){
return $('#mysql .mysql_db_list select[name=mysql_db]').val();
}
function mysqlGetTableName(){
return $('#mysql .mysql_table_list select[name=mysql_table]').val();
}
function mysqlInitField(f, data){
var option_html = '<option value="0">无字段</option>';
for (var i = 0; i < f.length; i++) {
if (data['soso_field'] == f[i]){
option_html+= '<option value="'+f[i]+'" selected>'+f[i]+'</option>';
} else {
option_html+= '<option value="'+f[i]+'">'+f[i]+'</option>';
}
}
$('select[name="mysql_field_key"]').html(option_html);
$('#mysql .mysql_find').unbind('click').click(function(){
var val = $('input[name="mysql_field_value"]').val();
if (val == ''){
layer.msg('搜索不能为空!',{icon:7});
return;
}
mysqlDataList(1);
});
}
function mysqlGetDbList(){ function mysqlGetDbList(){
var sid = mysqlGetSid(); var sid = mysqlGetSid();
myPostCB('get_db_list',{'sid':sid} ,function(rdata){ myPostCB('get_db_list',{'sid':sid} ,function(rdata){
if (rdata.data.status){ if (rdata.data.status){
var items = rdata.data.data['items']; var items = rdata.data.data['list'];
var content = ''; var content = '';
for (var i = 0; i < items.length; i++) { for (var i = 0; i < items.length; i++) {
var name = items[i]; var name = items[i];
if (i == 0){ if (i == 0){
content += '<option value="'+name+'" selected>items['+name+']</option>'; content += '<option value="'+name+'" selected>database['+name+']</option>';
} else { } else {
content += '<option value="'+name+'">items['+name+']</option>'; content += '<option value="'+name+'">database['+name+']</option>';
} }
} }
$('#memcached .item_list select').html(content); // console.log(content);
$('#memcached .item_list select').change(function(){ $('#mysql .mysql_db_list select[name=mysql_db]').html(content);
memcachedGetKeyList(1); $('#mysql .mysql_db_list select[name=mysql_db]').change(function(){
mysqlGetTableList(1);
}); });
mysqlGetTableList(1);
closeInstallLayer(); closeInstallLayer();
} else { } else {
showInstallLayer(); showInstallLayer();
} }
mysqlGetTableList(1);
}); });
} }
function mysqlGetTableList(p){ function mysqlGetTableList(p){
console.log('mysqlGetTableList',p); // console.log('mysqlGetTableList',p);
var sid = mysqlGetSid();
var db = mysqlGetDbName();
myPostCB('get_table_list',{'sid':sid,'db':db} ,function(rdata){
if (rdata.data.status){
var items = rdata.data.data['list'];
var content = '';
for (var i = 0; i < items.length; i++) {
var name = items[i];
if (i == 0){
content += '<option value="'+name+'" selected>table['+name+']</option>';
} else {
content += '<option value="'+name+'">table['+name+']</option>';
}
}
// console.log(content);
$('#mysql .mysql_table_list select[name=mysql_table]').html(content);
$('#mysql .mysql_table_list select[name=mysql_table]').change(function(){
mysqlGetDataList(1);
});
mysqlGetDataList(1);
}
});
}
function mysqlGetDataList(p){
var sid = mysqlGetSid();
var db = mysqlGetDbName();
var table = mysqlGetTableName();
myPostCB('get_data_list',{'sid':sid,'db':db,'table':table,'p':p} ,function(rdata){
console.log(rdata);
if (rdata.data.status){
if (rdata.data.status){
var data = rdata.data.data;
var dlist = data['list'];
// console.log(dlist);
var fields = mongodbGetDataFields(dlist);
if (fields.length != 0 ){
mysqlInitField(fields,data);
}
var header_field = '';
for (var i =0 ; i<fields.length ; i++) {
header_field += '<th>'+fields[i]+'</th>';
}
$('#mysql_table thead tr').html(header_field);
var tbody = '';
for (var i = 0; i < dlist.length; i++) {
tbody += '<tr>';
for (var j = 0; j < fields.length; j++) {
var f = fields[j];
if (f in dlist[i]) {
tbody += '<td style="white-space: nowrap;text-overflow: ellipsis;overflow: hidden;">'+dlist[i][f]+'</td>';
} else {
tbody += '<td>undefined</td>';
}
}
tbody += '</tr>';
}
// $('#mysql_table').css('width', $('.col-md-9').width()).parent().css('width', $(document).width()).css('overflow','scroll');
// $('#mysql').css('width',$(document).width()-240).css('overflow','hidden');
$('#mysql_table table').css('table-layout','fixed');
$('#mysql_table tbody').html(tbody);
$('#mysql .mysql_list_page').html(data.page);
}
}
});
} }

Loading…
Cancel
Save