获取SQL SERVER中的所有数据库:
SQL数据库信息,存储在master 表中的,可执行SQL语句来获取数据库信息:
SELECT * FROM sysdatabases
用此查询获取的结果集中,name 字段为数据库的名字。下面是我使用的用来获取数据库信息的函数,供大家参考:
/// <summary>
/// 获取指定SQL SERVER 中的所有数据库
/// </summary>
/// <returns></returns>
public DataSet GetDatabase()
{
DataProvider.Custom.SqlQuery sqlQuery = new DataProvider.Custom.SqlQuery();
sqlQuery.Sql = "SELECT * FROM sysdatabases";
using (CustomDataProvider db = GetDatabaseConnection())
{
return db.ExecuteDataSet(sqlQuery);
}
}
上述代码中所使用的类SqlQuery 是为CustomDataProvider类执行查询使用的,这两个类封装了ADO.NET对数据库的操作,同时支持SQL SERVER和ACCESS,可实现两种数据库的相互转化,支持.NET 1.1。其中CustomDataProvider 类的ExecuteDataSet方法执行了一个SQL语句,并返回包含查询结果的数据集。这样的封装网上有很多,这里不再多讲。/// 获取指定SQL SERVER 中的所有数据库
/// </summary>
/// <returns></returns>
public DataSet GetDatabase()
{
DataProvider.Custom.SqlQuery sqlQuery = new DataProvider.Custom.SqlQuery();
sqlQuery.Sql = "SELECT * FROM sysdatabases";
using (CustomDataProvider db = GetDatabaseConnection())
{
return db.ExecuteDataSet(sqlQuery);
}
}
获取数据库中的用户表,SQL语句:
SELECT id,name FROM sysobjects WHERE xtype='U' AND name <> 'dtproperties'
函数:
/// <summary>
/// 获取指定数据库中的所有表
/// </summary>
/// <param name="database">数据库的名字</param>
/// <returns></returns>
public DataSet GetTableList(string database)
{
DataProvider.Custom.SqlQuery sqlQuery = new DataProvider.Custom.SqlQuery();
sqlQuery.Sql = "SELECT id,name FROM sysobjects WHERE xtype='U' AND name <> 'dtproperties'";
using (CustomDataProvider db = GetDatabaseConnection(database))
{
return db.ExecuteDataSet(sqlQuery);
}
}
获取表中的所有字段信息:/// 获取指定数据库中的所有表
/// </summary>
/// <param name="database">数据库的名字</param>
/// <returns></returns>
public DataSet GetTableList(string database)
{
DataProvider.Custom.SqlQuery sqlQuery = new DataProvider.Custom.SqlQuery();
sqlQuery.Sql = "SELECT id,name FROM sysobjects WHERE xtype='U' AND name <> 'dtproperties'";
using (CustomDataProvider db = GetDatabaseConnection(database))
{
return db.ExecuteDataSet(sqlQuery);
}
}
/// <summary>
/// 获取指定表中的所有字段
/// </summary>
/// <param name="database">数据库的名字</param>
/// <param name="table">要获取字段的表</param>
/// <returns></returns>
public DataSet GetColumsList(string database, string table)
{
DataProvider.Custom.SqlQuery sqlQuery = new DataProvider.Custom.SqlQuery();
sqlQuery.Sql = @"SELECT a.colorder 列序号, a.name 列名, (CASE WHEN COLUMNPROPERTY(a.id,
a.name, 'IsIdentity') = 1 THEN '√' ELSE '' END) 标识, (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 '√' ELSE '' END) 主键, b.name 类型,
a.length 占用字节数, COLUMNPROPERTY(a.id, a.name, 'PRECISION') AS 长度,
isnull(COLUMNPROPERTY(a.id, a.name, 'Scale'), 0) AS 小数位数,
(CASE WHEN a.isnullable = 1 THEN '√' ELSE '' END) 允许空, isnull(e.text, '') 默认值,
isnull(g.[value], '') AS 字段说明
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
sysproperties g ON a.id = g.id AND a.colid = g.smallid
WHERE d .name = @table
ORDER BY a.id, a.colorder";
sqlQuery.AddParameter("@table", table);
using (CustomDataProvider db = GetDatabaseConnection(database))
{
return db.ExecuteDataSet(sqlQuery);
}
}
/// 获取指定表中的所有字段
/// </summary>
/// <param name="database">数据库的名字</param>
/// <param name="table">要获取字段的表</param>
/// <returns></returns>
public DataSet GetColumsList(string database, string table)
{
DataProvider.Custom.SqlQuery sqlQuery = new DataProvider.Custom.SqlQuery();
sqlQuery.Sql = @"SELECT a.colorder 列序号, a.name 列名, (CASE WHEN COLUMNPROPERTY(a.id,
a.name, 'IsIdentity') = 1 THEN '√' ELSE '' END) 标识, (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 '√' ELSE '' END) 主键, b.name 类型,
a.length 占用字节数, COLUMNPROPERTY(a.id, a.name, 'PRECISION') AS 长度,
isnull(COLUMNPROPERTY(a.id, a.name, 'Scale'), 0) AS 小数位数,
(CASE WHEN a.isnullable = 1 THEN '√' ELSE '' END) 允许空, isnull(e.text, '') 默认值,
isnull(g.[value], '') AS 字段说明
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
sysproperties g ON a.id = g.id AND a.colid = g.smallid
WHERE d .name = @table
ORDER BY a.id, a.colorder";
sqlQuery.AddParameter("@table", table);
using (CustomDataProvider db = GetDatabaseConnection(database))
{
return db.ExecuteDataSet(sqlQuery);
}
}
有了上述的介绍,相信读者可以自己编写出遍历数据库的程序了。剩下的事情就是根据自己的需要,通过上述获取的数据库信息生成代码(很长的字符串相加,看起来会很麻烦,没什么难度),并进行保存。下边是我编写的类中生成数据访问层接口的函数:
public string CreateIDALCode()
{
string className = _calssName;
string nameSpace = _nameSpace;
string strTime; //获取系统时间
StringBuilder result = new StringBuilder();
result.Append(
@"using System;
using System.Data;
using System.Collections;
using DBUtility.Generic;
using " + nameSpace + @".Model;
using " + nameSpace + @".Collection;
namespace " + nameSpace + @".IDAL
{
/// <summary>
/// I" + className + @" 的摘要说明
/// </summary>
/// <remarks>
/// 作者:" + _author + @"
/// 时间:" + strTime + @"
/// </remarks>
public interface I" + className + @" : IDisposable
{
/// <summary>
/// 执行命令的 DbHelper 实例对象
/// </summary>
DbHelper DbHelper
{
get;
}
/// <summary>
/// 增加一条数据
/// </summary>
/// <returns>新增记录的自增 ID</returns>
int Add" + className + @"(" + className + " " + className.Substring(0, 1).ToLower() + className.Substring(1) + @");
/// <summary>
/// 删除一条数据
/// </summary>
/// <returns>删除记录的行数/returns>
int Delete" + className + @"(int id);
/// <summary>
/// 修改记录数
/// </summary>
/// <returns>被修改的记录数/returns>
int Update" + className + @"(" + className + " " + className.Substring(0, 1).ToLower() + className.Substring(1) + @");
/// <summary>
/// 获取给定 ID 的指定记录
/// </summary>
/// <param name=" + "\"id\"" + @">将要获取记录的 ID </param>
/// <returns>返回 " + className + @" 类的一个实例对象</returns>
" + className + @" Get" + className + @"(int id);
/// <summary>
/// 获取所有的记录
/// </summary>
/// <returns>包含所有记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"();
/// <summary>
/// 获取记录的条数
/// </summary>
/// <returns>数据库中记录的条数</returns>
int GetCount();
/// <summary>
/// 获取页面数量
/// </summary>
/// <param name=""pageSize"">页面大小</param>
/// <returns>页面数量</returns>
int GetPageCount(int pageSize);
/// <summary>
/// 获取指定页面的记录
/// </summary>
/// <param name=" + "\"pageSize\"" + @">页面记录数量</param>
/// <param name=" + "\"pageIndex\"" + @">要获取的页面</param>
/// <returns>包含所有记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(int pageSize, int pageIndex);
/// <summary>
/// 获取满足指定条件的记录
/// </summary>
/// <param name=""filter"">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <returns>包含符合条件的记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(SqlQuery filter);
/// <summary>
/// 获取记录的条数
/// </summary>
/// <param name=""filter"">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <returns>数据库中记录的条数</returns>
int GetCount(SqlQuery filter);
/// <summary>
/// 获取页面数量
/// </summary>
/// <param name=""filter"">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=""pageSize"">页面大小</param>
/// <returns>页面数量</returns>
int GetPageCount(SqlQuery filter,int pageSize);
/// <summary>
/// 获取满足指定条件的记录
/// </summary>
/// <param name=""filter"">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=""count"">查询结果包含的记录数</param>
/// <returns>包含符合条件记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(SqlQuery filter,int count);
/// <summary>
/// 获取指定页面的记录
/// </summary>
/// <param name=""filter"">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=" + "\"pageSize\"" + @">页面记录数量</param>
/// <param name=" + "\"pageIndex\"" + @">要获取的页面</param>
/// <returns>包含符合条件的记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(SqlQuery filter, int pageSize, int pageIndex);
/// <summary>
/// 获取满足指定条件的记录
/// </summary>
/// <param name=" + "\"filter\"" + @">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=" + "\"order\"" + @">排序字段( SQL 中 ORDER BY 后边的条件)</param>
/// <returns>包含符合条件记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(SqlQuery filter, string order);
/// <summary>
/// 获取满足指定条件的记录
/// </summary>
/// <param name=" + "\"filter\"" + @">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=" + "\"order\"" + @">排序字段( SQL 中 ORDER BY 后边的条件)</param>
/// <param name=" + "\"count\"" + @">查询结果的数量</param>
/// <returns>包含符合条件记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(SqlQuery filter, string order, int count);
/// <summary>
/// 获取满足指定条件的记录
/// </summary>
/// <param name=" + "\"filter\"" + @">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=" + "\"order\"" + @">排序字段( SQL 中 ORDER BY 后边的条件)</param>
/// <param name=" + "\"pageSize\"" + @">页面记录数量</param>
/// <param name=" + "\"pageIndex\"" + @">要获取的页面</param>
/// <returns>包含符合条件记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(SqlQuery filter, string order, int pageSize, int pageIndex);
/// <summary>
/// 获取满足指定条件的记录。可以指定要获取的字段。
/// </summary>
/// <param name=" + "\"fields\"" + @">结果集中的字段</param>
/// <param name=" + "\"filter\"" + @">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=" + "\"order\"" + @">排序字段( SQL 中 ORDER BY 后边的条件)</param>
/// <returns>包含符合条件记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(string fields, SqlQuery filter, string order);
/// <summary>
/// 获取满足指定条件的记录。可以指定要获取的字段。
/// </summary>
/// <param name=" + "\"fields\"" + @">结果集中的字段</param>
/// <param name=" + "\"filter\"" + @">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=" + "\"order\"" + @">排序字段( SQL 中 ORDER BY 后边的条件)</param>
/// <param name=" + "\"count\"" + @">查询结果的数量</param>
/// <returns>包含符合条件记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(string fields, SqlQuery filter, string order, int count);
/// <summary>
/// 获取满足指定条件的记录。可以指定分页和要获取的字段
/// </summary>
/// <param name=" + "\"fields\"" + @">结果集中的字段</param>
/// <param name=" + "\"filter\"" + @">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=" + "\"order\"" + @">排序字段( SQL 中 ORDER BY 后边的条件)</param>
/// <param name=" + "\"pageSize\"" + @">页面记录数量</param>
/// <param name=" + "\"pageIndex\"" + @">要获取的页面</param>
/// <returns>包含符合条件记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(string fields, SqlQuery filter, string order, int pageSize, int pageIndex);
/// <summary>
/// 启动事务
/// </summary>
void BeginTrans();
/// <summary>
/// 提交事务
/// </summary>
void Commit();
/// <summary>
/// 事务回滚
/// </summary>
void Rollback();
}
}"
);
return result.ToString();
}
{
string className = _calssName;
string nameSpace = _nameSpace;
string strTime; //获取系统时间
StringBuilder result = new StringBuilder();
result.Append(
@"using System;
using System.Data;
using System.Collections;
using DBUtility.Generic;
using " + nameSpace + @".Model;
using " + nameSpace + @".Collection;
namespace " + nameSpace + @".IDAL
{
/// <summary>
/// I" + className + @" 的摘要说明
/// </summary>
/// <remarks>
/// 作者:" + _author + @"
/// 时间:" + strTime + @"
/// </remarks>
public interface I" + className + @" : IDisposable
{
/// <summary>
/// 执行命令的 DbHelper 实例对象
/// </summary>
DbHelper DbHelper
{
get;
}
/// <summary>
/// 增加一条数据
/// </summary>
/// <returns>新增记录的自增 ID</returns>
int Add" + className + @"(" + className + " " + className.Substring(0, 1).ToLower() + className.Substring(1) + @");
/// <summary>
/// 删除一条数据
/// </summary>
/// <returns>删除记录的行数/returns>
int Delete" + className + @"(int id);
/// <summary>
/// 修改记录数
/// </summary>
/// <returns>被修改的记录数/returns>
int Update" + className + @"(" + className + " " + className.Substring(0, 1).ToLower() + className.Substring(1) + @");
/// <summary>
/// 获取给定 ID 的指定记录
/// </summary>
/// <param name=" + "\"id\"" + @">将要获取记录的 ID </param>
/// <returns>返回 " + className + @" 类的一个实例对象</returns>
" + className + @" Get" + className + @"(int id);
/// <summary>
/// 获取所有的记录
/// </summary>
/// <returns>包含所有记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"();
/// <summary>
/// 获取记录的条数
/// </summary>
/// <returns>数据库中记录的条数</returns>
int GetCount();
/// <summary>
/// 获取页面数量
/// </summary>
/// <param name=""pageSize"">页面大小</param>
/// <returns>页面数量</returns>
int GetPageCount(int pageSize);
/// <summary>
/// 获取指定页面的记录
/// </summary>
/// <param name=" + "\"pageSize\"" + @">页面记录数量</param>
/// <param name=" + "\"pageIndex\"" + @">要获取的页面</param>
/// <returns>包含所有记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(int pageSize, int pageIndex);
/// <summary>
/// 获取满足指定条件的记录
/// </summary>
/// <param name=""filter"">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <returns>包含符合条件的记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(SqlQuery filter);
/// <summary>
/// 获取记录的条数
/// </summary>
/// <param name=""filter"">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <returns>数据库中记录的条数</returns>
int GetCount(SqlQuery filter);
/// <summary>
/// 获取页面数量
/// </summary>
/// <param name=""filter"">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=""pageSize"">页面大小</param>
/// <returns>页面数量</returns>
int GetPageCount(SqlQuery filter,int pageSize);
/// <summary>
/// 获取满足指定条件的记录
/// </summary>
/// <param name=""filter"">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=""count"">查询结果包含的记录数</param>
/// <returns>包含符合条件记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(SqlQuery filter,int count);
/// <summary>
/// 获取指定页面的记录
/// </summary>
/// <param name=""filter"">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=" + "\"pageSize\"" + @">页面记录数量</param>
/// <param name=" + "\"pageIndex\"" + @">要获取的页面</param>
/// <returns>包含符合条件的记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(SqlQuery filter, int pageSize, int pageIndex);
/// <summary>
/// 获取满足指定条件的记录
/// </summary>
/// <param name=" + "\"filter\"" + @">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=" + "\"order\"" + @">排序字段( SQL 中 ORDER BY 后边的条件)</param>
/// <returns>包含符合条件记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(SqlQuery filter, string order);
/// <summary>
/// 获取满足指定条件的记录
/// </summary>
/// <param name=" + "\"filter\"" + @">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=" + "\"order\"" + @">排序字段( SQL 中 ORDER BY 后边的条件)</param>
/// <param name=" + "\"count\"" + @">查询结果的数量</param>
/// <returns>包含符合条件记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(SqlQuery filter, string order, int count);
/// <summary>
/// 获取满足指定条件的记录
/// </summary>
/// <param name=" + "\"filter\"" + @">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=" + "\"order\"" + @">排序字段( SQL 中 ORDER BY 后边的条件)</param>
/// <param name=" + "\"pageSize\"" + @">页面记录数量</param>
/// <param name=" + "\"pageIndex\"" + @">要获取的页面</param>
/// <returns>包含符合条件记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(SqlQuery filter, string order, int pageSize, int pageIndex);
/// <summary>
/// 获取满足指定条件的记录。可以指定要获取的字段。
/// </summary>
/// <param name=" + "\"fields\"" + @">结果集中的字段</param>
/// <param name=" + "\"filter\"" + @">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=" + "\"order\"" + @">排序字段( SQL 中 ORDER BY 后边的条件)</param>
/// <returns>包含符合条件记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(string fields, SqlQuery filter, string order);
/// <summary>
/// 获取满足指定条件的记录。可以指定要获取的字段。
/// </summary>
/// <param name=" + "\"fields\"" + @">结果集中的字段</param>
/// <param name=" + "\"filter\"" + @">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=" + "\"order\"" + @">排序字段( SQL 中 ORDER BY 后边的条件)</param>
/// <param name=" + "\"count\"" + @">查询结果的数量</param>
/// <returns>包含符合条件记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(string fields, SqlQuery filter, string order, int count);
/// <summary>
/// 获取满足指定条件的记录。可以指定分页和要获取的字段
/// </summary>
/// <param name=" + "\"fields\"" + @">结果集中的字段</param>
/// <param name=" + "\"filter\"" + @">filter 过滤参数( filter.Sql 标识 SQL 中 WHERE 后边的条件,filter.Parameters为相应的参数)</param>
/// <param name=" + "\"order\"" + @">排序字段( SQL 中 ORDER BY 后边的条件)</param>
/// <param name=" + "\"pageSize\"" + @">页面记录数量</param>
/// <param name=" + "\"pageIndex\"" + @">要获取的页面</param>
/// <returns>包含符合条件记录的 " + className + @"Collection 实例</returns>
" + className + @"Collection Get" + className + @"(string fields, SqlQuery filter, string order, int pageSize, int pageIndex);
/// <summary>
/// 启动事务
/// </summary>
void BeginTrans();
/// <summary>
/// 提交事务
/// </summary>
void Commit();
/// <summary>
/// 事务回滚
/// </summary>
void Rollback();
}
}"
);
return result.ToString();
}