分享
 
 
 

Install Shield制作安装包技巧(SQL篇)

王朝mssql·作者佚名  2006-01-31
窄屏简体版  字體: |||超大  

对SQL数据库的操作我们首先要判断SQL Server是否安装,然后启动SQL Server。

再通过osql.exe执行SQL语句进行数据库操作。 下面是针对这几种操作的一些函数:

1、检查SQL Server是否安装

prototype CheckSQL();

function CheckSQL()

BOOL bSuccess;

NUMBER nType, nvSize;

STRING szVer;

STRING szSetupVer, szSetupPath;

begin

RegDBSetDefaultRoot ( HKEY_LOCAL_MACHINE );

szSetupPath = "SOFTWARE\\Microsoft\\MSSQLServer\\Setup";

szSetupVer = "SOFTWARE\\Microsoft\\MSSQLServer\\MSSQLServer\\CurrentVersion";

//获取SQL Server版本

nType = REGDB_STRING;

if (RegDBGetKeyValueEx ( szSetupVer, "CurrentVersion" , nType , szVer , nvSize ) < 0) then

bSuccess = FALSE;

else

//获取SQL Server安装路径

if (RegDBGetKeyValueEx ( szSetupPath, "SQLPath" , nType , szSQLPATH , nvSize ) < 0) then

bSuccess = FALSE;

else

bSuccess = TRUE;

endif;

endif;

return bSuccess;

end;

2、检查SQL Server版本号,是否安装了SP3

prototype CheckSQLVersion();

function CheckSQLVersion()

BOOL bSuccess;

NUMBER nType, nvSize;

STRING szVer;

STRING szSetupVer;

begin

RegDBSetDefaultRoot ( HKEY_LOCAL_MACHINE );

bSuccess = FALSE;

szSetupVer = "SOFTWARE\\Microsoft\\MSSQLServer\\MSSQLServer\\CurrentVersion";

nType = REGDB_STRING;

if (RegDBGetKeyValueEx ( szSetupVer, "CSDVersion" , nType , szVer , nvSize ) < 0) then

bSuccess = FALSE;

else

if szVer = '8.00.761' then

bSuccess = TRUE;

endif;

endif;

return bSuccess;

end;

3、启动SQL Server服务器

prototype StartSQLServr(STRING, STRING);

//传入用户名,用户密码

function StartSQLServr(szLoginName, szPassword)

BOOL bSuccess;

VARIANT objSQL;

begin

objSQL = CreateObject("SQLDMO.SQLServer");

if IsObject(objSQL) then

try

try

objSQL.Start(TRUE, "(Local)", szLoginName, szPassword);

catch

objSQL.Connect("(Local)", szLoginName, szPassword);

endcatch;

catch

bSuccess = FALSE;

return bSuccess;

endcatch;

else

bSuccess = FALSE;

return bSuccess;

endif;

if objSQL.VerifyConnection then

bSuccess = TRUE;

else

bSuccess = FALSE;

endif;

return bSuccess;

end;

4、检查数据库是否已经存在

prototype IsExistDB(STRING, STRING, STRING);

//传入用户名,用户密码,数据库名

function IsExistDB(szLoginName, szPassword, szDBName)

BOOL bExist;

NUMBER i;

STRING szTemp;

VARIANT objSQL;

begin

objSQL = CreateObject("SQLDMO.SQLServer");

objSQL.Connect("(Local)", szLoginName, szPassword);

bExist = FALSE;

for i = 1 to objSQL.Databases.Count

StrToUpper(szTemp, objSQL.Databases.Item(i).Name);

if (szTemp == szDBName) then

bExist = TRUE;

return bExist;

endif;

endfor;

return bExist;

end;

5、删除数据库

prototype DeleteDB(STRING, STRING, STRING);

//传入用户名,用户密码,数据库名

function DeleteDB(szLoginName, szPassword, szDBName)

STRING szSQL;

begin

szSQL = "declare @dttm varchar(55) \n"

+ "select @dttm=convert(varchar,getdate(),113)\n"

+ "raiserror('Beginning Check Database at %s ....',1,1,@dttm) with nowait \n"

+ "GO \n"

+ "use master \n"

+ "go \n"

+ "if exists (select * from sysdatabases where name='" + szDBName + "') \n"

+ "begin \n"

+ "raiserror('Dropping existing " + szDBName + " database ....',0,1) \n"

+ " DROP database " + szDBName + "\n"

+ "end \n"

+ " GO \n"

+ "CHECKPOINT \n"

+ "go \n";

if !ExecuteSQL(szLoginName, szPassword, szSQL) then

return FALSE;

endif;

return TRUE;

end;

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有