这样的 SQL 语句怎么写? ( 积分: 0 )

  • 主题发起人 主题发起人 chzhwenfigo
  • 开始时间 开始时间
C

chzhwenfigo

Unregistered / Unconfirmed
GUEST, unregistred user!
有以下语句:
adocommand1.CommandText:='insert into 进货单明细([编号],[进价] values ( '''+edit1.text+''','''+edit2.text+''')';
其中,数据库中 [编号]为varchar(7)型,[进价]为decimal型,执行语句adocommand1.execute 时,提示不能把varchar转换成decimal型;又不能写成
strtofloat(edit2.text),不知怎么写该语句。
 
有以下语句:
adocommand1.CommandText:='insert into 进货单明细([编号],[进价] values ( '''+edit1.text+''','''+edit2.text+''')';
其中,数据库中 [编号]为varchar(7)型,[进价]为decimal型,执行语句adocommand1.execute 时,提示不能把varchar转换成decimal型;又不能写成
strtofloat(edit2.text),不知怎么写该语句。
 
把 Edit2.text 两边的引号去掉 试一下,两边各用一个引号就可以。
 
要不试试ADOQuery1,用参数
...
ADOQuery1.SQL.Text:='insert into 进货明细单(编号,进价) Values(:a,:b)';
Parameters.ParamByName('a').Value:=Edit1.text;
Parameters.ParamByName('b').Value:=StrToFloat(Edit2.Text);
...
没有调试过,不知道有没有写错,这是这个意思啦
 
adocommand1.CommandText:='insert into 进货单明细([编号],[进价] values ( '''+edit1.text+''','+edit2.text+')';
 
是字符型的就用引号引起来,数字型的就不用引,你可以设断点调试,Ctrl+F7查看
语句是否正确,不过还是建议用参数比较好.
 
樓主的寫法沒有錯誤,看看edit2輸入的是不是數字
一定要控制在edit2中只能輸入數字
 
接受答案了.
 

Similar threads

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