Inno Setup connection to the database and create
原文 Inno Setup connection to the database and create
Description: the first half of this program in Inno Setup instance inside there, behind the database backup and restore inside the instance is not easy to find online, I spent a great difficulty sentence try out , please Zhuanzhai marked to indicate the respect of the individual labor. Thank you!
[Code]
{--- SQLDMO ---} / / about SQLDMO of knowledge can go online
const
/ / SQL server name, the name when installing SQL will be asked to enter the server name, the name you see when you open the SQL server on each machine is different, as I as shown below, but here we can use a generic The name is the (local) , Which means that the server is local. That's it.
SQLServerName = '(LOCAL)';
SQLDMOGrowth_MB = 0;
/ / This is to create a button press event, this button is in the Setup Wizard page, create a configuration database "button
to procedure SQLDMOButtonOnClick (Sender: TObject);
var
/ / Used in some of the variables
SQLServer, Database, DBFile, LogFile: Variant;
IDColumn, NameColumn, Table, oBackup, oRestore: Variant;
db_path: string;
/ / Variable to store read the registry key value
ResultStr: String;
begin
{Create the main SQLDMO COM Automation object}
/ / Check if you installed SQL
try
SQLServer: = CreateOleObject ('SQLDMO.SQLServer');
except
RaiseException ('You did not install the SQL database.' # 13 # 13 '(Error''' + GetExceptionMessage +'' 'occurred)');
end;
{Connect to the Microsoft SQL Server}
/ / Connect to SQL
SQLServer.LoginSecure: = True;
SQLServer.Connect (SQLServerName);
/ / MsgBox ('connection to SQL Server''' + SQLServerName +'' '.' MbInformation, MB_OK);
{Setup a database}
/ / Create the SQL database file
Database: = CreateOleObject ('SQLDMO.Database');
Database.Name: = 'dbase'; / / To create a database name
DBFile: = CreateOleObject ('SQLDMO.DBFile');
DBFile.Name: = 'ISData1';
/ / Database records
DBFile.PhysicalName: = 'c :/ program files / microsoft sql server / mssql / data / dbase_Data.MDF';
DBFile.PrimaryFile: = True;
DBFile.FileGrowthType: = SQLDMOGrowth_MB;
DBFile.FileGrowth: = 1;
Database.FileGroups.Item ('PRIMARY'). DBFiles.Add (DBFile);
LogFile: = CreateOleObject ('SQLDMO.LogFile');
LogFile.Name: = 'ISLog1';
/ / Database diary.
LogFile.PhysicalName: = 'c :/ program files / microsoft sql server / mssql / data / dbase_Log.LDF';
Database.TransactionLog.LogFiles.Add (LogFile);
{Add the database}
/ / Add database
SQLServer.Databases.Add (Database);
/ / MsgBox ('Added database''' + Database.Name +'' '.', MbInformation, mb_Ok);
/ / Data backup
oBackup: = CreateOleObject ('SQLDMO.Backup'); / / create a backup object
oBackup.Database: = 'louyu'; / / To back up the database name
oBackup.Files: = 'f :/ louyu3.bak'; / / backup to
oBackup.BackupSetName: = 'louyu3.bak'; / / name of the backup
oBackup.BackupSetDescription: = 'bakDescription';
oBackup.Initialize: = true;
oBackup.SQLBackup (SQL Server); / / execute SQL backup operation
/ / Restore the data
Highlights:
/ / Database backup file in a position to lay the package you want to restore the database to find the backup file first, then find the backup file before the software installation to where we need to know, which is the installation path. Installation in the registry to establish the relevant information, including software installation path recorded on the registry, please see the above write the INNO SETUP Registry Add read.
Why restore the database in this way, it seems to be around a circle, in fact, I also think that this may not be a good way, but I do not know any other way to get the data in the installation package ( file path) or software to be installed. {App}, {pf} such as this can not be directly used, why we have such a stupid way.
If any friends have a good way, please let me know.
/ / Get the installation path from the registry, according to the path found to restore the database backup file.
if RegQueryStringValue (HKLM, 'SOFTWARE / *******', 'Server', ResultStr) then
begin
ResultStr: = RemoveQuotes (ResultStr);
msgbox (resultstr, mbinformation, mb_ok);
try
oRestore: = CreateOleObject ('SQLDMO.Restore'); / / create a restore object
oRestore.Database: = 'dbase'; / / restore the database name
db_path: = resultstr + '/ database file / dbase.bak'; / / path of the backup file
The MsgBox (DB_PATH mbinformation, MB_OK); / / test to see the path right
oRestore.files: = db_path; / / Specify the backup file
oRestore.replacedatabase: = true;
oRestore.sqlrestore (sqlserver); / / perform the restore operation
MsgBox ('database restore was successful!', Mbinformation, MB_OK);
except
MsgBox ('database restore failed, please try again or consult the help documentation manual configuration!' Mbinformation, MB_OK);
end;
end;
end;
/ / Database creation and restore events finished, but it does not know when to perform intelligent, so we have to tell it when to perform. Here is the program is finished installing, At the end of the page BUTTON button, when this button is pressed, the database incident response.
{---}
/ / Create a button
procedure CreateButton (ALeft, ATop: Integer; ACaption: String; ANotifyEvent: TNotifyEvent);
begin
create with TButton.Create (WizardForm) do begin / / button object
Left: to = ALeft; / / Button's position and the width and height
Top: = ATop;
Width: = WizardForm.CancelButton.Width;
Height: = WizardForm.CancelButton.Height;
Caption: = ACaption; / / button name
OnClick: = ANotifyEvent;
/ / This is to create a button to specify a parent window, which means that it displayed in which the top of the page
Parent: = WizardForm.finishedPage; / / specified here is the end of the page of the form
end;
end;
/ / Initialization Wizard window
the procedure InitializeWizard ();
var
Left, Top, TopInc: Integer;
begin
Left: = WizardForm.WelcomeLabel2.Left;
TopInc: = WizardForm.CancelButton.Height + 8;
Top: = WizardForm.WelcomeLabel2.Top + WizardForm.WelcomeLabel2.Height - 4 * TopInc;
/ / Created above button displayed, and assign it a response event
CreateButton (Left, Top, '& configuration SQL database' _AT_ SQLDMOButtonOnClick);
Top: = Top + TopInc;
end;
Inno Setup connection to the database and create的更多相关文章
- INNO SETUP数据库的连接与创建
原文:INNO SETUP数据库的连接与创建 说明一下:这块程序的前半部分在INNO SETUP的实例里面就有,而后面如果对数据库进行备份和还原在实例里面没有,在网上也不好找,是本人费了好大劲一句一句 ...
- 用Inno Setup制作WEB程序安装包
原文 用Inno Setup制作WEB程序安装包 最近做了一个WEB程序的安装包,我把制作的过程做个介绍,贴出源码给大家做个参考 看看inno 的脚本 [Setup] AppCopyright=tes ...
- 【转载】inno setup 水波纹效果,检测安装vcredist_x86.exe等
以下inno setup脚本,实现了:1.水波纹效果 2.安装时检测是否安装其他版本,并在欢迎页面添加文字提示 4.检测安装vcredist_x86.exe 3.卸载时添加提示 ; 脚本由 Inno ...
- 一个简单的inno setup模板
一.模板代码 基本功能包括多路径安装.多语言.自定义图标. [Setup] ShowLanguageDialog=yes AppCopyright=Copyright Reserved(C) , 36 ...
- Inno Setup怎样创建一个自动申请管理员身份运行的快捷
如果你使用的是 Unicode 版本的 Inno Setup,那么以下是更为专业的解决方法. 这是 mlaan 提及的再一种方法. QUOTE( CodeAutomation3.iss) ...
- 以前编写的inno setup脚本,涵盖了自定义安装界面,调用dll等等应用 (转)
以前编写的inno setup脚本,涵盖了自定义安装界面,调用dll等等应用 (转) ; Script generated by the Inno Setup 脚本向导. ; SEE THE DOCU ...
- Inno Setup使用技巧
一.关于Inno Setup如何在安装时播放音乐 方法(1): 在脚本编译里的[Code]与[Files]段处添加以下代码: [Code] Function mciSendString(lpszCom ...
- 用inno Setup做应用程序安装包的示例脚本(.iss文件)(
用innoSetup做应用程序安装包的示例脚本(.iss文件),具体要看innoSetup附带的文档,好象是pascal语言写的脚本. 示例1(应用程序.exe,客户端安装): ;{089D6802- ...
- inno setup介绍及官方网站地址
使 用 笔 记 1.Inno Setup 是什么?Inno Setup 是一个免费的 Windows 安装程序制作软件.第一次发表是在 1997 年,Inno Setup 今天在功能设置和稳定性上的竞 ...
随机推荐
- Youtube最佳Red5 官方视频下载指南,字幕【亲测成功】
前言 最近在研究Red5 流媒体服务框架,官网上的信息足以让一个新手入门 有官方參考手冊 -- 高速了解red5的相关信息 有Red5 on Stackoverflow -- 在上面能够提问或者回答 ...
- CPU 风扇清理灰尘加油全过程图解
主机电源风扇因为使用时间长,风扇轴承的润滑油耗尽,导致风扇转速下降或是不转,引起电源热量无法有效排除而造成电脑常常死机,解决的方法有几种. 现图讲解明最简单省钱的办法例如以下: 1.把电源从主机上拆下 ...
- 每天收获一点点------Hadoop之HDFS基础入门
一.HDFS出现的背景 随着社会的进步,需要处理数据量越来越多,在一个操作系统管辖的范围存不下了,那么就分配到更多的操作系统管理的磁盘中,但是却不方便管理和维护—>因此,迫切需要一种系统来管理多 ...
- 在四川大学的第二个冠军游戏在线编程:Peter的X
四川大学线下编程比赛第二题:Peter的X 公布公司: 有 效 期: CSDN 2014-09-27至2015-09-26 难 度 等 级: 答 题 时 长: 编程语言要求: 120分钟 C C++ ...
- 挑逗B少年搞计划10 假设你是愿意用我的心脏层剥离一层~
这些天都非常推迟考试啊.然后,学校已安排一周培训,是的.在延迟学习,大狼医院我真的是正常水平. 幸好我们周六周日不让放假了,不然预计进度直接就停了.这两天也是抽出了时间把敲了一下三层的 ...
- React实践(一)
该实践取自官方教程:https://github.com/reactjs/react-tutorial 主要是自实现的过程以及一些心得体会 该实践是实现一个评论框. 一个展示所有评论的视图 一个提交评 ...
- sql server 更新表,每天的数据分固定批次设置批次号sql
按表中的字段 UpdateTime 按每天进行编号,每天的编号都从1开始编号,并附带表的主键 cid,把数据存入临时表中 WITH temp AS (SELECT cid,updatetime, RO ...
- Apache conf文件配置个人总结
其实说到conf文件的配置,网上那必定是大堆大堆的,故今儿写着篇小博文,也只是做个总结,至于分享的价值吗,如果对屏幕前的你有用,我也很乐意啦. 首先,我们要找到Apache安装目录,我的是Ap ...
- ASP.NET 5 (vNext)
ASP.NET 5 (vNext) 理解和入门 概述 ASP.NET 5 (又称为vNext) 是自ASP.NET产生15年以来一次革命性的更新, 我们可以从以下几点来理解其概貌和意义: ASP. ...
- vim添加自己//解决方案
使用vim从外面将代码复制并粘贴到时间,假设有一排//凝视.自己主动下一行加入//和每行增加一个<tab>.格全乱:其他编辑器*.c *cpp其他文件格当公式,假设有一排//凝视,按o换行 ...