还是SQL模糊查询的问题,大家帮忙呀!(30分)

  • 主题发起人 主题发起人 lfpsoft
  • 开始时间 开始时间
L

lfpsoft

Unregistered / Unconfirmed
GUEST, unregistred user!
一个人事数据表,有姓名,部门、性别等字段。
用ADO连接
表中有姓名为这样的记录:
张小兵、小李、小英、刘德华
要实现的功能是:
输入个“小”字查到的记录为:张小兵、小李、小英
输入“刘”字查到的记录为:刘德华

//在ACCESS中用以下代码查找“小”字得到的记录是:小李、小英,张小兵
var
SQL: String;
begin
SQL:='Select 员工姓名,部门名称 from 员工资料 Where 员工姓名 like :D1';
Q_UserInfo.SQL.Clear;
Q_UserInfo.SQL.Add(SQL);
Q_UserInfo.Parameters.ParamValues['D1'] := '%'+username.Text +'%';
Q_UserInfo.Open ;

但当然连接的是SQL Server 2000时,表的结构一样,但却什么也查不到。
哪位知道是什么原因呢?

 
Q_UserInfo.Parameters.ParamValues['D1'] := '''%'+username.Text +'%''';
 
试过了,还是不行!
 
SQL:='Select 员工姓名,部门名称 from 员工资料 Where 员工姓名 like ''%:D1%''';
Q_UserInfo.SQL.Clear;
Q_UserInfo.SQL.Add(SQL);
Q_UserInfo.Parameters.ParamValues['D1'] := username.Text;
Q_UserInfo.Open ;

 
HIGOAL:
出错,找不到D1
 
SQL:='Select 员工姓名,部门名称 from 员工资料 Where 员工姓名 like ''%';
Q_UserInfo.SQL.Clear;
Q_UserInfo.SQL.Add(SQL);
Q_UserInfo.SQL.Add(username.Text);
Q_UserInfo.SQL.Add('%''');
Q_UserInfo.Open ;
 
试试是不是本身没有记录啊
 
还是HIGOAL最后的方法行。
 
不支持参数传递?
 
select * from palma where ma02 like '%'+@a +'%'
 

Similar threads

S
回复
0
查看
3K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
2K
SUNSTONE的Delphi笔记
S
后退
顶部