连接数据库:
TADOCONNECTION(Conn);
connstr:='Provider=MSDASQL.1;Extended Properties="DBQ=DELPHI.MDB;
Driver={Microsoft Access Driver (*.mdb)}";';
//或者Driver={Microsoft Access Driver (*.mdb)}";Password=用户密码;User ID=用户名';
Conn.connectionstring:=connstr;
conn.open;
TADOCONNECTION(Conn);
connstr:='Provider=MSDASQL.1;Extended Properties="DBQ=DELPHI.MDB;
Driver={Microsoft Access Driver (*.mdb)}";';
//或者Driver={Microsoft Access Driver (*.mdb)}";Password=用户密码;User ID=用户名';
Conn.connectionstring:=connstr;
conn.open;
解决方案 »
- delphi中 treeview中GetNextChild()方法的参数的意义
- 怎么获取当前浏览器中所有打开的网页地址,及标题?
- 能不能把数据表的记录全部(有上百个字段)递归放在TStrings中(或数组中,或记录中),并能查录字符串是否在其中,那个会更好点,
- 关于怎么样定时将windows的服务启动?------再线等......
- datetimepicker问题!谢谢
- 请给点思路,谢谢。
- 关于access连接oracle(急)
- 关于自己制作控件定义属性使用TStrings遇到的问题
- UniDAC控件操作sqlite的简单例程,为什么会报错呢?
- 请教关于AdoDataSet使用的问题
- 如何在程序里控制打印纸张大小(A3,A4)和打印方向?不想打开设置窗口
- 在Delphi4中,使用FormulaOne6控件的EditCopy方法,提示出错“Unable to open clipboard”,请问如何解决?
with adoquery1 do
begin
close;
sql.clear;
sql.add('select * from table where query=xx ');
open;
end;
adoquery1.recordcount;//记录数
with adoquery1 do
begin
close;
sql.clear;
sql.add('select * from table where query=xx ');
open;
end;
adoquery1.recordcount;//记录数
with adoquery1 do
begin
close;
sql.clear;
sql.add('select * from table where 你的字段=xx ');
open;
end;
adoquery1.recordcount;
{ ---- CommandType的常量说明 ---- }
adCmdUnknown = 0008;//未知,
需要系统来判断,速度慢,为缺省值
adCmdText = 0001;//命令语句如SQL语句
adCmdTable = 0002;//数据表名称
adCmdStoredProc = 0004;//存储过程名称{ ---- CursorType的常量说明 ---- }
adOpenForwardOnly = 0;//只能由前向后单向访问,为缺省值
adOpenKeyset = 1;//可见其他用户对数据的修改,
但对其它用户的增加和删除不可见
adOpenDynamic = 2;//其他用户对数据的增加修改和删除均可见
adOpenStatic = 3;//其他用户对数据的增加修改和删除均不可见{---- LockType的常量说明 ---}
adLockReadOnly = 1;//只读,为缺省值
adLockPessimistic = 2;//在修改时,按单个记录锁定
adLockOptimistic = 3;//在修改后更新时,按单个记录锁定
adLockBatchOptimistic = 4;//在成批更新时记录锁定
var
AConnection, ARecordSet : variant;
longintTemp : integer;
strTemp : string;
intIndex : integer;
begin
{创建一个临时的ODBC数据源,
指向一个MsAccess数据库,
并利用此DSN建立一个数据库连接}
AConnection := CreateOleObject('ADODB.Connection');
AConnection.Open('Driver={Microsoft Access Driver
(*.mdb)};DBQ=C:\inetpub\wwwroot\test'); {建立一个数据集对象,并从数据表中提取数据}
ARecordSet := CreateOleObject('ADODB.RecordSet');
ARecordSet.open( 'wfjcommu',AConnection,
adOpenStatic,adLockOptimistic,adCmdTable ); memo1.lines.clear;
memo1.lines.add('********数据表原有的内容如下********');
{显示各个域的域名}
strTemp := '';
for intIndex := 0 to ARecordSet.Fields.count - 1 do
strTemp := strTemp + ARecordSet.Fields[intIndex].name+';';
memo1.lines.add( strTemp ); {显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := '';
for intIndex := 0 to ARecordSet.Fields.count - 1 do
strTemp := strTemp + ARecordSet.Fields
[intIndex].value+';';
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end; {增加一个记录}
ARecordSet.AddNew;//增加,Append
ARecordSet.Fields['AName'] := '1';
//以FieldByName的方式存取
ARecordSet.Fields['Portable'] := '2';
ARecordSet.Fields(2) := '3';
//以Fields[index]的方式存取
ARecordSet.Fields(3) := '4';
ARecordSet.Fields(4) := '5';
ARecordSet.Update;//更新,Post
ARecordSet.MoveFirst;//移到首条,First
memo1.lines.add('********增加了一条
记录后的数据表的内容如下********');
{显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := '';
for intIndex := 0 to ARecordSet.
Fields.count - 1 do
strTemp := strTemp +
ARecordSet.Fields[intIndex].value+';';
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end; {修改最后一条记录}
ARecordSet.MoveLast;
ARecordSet.Fields['AName'] := '11';
//以FieldByName的方式存取
ARecordSet.Fields['Portable'] := '22';
ARecordSet.Fields(2) := '33';
//以Fields[index]的方式存取
ARecordSet.Fields(3) := '44';
ARecordSet.Fields(4) := '55';
ARecordSet.Update;//更新,Post
ARecordSet.MoveFirst;//移到首条,First
memo1.lines.add('********修改了最后一条
记录后的数据表的内容如下********');
{显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := '';
for intIndex := 0 to
ARecordSet.Fields.count - 1 do
strTemp := strTemp +
ARecordSet.Fields[intIndex].value+';';
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end; {删除最后一条记录}
ARecordSet.MoveLast;//移到末条,Last
ARecordSet.delete;//删除,delete
ARecordSet.Update;//更新,在Delphi不需要
ARecordSet.MoveFirst;//移到首条,First
memo1.lines.add('********删除了最后一条
记录后的数据表的内容如下********');
{显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := '';
for intIndex := 0 to ARecordSet.Fields.count - 1 do
strTemp := strTemp + ARecordSet.
Fields[intIndex].value+';';
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end; ARecordSet.Close;{关闭数据集} {用SQL语句进行查询,查询姓名为“张三”的记录}
{注意,在SQL语句中,字符串应该用单引号包括起来}
ARecordSet.open( 'select * from wfjcommu
where AName = ''张三''',
AConnection,adOpenStatic,adLockOptimistic,
adCmdText );
memo1.lines.add('********张三的内容如下********');
memo1.lines.add( '共有' + IntToStr
( ARecordSet.RecordCount ) + '条匹配的记录' );
{显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := '';
for intIndex := 0 to ARecordSet.Fields.count - 1 do
strTemp := strTemp + ARecordSet.Fields
[intIndex].value+';';
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end; {关闭数据集和数据库连接}
ARecordSet.close;
AConnection.close;
end;
{ ---- CommandType的常量说明 ---- }
adCmdUnknown = 0008;//未知,
需要系统来判断,速度慢,为缺省值
adCmdText = 0001;//命令语句如SQL语句
adCmdTable = 0002;//数据表名称
adCmdStoredProc = 0004;//存储过程名称{ ---- CursorType的常量说明 ---- }
adOpenForwardOnly = 0;//只能由前向后单向访问,为缺省值
adOpenKeyset = 1;//可见其他用户对数据的修改,
但对其它用户的增加和删除不可见
adOpenDynamic = 2;//其他用户对数据的增加修改和删除均可见
adOpenStatic = 3;//其他用户对数据的增加修改和删除均不可见{---- LockType的常量说明 ---}
adLockReadOnly = 1;//只读,为缺省值
adLockPessimistic = 2;//在修改时,按单个记录锁定
adLockOptimistic = 3;//在修改后更新时,按单个记录锁定
adLockBatchOptimistic = 4;//在成批更新时记录锁定
var
AConnection, ARecordSet : variant;
longintTemp : integer;
strTemp : string;
intIndex : integer;
begin
{创建一个临时的ODBC数据源,
指向一个MsAccess数据库,
并利用此DSN建立一个数据库连接}
AConnection := CreateOleObject('ADODB.Connection');
AConnection.Open('Driver={Microsoft Access Driver
(*.mdb)};DBQ=C:\inetpub\wwwroot\test'); {建立一个数据集对象,并从数据表中提取数据}
ARecordSet := CreateOleObject('ADODB.RecordSet');
ARecordSet.open( 'wfjcommu',AConnection,
adOpenStatic,adLockOptimistic,adCmdTable ); memo1.lines.clear;
memo1.lines.add('********数据表原有的内容如下********');
{显示各个域的域名}
strTemp := '';
for intIndex := 0 to ARecordSet.Fields.count - 1 do
strTemp := strTemp + ARecordSet.Fields[intIndex].name+';';
memo1.lines.add( strTemp ); {显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := '';
for intIndex := 0 to ARecordSet.Fields.count - 1 do
strTemp := strTemp + ARecordSet.Fields
[intIndex].value+';';
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end; {增加一个记录}
ARecordSet.AddNew;//增加,Append
ARecordSet.Fields['AName'] := '1';
//以FieldByName的方式存取
ARecordSet.Fields['Portable'] := '2';
ARecordSet.Fields(2) := '3';
//以Fields[index]的方式存取
ARecordSet.Fields(3) := '4';
ARecordSet.Fields(4) := '5';
ARecordSet.Update;//更新,Post
ARecordSet.MoveFirst;//移到首条,First
memo1.lines.add('********增加了一条
记录后的数据表的内容如下********');
{显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := '';
for intIndex := 0 to ARecordSet.
Fields.count - 1 do
strTemp := strTemp +
ARecordSet.Fields[intIndex].value+';';
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end; {修改最后一条记录}
ARecordSet.MoveLast;
ARecordSet.Fields['AName'] := '11';
//以FieldByName的方式存取
ARecordSet.Fields['Portable'] := '22';
ARecordSet.Fields(2) := '33';
//以Fields[index]的方式存取
ARecordSet.Fields(3) := '44';
ARecordSet.Fields(4) := '55';
ARecordSet.Update;//更新,Post
ARecordSet.MoveFirst;//移到首条,First
memo1.lines.add('********修改了最后一条
记录后的数据表的内容如下********');
{显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := '';
for intIndex := 0 to
ARecordSet.Fields.count - 1 do
strTemp := strTemp +
ARecordSet.Fields[intIndex].value+';';
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end; {删除最后一条记录}
ARecordSet.MoveLast;//移到末条,Last
ARecordSet.delete;//删除,delete
ARecordSet.Update;//更新,在Delphi不需要
ARecordSet.MoveFirst;//移到首条,First
memo1.lines.add('********删除了最后一条
记录后的数据表的内容如下********');
{显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := '';
for intIndex := 0 to ARecordSet.Fields.count - 1 do
strTemp := strTemp + ARecordSet.
Fields[intIndex].value+';';
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end; ARecordSet.Close;{关闭数据集} {用SQL语句进行查询,查询姓名为“张三”的记录}
{注意,在SQL语句中,字符串应该用单引号包括起来}
ARecordSet.open( 'select * from wfjcommu
where AName = ''张三''',
AConnection,adOpenStatic,adLockOptimistic,
adCmdText );
memo1.lines.add('********张三的内容如下********');
memo1.lines.add( '共有' + IntToStr
( ARecordSet.RecordCount ) + '条匹配的记录' );
{显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := '';
for intIndex := 0 to ARecordSet.Fields.count - 1 do
strTemp := strTemp + ARecordSet.Fields
[intIndex].value+';';
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end; {关闭数据集和数据库连接}
ARecordSet.close;
AConnection.close;
end;
Edit.text:=ADOQuery1.FieldByName('name').asstring;
adoconn.ConnectionString:='Provider=SQLOLEDB.1;Persist Security Info=False;Initial Catalog=database_name;Use Procedure for Prepare=1;Auto Translate=True;Packet Size=4096'
adoconn.Open(user,pass);
{ ---- CommandType的常量说明 ---- }
adCmdUnknown = 0008;//未知,
需要系统来判断,速度慢,为缺省值
adCmdText = 0001;//命令语句如SQL语句
adCmdTable = 0002;//数据表名称
adCmdStoredProc = 0004;//存储过程名称{ ---- CursorType的常量说明 ---- }
adOpenForwardOnly = 0;//只能由前向后单向访问,为缺省值
adOpenKeyset = 1;//可见其他用户对数据的修改,
但对其它用户的增加和删除不可见
adOpenDynamic = 2;//其他用户对数据的增加修改和删除均可见
adOpenStatic = 3;//其他用户对数据的增加修改和删除均不可见{---- LockType的常量说明 ---}
adLockReadOnly = 1;//只读,为缺省值
adLockPessimistic = 2;//在修改时,按单个记录锁定
adLockOptimistic = 3;//在修改后更新时,按单个记录锁定
adLockBatchOptimistic = 4;//在成批更新时记录锁定
var
AConnection, ARecordSet : variant;
longintTemp : integer;
strTemp : string;
intIndex : integer;
begin
{创建一个临时的ODBC数据源,
指向一个MsAccess数据库,
并利用此DSN建立一个数据库连接}
AConnection := CreateOleObject('ADODB.Connection');
AConnection.Open('Driver={Microsoft Access Driver
(*.mdb)};DBQ=C:\inetpub\wwwroot\test'); {建立一个数据集对象,并从数据表中提取数据}
ARecordSet := CreateOleObject('ADODB.RecordSet');
ARecordSet.open( 'wfjcommu',AConnection,
adOpenStatic,adLockOptimistic,adCmdTable ); memo1.lines.clear;
memo1.lines.add('********数据表原有的内容如下********');
{显示各个域的域名}
strTemp := '';
for intIndex := 0 to ARecordSet.Fields.count - 1 do
strTemp := strTemp + ARecordSet.Fields[intIndex].name+';';
memo1.lines.add( strTemp ); {显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := '';
for intIndex := 0 to ARecordSet.Fields.count - 1 do
strTemp := strTemp + ARecordSet.Fields
[intIndex].value+';';
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end; {增加一个记录}
ARecordSet.AddNew;//增加,Append
ARecordSet.Fields['AName'] := '1';
//以FieldByName的方式存取
ARecordSet.Fields['Portable'] := '2';
ARecordSet.Fields(2) := '3';
//以Fields[index]的方式存取
ARecordSet.Fields(3) := '4';
ARecordSet.Fields(4) := '5';
ARecordSet.Update;//更新,Post
ARecordSet.MoveFirst;//移到首条,First
memo1.lines.add('********增加了一条
记录后的数据表的内容如下********');
{显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := '';
for intIndex := 0 to ARecordSet.
Fields.count - 1 do
strTemp := strTemp +
ARecordSet.Fields[intIndex].value+';';
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end; {修改最后一条记录}
ARecordSet.MoveLast;
ARecordSet.Fields['AName'] := '11';
//以FieldByName的方式存取
ARecordSet.Fields['Portable'] := '22';
ARecordSet.Fields(2) := '33';
//以Fields[index]的方式存取
ARecordSet.Fields(3) := '44';
ARecordSet.Fields(4) := '55';
ARecordSet.Update;//更新,Post
ARecordSet.MoveFirst;//移到首条,First
memo1.lines.add('********修改了最后一条
记录后的数据表的内容如下********');
{显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := '';
for intIndex := 0 to
ARecordSet.Fields.count - 1 do
strTemp := strTemp +
ARecordSet.Fields[intIndex].value+';';
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end; {删除最后一条记录}
ARecordSet.MoveLast;//移到末条,Last
ARecordSet.delete;//删除,delete
ARecordSet.Update;//更新,在Delphi不需要
ARecordSet.MoveFirst;//移到首条,First
memo1.lines.add('********删除了最后一条
记录后的数据表的内容如下********');
{显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := '';
for intIndex := 0 to ARecordSet.Fields.count - 1 do
strTemp := strTemp + ARecordSet.
Fields[intIndex].value+';';
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end; ARecordSet.Close;{关闭数据集} {用SQL语句进行查询,查询姓名为“张三”的记录}
{注意,在SQL语句中,字符串应该用单引号包括起来}
ARecordSet.open( 'select * from wfjcommu
where AName = ''张三''',
AConnection,adOpenStatic,adLockOptimistic,
adCmdText );
memo1.lines.add('********张三的内容如下********');
memo1.lines.add( '共有' + IntToStr
( ARecordSet.RecordCount ) + '条匹配的记录' );
{显示各个域的内容}
while not ARecordSet.eof do
begin
strTemp := '';
for intIndex := 0 to ARecordSet.Fields.count - 1 do
strTemp := strTemp + ARecordSet.Fields
[intIndex].value+';';
memo1.lines.add( strTemp );
ARecordSet.MoveNext;//移到下条,Next
end; {关闭数据集和数据库连接}
ARecordSet.close;
AConnection.close;
end;