在我们的程序中,如何新建一个数据库?如何判断一个数据库是否存在?数据库的系统信息是怎样的?如何新建一个数据库表?如何得到一个数据库中所有的表明?等等这些任务,使用程序如何完成?这篇文章所展示的DBSystemHelper类将助你完成这些任务!DBSystemHelper是EnterpriseServerBase类库中DataAccess.DbSystem下的一个帮助类。类中所用到的IADOBase接口及SqlADOBase存在于EnterpriseServerBase.DataAccess命名空间中。
data:image/s3,"s3://crabby-images/04dc6/04dc6fc45c16db5636e23c7bcbde53f8f6fa00c5" alt=""
/**//// <summary>
/// DBSystemHelper 用于提供数据库系统自身的信息,并提供对数据库自身的操作。目前主要针对SqlServer数据库。
/// 朱伟 2005.08.17
/// </summary>
public class DBSystemHelper
data:image/s3,"s3://crabby-images/04dc6/04dc6fc45c16db5636e23c7bcbde53f8f6fa00c5" alt=""
{
public DBSystemHelper()
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
}
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
GetAllDbSysInfos ,IsDbExist ,GetDbSysInformation#region GetAllDbSysInfos ,IsDbExist ,GetDbSysInformation
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
/**//// <summary>
/// 得到所有数据库的系统信息
/// </summary>
public static DbSysInformation[] GetAllDbSysInfos(string dbIP , string user ,string pwd)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
string connStr = string.Format("Server = {0} ;User = {1} ;Pwd = {2}" ,dbIP ,user ,pwd) ;
IADOBase adoBase = new SqlADOBase(connStr);
try
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
DataSet ds = adoBase.DoQuery("sp_helpdb") ;
DbSysInformation[] dbInfos = new DbSysInformation[ds.Tables[0].Rows.Count] ;
for(int i=0; i<dbInfos.Length ;i++)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
dbInfos[i].ID = int.Parse(ds.Tables[0].Rows[i]["DbID"].ToString()) ;
dbInfos[i].Name = ds.Tables[0].Rows[i]["Name"].ToString() ;
dbInfos[i].Owner = ds.Tables[0].Rows[i]["Owner"].ToString() ;
dbInfos[i].TimeCreated = DateTime.Parse(ds.Tables[0].Rows[i]["Created"].ToString()) ;
}
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
return dbInfos ;
}
catch(Exception ee)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
throw ee ;
}
}
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
/**//// <summary>
/// 判断某个数据库是否存在
/// </summary>
public static bool IsDbExist(string dbIP , string user ,string pwd ,string dbName)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
DbSysInformation[] dbInfos = DBSystemHelper.GetAllDbSysInfos(dbIP ,user ,pwd) ;
for(int i=0 ;i<dbInfos.Length ;i++)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
if(dbInfos[i].Name == dbName)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
return true ;
}
}
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
return false ;
}
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
/**//// <summary>
/// 得到指定数据库的系统信息
/// </summary>
public static DbSysInformation GetDbSysInformation(string dbIP , string user ,string pwd ,string dbName)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
DbSysInformation[] dbInfos = DBSystemHelper.GetAllDbSysInfos(dbIP ,user ,pwd) ;
for(int i=0 ;i<dbInfos.Length ;i++)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
if(dbInfos[i].Name == dbName)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
return dbInfos[i] ;
}
}
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
return null ;
}
#endregion
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
GetAllTableNames ,IsTableExist#region GetAllTableNames ,IsTableExist
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
/**//// <summary>
/// 得到指定数据库中所有用户表的名字
/// </summary>
public static string[] GetAllTableNames(string connStr)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
IADOBase adoBase = new SqlADOBase(connStr);
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
string query = "select name from sysobjects where OBJECTPROPERTY(id ,'IsUserTable')=1" ;
DataSet ds = adoBase.DoQuery(query) ;
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
string[] names = new string[ds.Tables[0].Rows.Count] ;
for(int i=0 ;i<ds.Tables[0].Rows.Count ;i++)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
names[i] = ds.Tables[0].Rows[i][0].ToString() ;
}
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
return names ;
}
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
/**//// <summary>
/// 判断特定的数据库中是否存在某个表
/// </summary>
public static bool IsTableExist(string connStr ,string tableName)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
string[] names = DBSystemHelper.GetAllTableNames(connStr) ;
for(int i=0 ;i<names.Length ;i++)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
if(names[i] == tableName)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
return true ;
}
}
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
return false ;
}
#endregion
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
CreateDb ,RemoveDb#region CreateDb ,RemoveDb
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
/**//// <summary>
/// 创建一个新的数据库
/// </summary>
public static void CreateDb(string dbIP , string user ,string pwd ,string newDbName)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
string connStr = string.Format("Server = {0} ;User = {1} ;Pwd = {2}" ,dbIP ,user ,pwd) ;
IADOBase adoBase = new SqlADOBase(connStr);
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
string command = string.Format("Create database {0}" ,newDbName ) ;
adoBase.DoCommand(command) ;
}
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
/**//// <summary>
/// 删除指定数据库
/// </summary>
public static void RemoveDb(string dbIP , string user ,string pwd ,string dbName)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
string connStr = string.Format("Server = {0} ;User = {1} ;Pwd = {2}" ,dbIP ,user ,pwd) ;
IADOBase adoBase = new SqlADOBase(connStr);
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
string command = string.Format("Drop database {0}" ,dbName ) ;
adoBase.DoCommand(command) ;
}
#endregion
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
BackUpDb ,RestoreDb#region BackUpDb ,RestoreDb
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
/**//// <summary>
/// 备份指定数据库
/// </summary>
public static void BackUpDb(string dbIP , string user ,string pwd ,string dbName ,string bakFilePath)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
string connStr = string.Format("Server = {0} ;User = {1} ;Pwd = {2}" ,dbIP ,user ,pwd) ;
IADOBase adoBase = new SqlADOBase(connStr);
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
string command = string.Format("use {0} backup database {0} to disk = '{1}'" ,dbName ,bakFilePath) ;
adoBase.DoCommand(command) ;
}
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
/**//// <summary>
/// 还原指定数据库
/// </summary>
public static void RestoreDb(string dbIP , string user ,string pwd ,string bakFilePath ,string dbName )
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
string connStr = string.Format("Server = {0} ;User = {1} ;Pwd = {2}" ,dbIP ,user ,pwd) ;
IADOBase adoBase = new SqlADOBase(connStr);
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
string command = string.Format("use {0} restore database {0} from disk = '{1}'" ,dbName ,bakFilePath) ;
adoBase.DoCommand(command) ;
}
#endregion
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
CreateTable ,RemoveTable#region CreateTable ,RemoveTable
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
/**//// <summary>
/// 在数据库中创建指定表
/// </summary>
public void CreateTable(string connStr ,DBTableDetail tableInfo)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
//形成SQL语句
StringBuilder strBuilder = new StringBuilder() ;
string str_create = string.Format("Create Table {0}" ,tableInfo.TableName) ;
strBuilder.Append(str_create) ;
strBuilder.Append(" (") ;
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
int start =0 ;
if(tableInfo.Columns[0].ColumnType == "int")
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
if(tableInfo.Columns[0].IsAutoID)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
strBuilder.Append(string.Format("{0} int PRIMARY KEY IDENTITY ," ,tableInfo.Columns[0].ColumnName)) ;
start =1 ;
}
}
for(int i=start ;i<tableInfo.Columns.Length ;i++)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
bool length_fixed = DBSystemHelper.DBType_lengthFixed(tableInfo.Columns[i].ColumnType) ;
string item ;
if(length_fixed)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
item = string.Format("{0} {1} " ,tableInfo.Columns[i].ColumnName ,tableInfo.Columns[i].ColumnType) ;
}
else
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
item = string.Format("{0} {1}({2}) " ,tableInfo.Columns[i].ColumnName ,tableInfo.Columns[i].ColumnType) ;
}
if((tableInfo.Columns[i].DefaultValue != null) && (tableInfo.Columns[i].DefaultValue != ""))
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
item += string.Format("DEFAULT {0}" ,tableInfo.Columns[i].DefaultValue) ;
}
if(tableInfo.Columns[i].IsPkey)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
item += "PRIMARY KEY" ;
}
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
if(i != tableInfo.Columns.Length-1)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
item += " , " ;
}
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
strBuilder.Append(item) ;
}
strBuilder.Append(" )") ;
//插入数据库
IADOBase adoBase = new SqlADOBase(connStr);
adoBase.DoCommand(strBuilder.ToString()) ;
}
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
/**//// <summary>
/// 删除数据库中的指定表
/// </summary>
public void RemoveTable(string connStr ,string tableName)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
IADOBase adoBase = new SqlADOBase(connStr);
string deleteStr = string.Format("Drop Table {0}" ,tableName) ;
adoBase.DoCommand(deleteStr) ;
}
data:image/s3,"s3://crabby-images/6cc3f/6cc3f53be81891e78416e646c9f0e9c36aff62f9" alt=""
private static bool DBType_lengthFixed(string DB_type)
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
if(DB_type == "nvarchar" || DB_type == "varbinary")
data:image/s3,"s3://crabby-images/983a7/983a712ef2dacf1a78097b7d97f93aaaa23b83f0" alt=""
{
return false ;
}
return true ;
}
#endregion
}
data:image/s3,"s3://crabby-images/e98b6/e98b62895bf644c8dba05fe6d386dc53433055e5" alt=""
data:image/s3,"s3://crabby-images/04dc6/04dc6fc45c16db5636e23c7bcbde53f8f6fa00c5" alt=""
/**//// <summary>
/// 某个数据库的系统信息
/// </summary>
public class DbSysInformation
data:image/s3,"s3://crabby-images/04dc6/04dc6fc45c16db5636e23c7bcbde53f8f6fa00c5" alt=""
{
public int ID ;
public string Name ;
public string Owner ;
public DateTime TimeCreated ;
}