导出oracle、postgresql、mysql表结构到excel


利用sql查询出表结构数据,将查询结构导出成excel

1.Oracle表结构导出-库中的所有表

不需要改,粘过去执行即可

SELECT t1.Table_Name || chr(13) || t3.comments       AS "表名称及说明",
       --t3.comments                                 AS "表说明",
       t1.Column_Name                                AS "字段名称",
       t1.DATA_TYPE || '(' || t1.DATA_LENGTH || ')'  AS "数据类型",
       t1.NullAble                                   AS "是否为空",
       t2.Comments                                   AS "字段说明",
       t1.Data_Default "默认值"
       --t4.created                                  AS "建表时间"
  FROM cols t1
  LEFT JOIN user_col_comments t2 
         ON t1.Table_name = t2.Table_name
        AND t1.Column_Name = t2.Column_Name
  LEFT JOIN user_tab_comments t3 
         ON t1.Table_name = t3.Table_name
  LEFT JOIN user_objects t4 
         ON t1.table_name = t4.OBJECT_NAME
  WHERE NOT EXISTS (SELECT t4.Object_Name
          FROM User_objects t4
         WHERE t4.Object_Type = 'TABLE'
           AND t4.Temporary = 'Y'
           AND t4.Object_Name = t1.Table_Name)
  ORDER BY t1.Table_Name, t1.Column_ID;

2.postgresql导出表结构-指定表,需要一个个表查出来

需要在C.relname处改成每个指定表的表名

SELECT 
  A.attnum AS "序号",
    C.relname AS "表名",
    ---CAST ( obj_description ( relfilenode, 'pg_class' ) AS VARCHAR ) AS "表名描述",
    A.attname AS "字段名",
		concat_ws ( '', T.typname, SUBSTRING ( format_type ( A.atttypid, A.atttypmod ) FROM '(.*)' ) ) AS "数据类型",
		C.relhaspkey AS "是否主键",
		---IF(A.attnotnull='f','是','否') AS '必填',
    CASE A.attnotnull WHEN 'f' THEN 'Y' ELSE 'N' END,
--  A.attnotnull as 是否为空,
    ---IF(A.attnotnull='f','是','否') AS '必填',
    
    d.description AS "字段说明" 
FROM
    pg_class C,
    pg_attribute A,
    pg_type T,
    pg_description d 
WHERE
--指定的表
    C.relname = '指定的表名' 
    AND A.attnum > 0 
    AND A.attrelid = C.oid 
    AND A.atttypid = T.oid 
    AND d.objoid = A.attrelid 
    AND d.objsubid = A.attnum 
ORDER BY
    C.relname DESC,
    A.attnum ASC

3.mysql导出表结构-库中所有表

不需要改,粘过去执行即可

SELECT
TABLE_NAME 表名,
COLUMN_NAME 列名,
COLUMN_TYPE 数据类型,
DATA_TYPE 字段类型,
CHARACTER_MAXIMUM_LENGTH 长度,
IS_NULLABLE 是否为空,
COLUMN_DEFAULT 默认值,
COLUMN_COMMENT 备注 
FROM
INFORMATION_SCHEMA.COLUMNS
WHERE
-- 对应的数据库
table_schema = '换成指定数据库名'
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在DataGrip中,导出数据库结构和数据是分开的。要导出数据库结构,你可以使用SQL generator来实现。首先,选中要导出的数据,然后右键点击,选择"Import/Export",再选择"Export to files"。这样,每张都会独立导出一个SQL文件,其中记录了对应结构和定义。 要导出数据库数据,你也可以选中要导出的数据,然后右键点击,选择"Import/Export",再选择"Export to file"。在弹出的窗口中,选择输出格式为SQL Insert。这样,每个选中的都会导出一个对应的SQL文件,其中包含了的数据。 但需要注意的是,DataGrip在导出数据库整体到一个SQL脚本的功能方面相较于Navicat有一些不足,需要分别导出结构数据,并且导出数据会生成多个对应的SQL文件。这是DataGrip需要改进的地方,相比之下Navicat能够将数据库结构和内容全部导出到同一个SQL脚本中。 目前,我在网上找不到DataGrip能够实现将整个Oracle数据库导出到单个SQL文件的方法。官方文档中提到的导出功能只适用于MySQLPostgreSQL数据库。 综上所述,DataGrip在导出数据库结构和数据方面有一些不足,需要改进。而要将整个Oracle数据库导出到单个SQL文件,目前我无法找到相关的方法。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [datagrip 导出 Oracle 数据库结构和数据到sql脚本中](https://blog.csdn.net/weixin_44112083/article/details/126860707)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

猪大侠0.0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值