VB+SQL数据库管理系统中,如何在无数据源的情况下执行SQL

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

一般的数据库系统编程教程都是在开始编程的时候创建数据库,并在系统中生成用户数据源、系统数据源和文件数据院,在集成开发环境中,通过数据源连接到数据库。那么,如何在没有数据源的情况下,进行编程。生成应用程序要操纵的数据库以及表呢?(如:应用程序在安装完毕后,第一次启动时生成相应的数据库)。

方法:在应用程序的ADO对象的连接字符串中指定DBMS的合法用户名和密码,并指定数据库驱动程序及要连接到目标主机。

如:连接到本机的SQL SERVER 假设 用户名为 SA 密码为空。

连接字符串为:conn_str = "uid=sa;pwd=;driver={sql server};server=(local)"

然后,连接的数据库就可以进行相应的操作了。

下面是我的一个模拟医疗管理系统的原代码(VB):

Public Sub generate_db()

'判断在应用程序的目录下是否有应用程序的数据库文件

Dim db_file As String

db_file = Dir(App.Path + "\test.mdf")

If db_file = "" Then

'定义连接字符串

Dim conn_str As String

conn_str = "uid=sa;pwd=;database=master;driver={sql server};server=(local)"

'声明要使用的对象

Dim conn As New ADODB.Connection

Dim cmd As New ADODB.Command

Dim rs As New ADODB.Recordset

'连接数据源

conn.Open conn_str

'建立查询命令

cmd.CommandText = "create database test on primary(name=test,filename='" & App.Path + "\test.mdf" & "',size=5mb,maxsize=10mb,filegrowth=20%) log on(name=test_log,filename='" & App.Path + "\test_log.ldf" & "',size=2mb,maxsize=4mb,filegrowth=20%)"

'执行命令(用来生成数据库)

conn.Execute cmd.CommandText, Default, -1

'生成数据库需要用到的表

cmd.CommandText = "CREATE TABLE test.[dbo].[db_user] ( [用户名] [varchar] (20) COLLATE Chinese_PRC_CI_AS NOT NULL , [密码] [varchar] (20) COLLATE Chinese_PRC_CI_AS NOT NULL , [权限] [varchar] (20) COLLATE Chinese_PRC_CI_AS NOT NULL , [注册日期] [varchar] (20) COLLATE Chinese_PRC_CI_AS NULL)"

conn.Execute cmd.CommandText, Default, -1

'给数据库一个根用户

cmd.CommandText = "INSERT INTO test.[dbo].db_user VALUES('root','root','管理员','原始用户')"

conn.Execute cmd.CommandText, Default, -1

Else

MsgBox "当前使用的数据库文件状态完好!", vbOKOnly + vbInformation, "提示"

End If

End Sub

2004年10月4日

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航