帮忙看下,运行总是报这个错误?

WoJoJo 2008-04-01 09:29:55
Error invalid operand type for dot operator:string

代码:
string ls_old,ls_new
select old
into :ls_old
from test
where id=1;
ls_new=ls_old.Replace("0","@");
数据库里这字段是varchar的,我是新手,各位帮忙看下!! 谢谢
...全文
631 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
WoJoJo 2008-04-01
  • 打赏
  • 举报
回复
十分感谢 各位
winstonsu 2008-04-01
  • 打赏
  • 举报
回复
//将ls_string中的ls_old替换为ls_new
string ls_string,ls_old,ls_new
integer li_pos

ls_old = '0'
ls_new = '@'
ls_string = //
do while true
li_pos = pos(ls_string,ls_old,1)
if li_pos <= 0 then exit
ls_string = replace(ls_string,li_pos,len(ls_old),ls_new)
loop
I_am_Z 2008-04-01
  • 打赏
  • 举报
回复
long ll_pos

do
ll_pos = pos( ls_str,"0" )
ls_old = replace( ls_old ,ll_pos,1,"@" )
loop while pos( ls_old ,"0" ) > 0
messagebox("",ls_old )
WoJoJo 2008-04-01
  • 打赏
  • 举报
回复
谢谢前辈拉
那我要将表里的old列中的“0” 转换成“@”应该怎么写呢?
麻烦多指教 谢谢
yysy2000 2008-04-01
  • 打赏
  • 举报
回复
ls_old.Replace("0","@")
修改为
int li_len
li_len= len(ls_old)
int i
string ls_split
for i=1 to li_len
/* 自字符串的第一位开始至末位,逐一判断,逐一修改 */
ls_split = mid( ls_old, i, 1)
if ls_split ="0" then replace( ls_old, i, 1, "@")
next

代码未经测试,仅表达含义。
leio 2008-04-01
  • 打赏
  • 举报
回复
ls_old.Replace("0","@") 这句错误

仔细看看联机帮助里的replace说明。

1,078

社区成员

发帖
与我相关
我的任务
社区描述
PowerBuilder 相关问题讨论
社区管理员
  • 基础类社区
  • WorldMobile
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