sql-SQL2005数据处理的问题

问题描述

SQL2005数据处理的问题

select * INTO #a
from (SELECT ROW_NUMBER() OVER (ORDER BY dy) xx,aid,company, name, areaID, dy, bz, rem, groupname, price425, price325
FROM Attribute
where compid=101 and areaid=1) a
select * from #a

select * into #b
from (SELECT ROW_NUMBER() OVER (ORDER BY po) xx,
(case when po-poold
when po-poold=0 then 0
when po-poold>0 then 1 end) as t, dbo.Groups.dnam, pc,po,pcold, poold, dbo.T_PRICE.rem
FROM dbo.T_PRICE INNER JOIN
dbo.Groups ON dbo.T_PRICE.groupID = dbo.Groups.groupID
where compid=101 and areaid=1) b
select * from #b

如上生成两个临时表,要将#b中的值更新按照一定次序到#a中,如何实现比较方便?我采用如下方式

update #a
set groupname=#b.dnam,price425=#b.poold,price325=#b.pcold,bz=#b.t
from #a,#b
where #b.xx=#a.xx

update attribute
set groupname=#a.groupname,price425=#a.price425,price325=#a.price325,bz=#a.bz
from attribute,#a
where attribute.aid=#a.aid

这种方式如果where compid=101 and areaid=1是固定的可以实现,但是如果是变化的要如何处理呢?compid可以是101、101....areaid可以是1、2...,如果一一罗列就太麻烦啦。求教各位大侠,请指点迷津!万分感谢。。

时间: 2024-10-27 14:06:58

sql-SQL2005数据处理的问题的相关文章

利用索引提高SQL Server数据处理的效率

在良好的数据库设计基础上,能有效地使用索引是SQL Server取得高性能的基础,SQL Server采用基于代价的优化模型,它对每一个提交的有关表的查询,决定是否使用索引或用哪一个索引.因为查询执行的大部分开销是磁盘I/O,使用索引提高性能的一个主要目标是避免全表扫描,因为全表扫描需要从磁盘上读表的每一个数据页,如果有索引指向数据值,则查询只需读几次磁盘就可以了.所以如果建立了合理的索引,优化器就能利用索引加速数据的查询过程.但是,索引并不总是提高系统的性能,在增.删.改操作中索引的存在会增加

利用索引提高SQL Server数据处理效率

在良好的数据库设计基础上,能有效地使用索引是SQL Server取得高性能的基础,SQL Server采用基于代价的优化模型,它对每一个提交的有关表的查询,决定是否使用索引或用哪一个索引.因为查询执行的大部分开销是磁盘I/O,使用索引提高性能的一个主要目标是避免全表扫描,因为全表扫描需要从磁盘上读表的每一个数据页,如果有索引指向数据值,则查询只需读几次磁盘就可以了.所以如果建立了合理的索引,优化器就能利用索引加速数据的查询过程.但是,索引并不总是提高系统的性能,在增.删.改操作中索引的存在会增加

ms SQL server数据库备份、压缩与SQL数据库数据处理的方法_数据库其它

一.备份数据库  1.打开SQL企业管理器,在控制台根目录中依次点开Microsoft SQL Server 2.SQL Server组-->双击打开你的服务器-->双击打开数据库目录 3.选择你的数据库名称(如论坛数据库Forum)-->然后点上面菜单中的工具-->选择备份数据库 4.备份选项选择完全备份,目的中的备份到如果原来有路径和名称则选中名称点删除,然后点添加,如果原来没有路径和名称则直接选择添加,接着指定路径和文件名,指定后点确定返回备份窗口,接着点确定进行备份  二.

SQL基础--> 数据处理(DML、RETURNING、MERGE INTO)

--================================================= --SQL基础--> 数据处理(DML.RETURNING.MERGE INTO) --=================================================   一.常用的DML语句及事物处理     向表中插入数据(INSERT)     更新表中数据(UPDATE)     从表中删除数据(DELETE)     将表中数据和并(MERGE)     控制事务

(MS SQL Server)SQL语句导入导出大全

server|语句 /*******  导出到excel EXEC master..xp_cmdshell 'bcp SettleDB.dbo.shanghu out c:\temp1.xls -c -q -S"GNETDATA/GNETDATA" -U"sa" -P""' /***********  导入Excel SELECT * FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',   'Data

sql2005的xml字段类型在.net中的应用

sql|sql2005|xml    今天要介绍的就是sql2005的xml字段类型在.net中的应用.调用过程是:先运用并行化的办法把xml字段类型中的数据转换成Model对象,对Model对象操作后,再运用串行化的方法把Model对象转变成xml格式,最后存储到数据库中.       我认为如果把复杂的业务关系数据存储在xml字段中,可简化数据库的设计,方便业务的处理.        这里写了个小demo:            假如我们有很多店铺信息,每个店铺都有一个ShopID, 所以我

一些关于SQL2005+ASP.NET2.0的问题

asp.net|sql|sql2005|问题 一般我们能过VS2005的SQL explorer来添加一个本地的MDF文件.也许你可能会出现下面这个问题:Exception Details: System.Data.SqlClient.SqlException: The user instance login flag is not supported on this version of SQL Server. The connection will be closed. 通过搜索.发现这里有

SQL数据库导入导出数据代码大全

/*******  导出到excel EXEC master..xp_cmdshell 'bcp SettleDB.dbo.shanghu out c:\temp1.xls -c -q -S"GNETDATA/GNETDATA" -U"sa" -P""' /***********  导入Excel SELECT * FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0',   'Data Source=&qu

VS2005+SQL2005 ASP.NET2.0数据库连接

asp.net|sql|sql2005|数据|数据库|数据库连接 对于的新手来说,整个数据库连接不太容易,根据连接过程中的问题总结如下. 1.开启SQL2005远程连接功能,开启办法如下: 配置工具->SQL Server外围应用配置器->服务和连接的外围应用配置器->打开MSSQLSERVER节点下的Database Engine节点,先择"远程连接",接下建议选择"同时使用TCP/IP和named pipes",确定后重启数据库服务就可以了.

c#中连接SqL2005数据库错误解决及转义字符

sql|sql2005|错误|解决|数据|数据库 在C#中与SQL2005建立连接时,出现错误:在建立与服务器的连接时出错.在连接到 SQL Server 2005 时,在默认的设置下 SQL Server 不允许进行远程连接可能会导致此失败. (provider: 命名管道提供程序, error: 40 - 无法打开到 SQL Server 的连接) 查找有关资料"从"开始菜单"调出"配置工具"中的"SQL Server 外围应用配置器&quo