Sybase Anywhere 11 元数据[SQL Schema]

简介:

前言

  近两天的工作是将以前项目的Sybase Anywhere 11数据库表结构以及数据导出到Sqlite上,起初想法是通过PowerDesigner来做反向工程然后再导出。装工具找资料折腾老半天,一方面不是很会用,勉强能将表反向工程到PowerDesigner,导出时又发现不支持Sqlite导出,隐约觉得到时候导数据可能还是有问题,所以决定放弃这条路线。之前有接触过代码生成,对取元数据(表结构)相对熟练,打算自己写代码来导出。由于之前没有接触过Sybase Anywhere 11数据库,所以也差不多弄了一天才把这个语句试出来,备忘和分享一下。

 

致谢

  1.  http://stackoverflow.com/questions/2263300/introspecting-identity-columns-in-sybase-sql-anywhere  是这个帖子中提到的systab帮助我找到相关的表 

 

正文

  一、取得所有用户表

select  st.table_name,st.remarks  from  sysobjects tbl 
inner   join  SYSTABLE st  on  st. object_id   =  tbl.id
where  tbl.type  =   ' U '   and  tbl.uid  =   1


  二、取得表的详细字段信息

复制代码
select  c.name  as  ColumnName, c.length, c.prec, c.scale,baset.name  as   [ DataType ] ,stb.pkey,stb. [ nulls ] ,stb. [ default ] ,stb.remarks
from  sysobjects tbl
inner   join  dbo.syscolumns  as  c  on  tbl.id = c.id
inner   join  SYSTABLE st  on  st. object_id   =  tbl.id
inner   join  SYSCOLUMN stb  on  stb.column_name  =   c.name  and  stb.table_id  =  st.table_id
inner   join  systypes  as  baset  on  c.type  =  baset.type  and  c.usertype  =  baset.usertype
where  tbl.name = ' {0} '   and  tbl.type  =   ' U '   and  tbl.uid  =   1
复制代码

    注意"tbl.name='{0}'"替换成表名,这里就不考虑额外的情况了。

 

  三、注意问题

    3.1  以上取表结构语句不能取到数据类型为“uniqueidentifierstr”的字段,这个字段在sysobjects和syscolumns没有!!但是SYSCOLUMN里面能找到,所以随后需要再研究一下,找到办法了会再来更新此文。

    3.2  取试图和存储过程等其他取元数据的SQL语句随后要用到或者有时间并且能弄出来的话再贴出来更新此文。

 

结束语

  明白原理了,就不用花大把大把的时间去研究人家工具了,一方面有点杀鸡用牛刀,再者自己写的时间比研究工具的时间可能要短,并且更加实用一些(找破解、一动就是几百兆的软件安装 - -#)。再次感谢搜索引擎,虽然没有直接找到,但是给的暗示足够我完成这项任务 : )

 

转载:http://www.cnblogs.com/over140/archive/2010/04/25/1718440.html

目录
相关文章
|
SQL 分布式计算 HIVE
spark sql编程之实现合并Parquet格式的DataFrame的schema
spark sql编程之实现合并Parquet格式的DataFrame的schema
296 0
spark sql编程之实现合并Parquet格式的DataFrame的schema
|
SQL Oracle 关系型数据库
SQL标准对schema如何定义?
ISO/IEC 9075-1 SQL标准中将schema定义为描述符的持久命名集合(a persistent, named collection of descriptors),如果你之前对schema的定义疑惑不解,希望看了我的这篇文章会好一些,起码不会更差。 广义上 造成疑惑的另一个原因可能是由于schema这一术语具有如此广泛的含义,因为它在不同的环境下有不同的含义,schema一词源于希腊语skhēma,意思是形态(form),轮廓(figure),形状(shape)或方案(plan)。Schema在心理学中被用来描述组织信息类别及其之间关系的有组织的思维或行为模式。我们在设计一个数
253 0
|
SQL 关系型数据库 MySQL
SQL 手册-实用 SQL 语句-跨Schema
PolarDB-X 1.0实例中通常有多个Schema,PolarDB-X 1.0支持通过SQL语法进行跨Schema的查询,效果与MySQL的跨Schema查询类似。
558 0
|
SQL 存储 测试技术
表格存储 SQL 元数据操作实战
本文主要介绍表格存储 SQL 支持的元数据操作。 ## 背景说明 如下表所示,目前表格存储 SQL 支持的元数据操作主要分为两大类:DDL操作和Admin操作。其中DDL操作包括:CREATE TABLE, DROP MAPPING TABLE, DESCRIBE TABLE。Admin操作包括:SHOW INDEX, SHOW TABLES。更多的元数据操作将在后续的版本迭代中支持,敬请期待。
208 0
|
SQL NoSQL 关系型数据库
DLA一键发现Tablestore元数据,轻松开启数据湖SQL分析之旅
为了使用DLA标准SQL分析Tablestore数据,往往需要很多步骤才能在DLA中创建相应元数据映射,进而使用SQL去分析Tablestore数据。 现在,数据湖分析DLA发布了一个免费的新功能可以一键快速发现Tablestore元数据,自动创建DLA库表映射到Tablestore的实例和表上,仅倒一杯水的时间即可开启SQL分析Tablestore数据之旅。
DLA一键发现Tablestore元数据,轻松开启数据湖SQL分析之旅
|
SQL Oracle Java
如何将PG,PPAS,oracle,mysql,ms sql,sybase 迁移到 PG, PPAS (支持跨版本升级)
标签 PostgreSQL , PPAS , 迁移 , 跨版本升级 , oracle , mysql , SQL Server , Sybase , 同步 背景 使用EDB的MTK工具,可以完成异构迁移,同构迁移,异平台迁移,版本升级等动作例如: 1、PG, PPAS, oracle, mysql, ms sql, sybase 迁移到 PG, PPAS。
2554 0
|
SQL 存储 Oracle
PostgreSQL Oracle/sql server/SYBASE 兼容性之 - nchar , nvarchar , ntext (unicode character)
标签 PostgreSQL , Oracle , nchar , nvarchar , ntext , ms sql , sybase , unicode character , utf8 背景 在Oracle, MS SQL, SYBASE数据库引擎中,有一些这样的字符串类型nchar , nvarchar , ntext。
1375 0
|
SQL Go 数据库
SQL Server元数据损坏(metadata corruption)修复
原文:SQL Server元数据损坏(metadata corruption)修复   在升级一个SQL Server 2000的数据库时,遇到了一致性错误,其中有几个错误是元数据损坏(metadata corruption),特意研究了一下这个案例,因为以前也零零散散的遇到过一些一致性相关错误,但是难得遇到元数据损坏的案例。
1026 0