当前位置: 首页 > news >正文

PostgreSQL_数据回退,数据库导出、导入

目录

前置:

1 数据回退

1.1 代码

1.2 pgAdmin4 中查看

1)t_daily

2) t_stock_daily

2 数据库导出、导入 


前置:

本博文是一个系列。在本人“数据库专栏”-》“PostgreSQL_”开头的博文。

1 数据回退

上一节“PostgreSQL_数据下载并保存(psycopg2)”,保存了 2023年7月11日 至 2025年2月13日 的数据。任意取一个日期,比如2025年1月10日,回退到这个日期。

1.1 代码

def rollback_to_day_before(date_str:str):
    conn = connect_db()
    '''
    t_stock_daily
    1 找出每只股票 date_str 对应的索引位置
    2 遍历 update 表格
    '''
    cur = conn.cursor()

    # 传入的 date_str 可能不是交易日,如果不是交易日要找到最靠近 date_str 之前的交易日
    sql_q_m_str = f"select max(tradeDateOj) from t_daily where tradeDateOj <= \'{date_str}\';"
    cur.execute(sql_q_m_str)
    res0 = cur.fetchone()
    date_str0 = res0[0].strftime('%Y-%m-%d')

    sql_query_str = f"select ticker,array_position(tradeDate,\'{date_str0}\') from t_stock_daily;"
    cur.execute(sql_query_str)
    res = cur.fetchall()

    sql_update_str = """
    update t_stock_daily set tradeDate=tradeDate[1:%s],openPrice=openPrice[1:%s],highestPrice=highestPrice[1:%s],lowestPrice=lowestPrice[1:%s],closePrice=closePrice[1:%s],turnoverVol=turnoverVol[1:%s],turnoverValue=turnoverValue[1:%s],dealAmount=dealAmount[1:%s],turnoverRate=turnoverRate[1:%s],negMarketValue=negMarketValue[1:%s],marketValue=marketValue[1:%s],chgPct=chgPct[1:%s],PE=PE[1:%s],PE1=PE1[1:%s],PB=PB[1:%s],isOpen=isOpen[1:%s],vwap=vwap[1:%s] where ticker=%s;
    """

    # 删除 t_daily date_str之后的数据
    sql_delete_str = f"delete from t_daily where tradeDateOj>\'{date_str}\';"

    data_list = []
    for one in res:
        one_node = (
            one[1],
            one[1],
            one[1],
            one[1],
            one[1],
            one[1],
            one[1],
            one[1],
            one[1],
            one[1],
            one[1],
            one[1],
            one[1],
            one[1],
            one[1],
            one[1],
            one[1],
            one[0]
        )
        data_list.append(one_node)
        pass

    try:
        cur.executemany(sql_update_str,data_list)
        cur.execute(sql_delete_str)
        conn.commit()
    except Exception as e:
        print(f'error:{e}')
        conn.rollback()
    finally:
        cur.close()
        conn.close()
    pass

1.2 pgAdmin4 中查看

1)t_daily

2) t_stock_daily

select tradeDate[array_length(tradeDate,1)],openPrice[array_length(openPrice,1)],highestPrice[array_length(highestPrice,1)],lowestPrice[array_length(lowestPrice,1)],closePrice[array_length(closePrice,1)],turnoverVol[array_length(turnoverVol,1)],turnoverValue[array_length(turnoverValue,1)],dealAmount[array_length(dealAmount,1)],turnoverRate[array_length(turnoverRate,1)],negMarketValue[array_length(negMarketValue,1)],marketValue[array_length(marketValue,1)],chgPct[array_length(chgPct,1)],PE[array_length(PE,1)],PE1[array_length(PE1,1)],PB[array_length(PB,1)],isOpen[array_length(isOpen,1)],vwap[array_length(vwap,1)] from t_stock_daily where ticker='000001';

2 数据库导出、导入 

导出

1 打开cmd

2 cd 到postgreSQL安装目录的bin目录

执行 

pg_dump -U postgres -h 127.0.0.1 -p 5432 -F c -b -v -f E:/db_stock.dump db_stock

注意:“E:/db_stock.dump”换成自己的路径; db_stock换成要导出的数据库名

导入

 

1 打开cmd

2 cd 到postgreSQL安装目录的bin目录

执行 

dropdb -U postgres -h 127.0.0.1 -p 5432 db_stock

createdb -U postgres -h 127.0.0.1 -p 5432 db_stock

pg_restore -U postgres -h 127.0.0.1 -p 5432 -d db_stock -v D:/db_stock.dump

相关文章:

  • UI自动化测试往往在功能测试之后进行的核心原因
  • 前端技巧第九期JavaScript数据类型
  • 博客图床 VsCode + PicGo + 阿里云OSS,小丑,Github
  • git 设置保存密码 git保存密码
  • 【日志库】—— log4cpp 部署套路
  • [极客大挑战 2019]BabySQL—3.20BUUCTF练习day4(3)
  • 传感器研习社:Swift Navigation与意法半导体(STMicroelectronics)合作 共同推出端到端GNSS汽车自动驾驶解决方案
  • IM项目 ----- 项目部署
  • SZU软件工程大学生涯 2022~2026
  • 语言大模型之BERT
  • Java 大视界 -- Java 大数据中的知识图谱可视化与交互分析技术(141)
  • 数据库面试题一
  • 开箱即用:免费的数据库管理平台 NineData 社区版
  • 安装和部署Tomcat并在idea创建web文件
  • 在linux服务器部署Heygem
  • pdf文件分页按需查看
  • c库、POSIX库、C++库、boost库之间的区别和联系
  • 自动驾驶背后的数学:多模态传感器融合的简单建模
  • 星玲之战.重启誓约(第四章)
  • 玩转C#函数:参数、返回值与游戏中的攻击逻辑封装
  • 江西3人拟提名为县(市、区)长候选人
  • 国家卫健委通报:吊销肖某医师执业证书,撤销董某莹四项证书
  • 国防部:赖清德歪曲二战历史,背叛民族令人不齿
  • 李公明︱一周书记:当前科学观中的盲点、危机与……人类命运
  • 观察|本轮印巴冲突或促使印度空军寻求更先进战机
  • 上海虹桥国际咖啡文化节周五开幕,来看Coffeewalk通关攻略