update

lihongf 2003-10-17 03:58:46
表a
jsdm gs
01-0001 0000001
01-0001 0000005
01-0001 0000006
01-0002 0000011
01-0003 0000054
01-0003 0000048
01-0003 0000068
01-0003 0000018
01-0003 0000059
....
表b
jsdm strings
01-0001 0000001,0000005,0000006
01-0002 0000011
01-0003 0000054,0000048,0000068,0000018,0000059
..

如何将表a的按jsdm把gs 连接起来成为表b 中的样子
...全文
52 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
zjcxc 2003-10-17
  • 打赏
  • 举报
回复
--方法2.直接生成,适合7.0/2000

--生成表b
select jsdm,cast(gs as varchar(8000)) as strings into 表b from 表a order by jsdm

--更新strings
declare @jsdm varchar(10),st varchar(8000)
update 表b set st=case jsdm when @jsdm then st+','+stings else strings end
,stings=@jsdm,@jsdm=jsdm

--删除多余的数据
delete from 表b where strings<>(select top 1 strings from 表b a where a.jsdm=jsdm order by len(strings) desc)



zjcxc 2003-10-17
  • 打赏
  • 举报
回复

--这个问题太多人问了.
--方法1.用自定义函数,适用于sql2000
create function f_merg(@jsdm varcahr(10))
returns varchar(8000)
as
begin
declare @re varchar(8000)
set @re=''
select @re=@re+','+gs from 表a where jsdm=@jsdm
set @re=substring(@re,2,8000)
return(@re)
end
go

--调用自定义实现你的要求:
select jsdm,dbo.f_merg(jsdm) strings into 表b from 表a group by jsdm
nboys 2003-10-17
  • 打赏
  • 举报
回复
利用函数:

create function f_name(@jsdm varchar(100))
returns varchar(8000) --如果数据大,可以改成大一点的长度
as
begin
declare @sql varchar(8000)
set @sql=''
select @sql=@sql+gs from a where jsdm=@jsdm
return(@sql)
end
go

执行:
select jsdm,dbo.f_name(jsdm) as [strings] into b from a group by jsdm

select * from b
nboys 2003-10-17
  • 打赏
  • 举报
回复
利用函数:

create function f_name(@id varchar(100))
returns varchar(8000) --如果数据大,可以改成大一点的长度
as
begin
declare @sql varchar(8000)
set @sql=''
select @sql=@sql+gs from a where jsdm=@id
return(@sql)
end
go

执行:
selecdt jsdm,dbo.f_name(jsdm) as [strings] from a group by jsdm

sdhdy 2003-10-17
  • 打赏
  • 举报
回复
--用函数
create function test(@id varchar(200))
returns varchar(8000)
as
begin
declare @sql varchar(8000)
set @sql=''
select @sql=@sql+gs+',' from 表a where jsdm=@id
set @sql=left(@sql,len(@sql)-1)
return(@sql)
end

--执行
select distinct jsdm,dbo.test(jsdm) as strings from 表a
txlicenhe 2003-10-17
  • 打赏
  • 举报
回复
这种贴子太多了

--1.创建一个合并的函数
create function fmerg(@id varchar(10))
returns varchar(8000)
as
begin
declare @str varchar(8000)
set @str=''
select @str=@str+','+gs from 表A where jsdm=@id
set @str=right(@str,len(@str)-1)
return(@str)
End
go

--调用自定义函数得到结果
select distinct jsdm,dbo.fmerg(jsdm) from 表A
yujohny 2003-10-17
  • 打赏
  • 举报
回复
--先建立一个合并函数
create function getstr(@bh char(10))
returns varchar(4000)
as
begin
declare @str varchar(4000)
set @str=''
select @str=@str+gs+',' from 表a where jsdm=@bh

set @str=left(@str,len(@str)-1)
return @str
end


--然后调用
select jsdm,dbo.getstr(jsdm) as strings into 表b from 表a group by jsdm
yujohny 2003-10-17
  • 打赏
  • 举报
回复
--先建立一个合并函数
create function getstr(@bh char(10))
returns varchar(4000)
as
begin
declare @str varchar(4000)
set @str=''
select @str=@str+gs+',' from 表a where jsdm=@bh

