关系数据库元数据处理类(一) 创建MSSQL元数据具体处理类

 1 public class SqlServer : BaseMetadata
 2     {
 3 
 4         public SqlServer(string connectionString)
 5             : base(new DbUtility(connectionString, DbProviderType.SqlServer))
 6         {
 7 
 8         }
 9 
10         protected override string GetDataBaseSting()
11         {
12             return "Select name FROM Master..SysDatabases order by Name";
13         }
14 
15         protected override string GetDataTableString(string database = "")
16         {
17             return "SELECT " +
18                    " Name = case when a.colorder = 1 then d.name else '' end," + //表名称
19                    " Explain = case when a.colorder = 1 then isnull(f.value, '') else '' end " + //表说明
20                    " FROM syscolumns a " +
21                    " inner join sysobjects d on a.id = d.id and d.xtype = 'U' and d.name <> 'sys.extended_properties' " +
22                    " left join sys.extended_properties f on a.id = f.major_id and f.minor_id = 0 " +
23                    " Where (case when a.colorder = 1 then d.name else '' end) <>''";
24         }
25 
26         protected override string GetDataColumnString()
27         {
28             return "SELECT  " +
29                    "TableName= d.name," +
30                    "Name = a.name, " +
31                    "IsMarke =(case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then '1'else '0' end)," +
32                    "IsPrimarykey= (case when (SELECT count(*) FROM sysobjects WHERE (name in (SELECT name FROM sysindexes WHERE (id = a.id) AND (indid in (SELECT indid FROM sysindexkeys WHERE (id = a.id) AND (colid in (SELECT colid FROM syscolumns WHERE (id = a.id) AND (name = a.name))))))) AND (xtype = 'PK'))>0 then '1' else '0' end)," +
33                    "Type =b.name," +
34                    "Bytes=a.length, " +
35                    "Length=COLUMNPROPERTY(a.id,a.name,'PRECISION')," +
36                    "DecimalPlaces = isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0)," +
37                    "IsNull=(case when a.isnullable=1 then '1'else '0' end), " +
38                    "DefaultValue=isnull(e.text,'')," +
39                    "Explain=isnull(g.[value], ' ')" +
40                    " FROM syscolumns a left join systypes b on a.xtype=b.xusertype inner join sysobjects d on a.id=d.id and d.xtype='U' and d.name<>'dtproperties' left join syscomments e on a.cdefault=e.id left join sys.extended_properties g on a.id=g.major_id AND a.colid=g.minor_id left join sys.extended_properties f on d.id=f.class and f.minor_id=0 where b.name is not null --WHERE d.name='要查询的表' --如果只查询指定表,加上此条件 order by a.id,a.colorder";
41         }
42 
43         protected override string GetDataRelationString()
44         {
45             return
46                 "SELECT 外键表ID = b.fkeyid , ForeignTableName = object_name(b.fkeyid) , 外键列ID = b.fkey , ForeignKeyName = (SELECT name FROM syscolumns WHERE colid = b.fkey AND id = b.fkeyid) , 主键表ID = b.rkeyid , PrimaryTableName = object_name(b.rkeyid) , 主键列ID = b.rkey , PrimaryKeyName = (SELECT name FROM syscolumns WHERE colid = b.rkey AND id = b.rkeyid) , 级联更新 = ObjectProperty(a.id,'CnstIsUpdateCascade') , 级联删除 = ObjectProperty(a.id,'CnstIsDeleteCascade') FROM sysobjects a JOIN sysforeignkeys b ON a.id = b.constid JOIN sysobjects c ON a.parent_obj = c.id WHERE a.xtype = 'F' AND c.xtype = 'U' ";
47         }
48 
49         protected override List<Database> ConversionDatabase(DataTable table)
50         {
51             return Mapper.DynamicMap<IDataReader, List<Database>>(table.CreateDataReader());
52         }
53 
54         protected override List<Table> ConversionDataTable(DataTable table)
55         {
56             return Mapper.DynamicMap<IDataReader, List<Table>>(table.CreateDataReader());
57         }
58 
59         protected override List<Column> ConversionColumn(DataTable table)
60         {
61             return Mapper.DynamicMap<IDataReader, List<Column>>(table.CreateDataReader());
62         }
63 
64         protected override List<Relation> ConversionDataRelation(DataTable table)
65         {
66             return Mapper.DynamicMap<IDataReader, List<Relation>>(table.CreateDataReader());
67         }
68     }

 

posted @ 2014-04-07 11:29  OneWork  阅读(244)  评论(0编辑  收藏  举报