LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 901|回复: 8

请教高手:关于SQL问题

[复制链接]
发表于 2005-1-22 17:08:44 | 显示全部楼层 |阅读模式
在mysql里,我现在有个库
有个字段(data)是字符型的。
例如:数据为:“9000”,“8000”,“7000”,"6000"……
我想用命令修改一下,都在前面加上“BL-",使得成为"BL_9000"……
该如何写命令的?
多谢!
发表于 2005-1-22 18:49:09 | 显示全部楼层
update your_table set data= 'LB_'||data
我没有mysql,但是这个在postgresql下是可以的,你不妨试一下。
回复 支持 反对

使用道具 举报

 楼主| 发表于 2005-1-24 09:29:33 | 显示全部楼层
谢谢的!
我试了一下。出现了一些问题。好象实现不了的。
我附上图片。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
回复 支持 反对

使用道具 举报

发表于 2005-1-24 09:57:56 | 显示全部楼层
我没有看清楚你的问题。
我一直以为你的data是字符型,但是从你的图来看是日期型,日期型的当然不行了。“||”连接的是字符。
如果你直接要用sql语句编写的话,那要看mysql有什么函数可以把日期型转化为字符型
比如:
update table set Cdata='LB_'||function(data)
回复 支持 反对

使用道具 举报

 楼主| 发表于 2005-1-24 10:04:24 | 显示全部楼层
不是日期型的啊。
model字段是字符型。
我用:
update table set model='LB_'||model
就是不行的。
麻烦你帮我看看的

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
回复 支持 反对

使用道具 举报

 楼主| 发表于 2005-1-24 10:07:26 | 显示全部楼层
我这种表达对不对的?
回复 支持 反对

使用道具 举报

发表于 2005-1-24 22:47:10 | 显示全部楼层
||是mysql中的逻辑操作符号--从你的查询结果可以看出来,这么多0;
我问了一个弟兄,他说在mysql下有专门的函数而不是操作符。
update table set data=CONCAT('LB_',data);
就是下面的这个。 :beat
CONCAT(str,str,...)


如果这个也不行那我也不知道了,mysql的文档我看了一下,也只有这个看上去好用的。
回复 支持 反对

使用道具 举报

 楼主| 发表于 2005-1-25 10:24:09 | 显示全部楼层
可以的。真的谢谢。
我昨天也找了一些资料看看了。终于搞定了。
回复 支持 反对

使用道具 举报

发表于 2005-1-25 18:07:57 | 显示全部楼层
可以就好,我也知道了。不过mysql的文档做的真是没有pgsql的好。
你有机会转那个的话,就省力多了。
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表