PostgreSQL.py 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. # -*- coding: utf-8 -*-
  2. __author__ = 'wanger'
  3. __date__ = '2024-08-20'
  4. __copyright__ = '(C) 2024 by siwei'
  5. __revision__ = '1.0'
  6. import time
  7. from typing import Optional
  8. import os
  9. import psycopg2
  10. import uuid
  11. class PostgreSQL:
  12. # 矢量数据元数据表
  13. Vector_Storage = "t_vector_storage"
  14. def __init__(
  15. self,
  16. host: Optional[str] = "192.168.60.2", # default host during installation
  17. port: Optional[str] = "5432", # default port during pg installation
  18. user: Optional[str] = "postgres", # default user during pg installation
  19. password: Optional[str] = "postgis", # default password during pg installation
  20. dbname: Optional[str] = "real3d", # default dbname during pg installation
  21. schema: Optional[str] = None
  22. ):
  23. # 配置数据库连接参数并指定schema
  24. self.connparams = {
  25. "dbname": dbname,
  26. "user": user,
  27. "password": password,
  28. "host": host,
  29. "port": port,
  30. "options": "-c search_path=otherSchema," + schema if schema is not None else None
  31. }
  32. self.conn = psycopg2.connect(**self.connparams)
  33. # 创建一个游标对象
  34. self.cur = self.conn.cursor()
  35. # 执行一个查询
  36. # self.cur.execute("SELECT 省,类型 from \"XZQH3857\";")
  37. # 获取查询结果
  38. # rows = self.cur.fetchall()
  39. # 打印结果
  40. # for row in rows:
  41. # for v in row:
  42. # print(v)
  43. # def execute(self, sql):
  44. # # 执行一个查询
  45. # self.cur.execute(sql)
  46. # # 获取查询结果
  47. # return self.cur.fetchall()
  48. def execute(self, sql, params=None):
  49. try:
  50. if params:
  51. self.cur.execute(sql, params)
  52. else:
  53. self.cur.execute(sql)
  54. # 如果是 SELECT,才 fetch 结果
  55. if sql.strip().lower().startswith("select"):
  56. return self.cur.fetchall()
  57. else:
  58. self.conn.commit()
  59. return None
  60. except Exception as e:
  61. print(f"SQL执行出错:{e}")
  62. self.conn.rollback()
  63. raise
  64. def close(self):
  65. # 关闭游标和连接
  66. self.cur.close()
  67. self.conn.close()
  68. def fetchone(self):
  69. return self.cur.fetchone()
  70. def getManagerTables(self, username='admin'):
  71. sql = f'select t.id "id",name "name", case when t.table_alias != \'\' then t.table_alias else t.name end as "alias", t.ywlx "ywlx" ' \
  72. f'from {self.Vector_Storage} t where t.glbm = (select dept_name from sys_dept d where d.dept_id = (select dept_id from sys_user u where u.user_name = \'{username}\' )) and t.sjlx = \'vector\''
  73. self.cur.execute(sql)
  74. rows = self.cur.fetchall()
  75. return rows
  76. def dropTable(self, tablename):
  77. try:
  78. drop_sql = sql.SQL("DROP TABLE IF EXISTS {}").format(sql.Identifier(tablename))
  79. self.cur.execute(drop_sql)
  80. except Exception as e:
  81. print(f"删除表 {tablename} 失败: {e}")
  82. def getZyml(self):
  83. """获取资源目录数据,按sort字段排序"""
  84. self.cur.execute("""
  85. SELECT *
  86. FROM (
  87. SELECT
  88. t.bsm::text,
  89. t.name::text,
  90. t.pbsm::text,
  91. ''::text AS type,
  92. CASE
  93. WHEN t.sort IS NULL OR t.sort = '' THEN 9999
  94. ELSE CAST(t.sort AS INTEGER)
  95. END AS sort
  96. FROM t_vector_zyml t
  97. ORDER BY t.pbsm,
  98. CASE
  99. WHEN t.sort IS NULL OR t.sort = '' THEN 9999
  100. ELSE CAST(t.sort AS INTEGER)
  101. END
  102. ) AS a
  103. UNION ALL
  104. SELECT
  105. s.name::text AS bsm,
  106. CASE
  107. WHEN s.table_alias IS NULL OR s.table_alias = '' THEN s.name
  108. ELSE s.table_alias
  109. END::text AS name,
  110. s.xmlx::text AS pbsm,
  111. s.sjlx::text AS type,
  112. row_number() OVER (ORDER BY cnt DESC)::integer AS sort
  113. FROM (
  114. SELECT s.*, count(*) OVER (PARTITION BY s.xmlx) AS cnt
  115. FROM t_vector_storage s
  116. JOIN t_vector_zyml z ON s.xmlx = z.bsm OR s.xmlx = z.pbsm
  117. ) s
  118. ORDER BY pbsm, sort
  119. """)
  120. columns = [desc[0] for desc in self.cur.description]
  121. return [dict(zip(columns, row)) for row in self.cur.fetchall()]
  122. def addZyml(self, uid, pid, name):
  123. """添加新的资源目录节点"""
  124. # 获取同级节点的最大sort值
  125. self.cur.execute("SELECT COALESCE(MAX(CAST(sort AS INTEGER)), -1) + 1 FROM t_vector_zyml WHERE pbsm = %s",
  126. (pid,))
  127. sort_val = self.cur.fetchone()[0]
  128. self.cur.execute(
  129. "INSERT INTO t_vector_zyml (bsm, name, pbsm, sort) VALUES (%s, %s, %s, %s)",
  130. (uid, name, pid, sort_val)
  131. )
  132. self.conn.commit()
  133. print(f"添加新节点: {name} (bsm: {uid}, 父节点: {pid}, 排序: {sort_val})")
  134. def updateZymlOrder(self, bsm, pbsm, sort_index):
  135. """更新资源目录节点的父节点和排序"""
  136. self.cur.execute(
  137. "UPDATE t_vector_zyml SET pbsm = %s, sort = %s WHERE bsm = %s",
  138. (pbsm, str(sort_index), bsm) # 将整数转换为字符串存储
  139. )
  140. def deleteZyml(self, bsm):
  141. """删除资源目录节点"""
  142. # 先删除所有子节点
  143. self.cur.execute("DELETE FROM t_vector_zyml WHERE pbsm = %s", (bsm,))
  144. # 再删除自身
  145. self.cur.execute("DELETE FROM t_vector_zyml WHERE bsm = %s", (bsm,))
  146. def renameZyml(self, id, name):
  147. self.cur.execute("update t_vector_zyml set name = '{}' where bsm = '{}'".format(name, id))
  148. self.conn.commit()
  149. def getResourceAttr(self, tablename):
  150. self.cur.execute(
  151. "select t.*, case when t.sjlx = 'vector' then '矢量数据' else '栅格数据' end from t_vector_storage t where name = '{}'".format(
  152. tablename))
  153. rows = self.cur.fetchall()
  154. return rows[0]
  155. # 获取行政区划
  156. def getXzqh(self):
  157. self.cur.execute(
  158. "select t.id, t.name, case when t.pid = '0' then '' else t.pid end from vector.xzqh t order by t.id")
  159. rows = self.cur.fetchall()
  160. return rows
  161. # 判断数据是否为字符串
  162. def is_string(self, var):
  163. return isinstance(var, str)