代码生成器Sql Server 和 Mysql 数据库脚本
经常用到代码生成器,对于取数据脚本做个记录:
#region SQL-SqlServer private string SqlTableList = @"SELECT so.name, Convert( VARCHAR(10), ep.[value]) AS [description] FROM sysobjects so(NOLOCK) LEFT JOIN sys.extended_properties ep(NOLOCK) ON ep.major_id=so.id AND ep.minor_id=0 WHERE so.[type]=‘U‘ AND so.name<>‘sysdiagrams‘ ORDER BY so.name"; private string SqlFieldList = @"SELECT c.name, t.name AS [type], c.length AS maxLength, c.isnullable AS isNullable, ( SELECT COUNT(1) FROM sys.identity_columns ic(NOLOCK) WHERE ic.[object_id]=c.id AND ic.column_id=c.colid ) AS isIdentity, ( SELECT VALUE FROM sys.extended_properties ep(NOLOCK) WHERE ep.major_id = c.id AND ep.minor_id=c.colid ) AS [description], [IsPk]=CASE WHEN EXISTS (SELECT 1 FROM sysobjects WHERE xtype=‘PK‘ and parent_obj=c.id and name IN ( SELECT name FROM sysindexes WHERE indid in(SELECT indid FROM sysindexkeys WHERE id = c.id AND colid=c.colid))) THEN 1 ELSE 0 END FROM syscolumns c(NOLOCK) INNER JOIN sys.tables ts(NOLOCK) ON ts.[object_id] = c.id INNER JOIN sys.types t(NOLOCK) ON t.system_type_id=c.xtype INNER JOIN systypes st(NOLOCK) ON st.name=t.name AND st.name<>‘sysname‘ INNER JOIN sysusers su(NOLOCK) ON st.uid=su.uid AND su.name=‘sys‘ --INNER JOIN syscolumns s(NOLOCK) ON c.[object_id]=s.id WHERE ts.name=‘{0}‘ ORDER BY c.id ASC"; #endregion #region SQL-MySql private string SqlTableList_MySql = @"SELECT TABLE_NAME as name, TABLE_COMMENT as description FROM information_schema.TABLES WHERE TABLE_SCHEMA=‘{0}‘"; private string SqlFieldList_MySql = @"SELECT COLUMN_NAME as name, DATA_TYPE as type, IFNULL(CHARACTER_MAXIMUM_LENGTH,0) as maxLength, (CASE IS_NULLABLE WHEN ‘NO‘ THEN 0 ELSE 1 END) as isNullable, 0 as isIdentity, COLUMN_COMMENT as description, (CASE COLUMN_KEY WHEN ‘PRI‘ THEN 1 ELSE 0 END) as IsPk FROM information_schema.COLUMNS WHERE TABLE_SCHEMA=‘{0}‘ AND TABLE_NAME=‘{1}‘ ORDER BY ORDINAL_POSITION ASC"; #endregion
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。