我创建了一个连接字符串的存储过程,但是连接完后去不掉里面的空格

a375559435 2011-10-16 09:02:59
create proc jsj090412_jinchang
(@riqi datetime, @czrenyuan char(10),@wuliaodaima char(10),@jcshuliang int,@remark char(20))
as
begin
set nocount on;
declare @danhao char(20)
declare @driqi char(6), @dczrenyuan char(4),@dwuliaodaima char(4),@djcshuliang char(3)
set @dczrenyuan=(substring(@czrenyuan,7,4))
set @driqi = (convert(varchar(6),@riqi,12))
set @dwuliaodaima = (substring(@wuliaodaima,4,4))
set @djcshuliang = (convert(varchar(3),@jcshuliang))
set @danhao = @driqi+@dczrenyuan+@dwuliaodaima+@djcshuliang
insert into jsj090412_jincangjilu values(@danhao,@riqi,@czrenyuan,@remark,@wuliaodaima,@jcshuliang)
end
go

这是代码,然后:exec jsj090412_jinchang '2009-06-19','0309101412','2134440',50,'无'

结果变成090619 1412 4440 50 到这里
在表了我将@danhao字段的属性设成了char(50),太短的话会报错
请问我该怎么改成能将那些没用的空格去掉,变成0906191412444050这样呢?
...全文
135 8 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
ijwsoft 2011-10-17
  • 打赏
  • 举报
回复
用varchar
Rotel-刘志东 2011-10-17
  • 打赏
  • 举报
回复
楼主的数据类型用的有问题,最好用varchar()类型,如果用char()容易产生空格。
--小F-- 2011-10-16
  • 打赏
  • 举报
回复
Char是有可能会产生空格的.
中国风 2011-10-16
  • 打赏
  • 举报
回复
看错楼主要的结果,把变量类型改为varchar就行了,空格是Char造成的
中国风 2011-10-16
  • 打赏
  • 举报
回复
Create proc jsj090412_jinchang  
(@riqi datetime, @czrenyuan varchar(10),@wuliaodaima varchar(10),@jcshuliang int,@remark varchar(20))
as
begin
set nocount on;
declare @danhao varchar(20)
declare @driqi varchar(6), @dczrenyuan varchar(4),@dwuliaodaima varchar(4),@djcshuliang varchar(3)
set @dczrenyuan=(substring(@czrenyuan,7,4))
set @driqi = (convert(varchar(6),@riqi,12))
set @dwuliaodaima = (substring(@wuliaodaima,4,4))
set @djcshuliang = (convert(varchar(3),@jcshuliang))
set @danhao = @driqi+@dczrenyuan+@dwuliaodaima+@djcshuliang
select @danhao
insert into jsj090412_jincangjilu values(@danhao,@riqi,@czrenyuan,@remark,@wuliaodaima,@jcshuliang)
end
go

exec jsj090412_jinchang '2009-06-19','0309101412','2134440',50,'无'


--生成为:0906191412444050
中国风 2011-10-16
  • 打赏
  • 举报
回复
怎么喜欢用Char
建议全改为varchar


(convert(varchar(6),@riqi,12))
改为
(convert(varchar(6),@riqi,120))
唐诗三百首 2011-10-16
  • 打赏
  • 举报
回复

select replace('090619 1412 4440 50',' ','') 'r'

r
------------------
0906191412444050
geniuswjt 2011-10-16
  • 打赏
  • 举报
回复

select replace('090619 1412 4440 50',' ','')

/*
0906191412444050
notepad--v3.4 windows Notepad--v3.4.0-plugin-Installer.exe 是win10下面的插件版安装包,会关联右键菜单等。 Notepad--v3.4.0-win10-portable.zip 是绿色免安装版本,解压即用,不会关联右键菜单注册表。 Ndd-quick-v3.3.0-win10-single-portable.zip 是单文件绿色免安装版,只包含皮肤和vc依赖库,不含插件、不含文件对比,主推轻量级、快速反应。适合只需要纯粹、轻快级,文本编辑器的用户。不定期发布。 MacOS 版本 Notepad--v3.4.0-mac_x64_12.3.dmg 是macos 12.x 及以后的版本。 Notepad--v3.4.0-mac_arm64_12.3.dmg 是macos 12.x 及以后 arm64 m1/m2芯片 的版本。第一次安装时,需要在设置偏好里面,放开苹果的安装限制,才能正常识别,请自行放开设置一下。 如果还是有问题,参考帖子:#I8JTJN:macOS Sonoma 14.1.1安装提示已损坏:macOS Sonoma 14.1.1安装提示已损坏 uos com.hmja.notepad_3.4.0.0_amd64.deb 是x64 cpu架构的uos系统对应的ndd版本。 其余系统版本后续会发布。 3.4 修改如下: 1 支持文件标签拖入拖出到新窗口的效果。 2 windows下修改快捷键放开。 3 按行号切分大文件。 4 大文件打开时,在文件夹查找所在目录,macos下可能会崩溃问题。 5 目录右键增加删除文件、文件夹功能。 6 补充深色主题下rust语法高亮; lisp 语法失效问题。 7 linux下信号打开文件,不拿锁,打开文件在消息队列中去做。

34,838

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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