set @str=left(@str,len(@str)-1)
return @str
end


--然后调用
select jsdm,dbo.getstr(jsdm) from 表a group by jsdm
​ 博主介绍:✌在职Java研发工程师、专注于程序设计、源码分享、技术交流、专注于Java技术领域和毕业设计✌项目名称基于Web的酒店客房管理系统的设计与实现系统说明3.2.1  用户模块功能分析前台模块应主要包括用户登录模块、用户注册模块、查看客房信息模块、客房预定 模块、用户留言模块、充值模块和个人信息维护模块。用户登录模块:用户通过输入注册的的账号和密码,然后进行身份验证,匹配成功 后实现登录功能。用户注册模块:用户输入合法的账号和密码可以实现注册功能。 查看客房信息模块:用户可以通过首页查看客房的价格,图片,详情等信息,从而   可以选择想要预定的房间。 客房预定模块:用户选择自己想要预定的客房后,可以通过输入相关信息进行订房操作。用户留言模块:用户可以向管理员发送留言。 充值模块:用户可以通过添加银行卡再为自己进行充值操作。 个人信息维护模块:用户可以修改自己的姓名、密码、身份证号等信息,还可以查看自己的订单。3.2.2  管理员模块功能分析对于管理员而言,一个好的管理系统总是能让酒店的管理工作事半功倍[7]。管理员 能够通过这个系统对自己的酒店情况一目了然,应该包括客户留言模块、客房管理模 块、订房信息管理模块、入住信息管理模块、统计分析模块、酒店新闻管理模块、会 员信息管理模块、员工信息管理模块、系统用户管理模块、个人信息维护模块。客户留言模块:管理员可以查看并回复用户的留言。客房管理模块:管理员可以管理客房信息,可以添加新的客房,删除已经停用的客房信息,还可以修改现有的客房信息。订房信息管理模块:管理员可以处理用户的订房请求,为用户办理入住手续。入住信息管理模块:对于没有注册的线下客户,也可以办理入住手续。统计分析模块:可以对酒店所有的入住信息进行记录和总结分析。酒店新闻管理模块:管理员可以更新网站上的新闻公告,展示图片等信息。会员信息管理模块:管理员可以查看到所有的注册会员信息,可以对会员信息进行删除,修改,添加操作。员工信息管理模块:管理员可以查看到自己公司所有的员工信息,而且还可以对员工的相关信息进行管理。系统用户管理模块:管理员可以查看到所有的系统管理员信息并对管理员信息进行管理。个人信息维护模块:管理员可以更改自己的登录密码或者是姓名、性别、手机号等 相关个人信息。​编辑 环境需要1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA;3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS; 5.数据库:MySql 5.7版本;6.是否Maven项目:否;技术栈1. 后端:Spring+SpringMVC+Mybatis2. 前端:JSP+CSS+JavaScript+jQuery使用说明1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;2. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;若为maven项目,导入成功后请执行maven clean;maven install命令,然后运行;3. 将项目中springmvc-servlet.xml配置文件中的数据库配置改为自己的配置;4. 运行项目,在浏览器中输入http://localhost:8080/ 登录运行截图​编辑​编辑​编辑​编辑​编辑​编辑​编辑​编辑​编辑​编辑​编辑​编辑​编辑​编辑​编辑 用户管理控制层:package com.houserss.controller;import javax.servlet.http.HttpSession;import org.apache.commons.lang3.StringUtils;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RequestMethod;import org.springframework.web.bind.annotation.RequestParam;import org.springframework.web.bind.annotation.ResponseBody;import com.houserss.common.Const;import com.houserss.common.Const.Role;import com.houserss.common.ServerResponse;import com.houserss.pojo.User;import com.houserss.service.IUserService;import com.houserss.service.impl.UserServiceImpl;import com.houserss.util.MD5Util;import com.houserss.util.TimeUtils;import com.houserss.vo.DeleteHouseVo;import com.houserss.vo.PageInfoVo;/** * Created by admin */@Controller@RequestMapping(/user/)public class UserController if (ip != null && ip.length() > 0) String[] ips = ip.split(,);for (int i = 0; i  

22,207

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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