-
SQLServer将一列的多行内容拼接成一行的实现方法
下面大家先看下示例代码:示例昨天遇到一个SQLServer的问题:需要写一个储存过程来处理几个表中的数据,最后问题出在我想将一个表的一个列的多行内容拼接成一行,比如表中有两列数据:类别名称AAA企业1AAA企业2AAA企业3BBB企业4BBB企业5我想把这个表变成如下格式:类别名称AAA企业1,企业2,企业3BBB企业4,企业5一开始挺头疼的(会了的肯定没有这种感觉,不会那必须是头疼啊(*^__^*)),从网上找了点资料,算是找到一种比较简单方便的方法吧,现在大体总结一下,供大家共同学习。原先的表名为Table_A,实现代码如下:select类别,名称=(stuff((select','+名称fromTable_Awhere类别=A.类别forxmlpath('')),1,1,''))fromTable_AasAgroupby类别这里使用了SQLServer2005版本以后加入的stuff以及forxmlpath,先说下在上面这句sql中的作用,然后再详细的说明一下这两个的用法...
数据库操作教程 2022-09-23 17:38:45 -
SQL语句实现查询SQLServer服务器名称和IP地址
获取服务器名称:SELECTSERVERPROPERTY('MachineName')select@@SERVERNAMEselectHOST_NAME()获取IP地址可以使用xp_cmdshell执行ipconfig命令:--开启xp_cmdshellexecsp_configure'showadvancedoptions',1reconfigurewithoverrideexecsp_configure'xp_cmdshell',1reconfigurewithoverrideexecsp_configure'showadvancedoptions',0reconfigurewithoverridegobegindeclare@iplinevarchar(200)declare@posintdeclare@ipvarchar(40)setnocountonset@ip=nullifobject_id('tempdb....
数据库操作教程 2022-09-23 17:38:36 -
SQL语句实现查询SQLServer内存使用状况
SELECTtype,--Clerk的类型sum(virtual_memory_reserved_kb)asvm_Reserved_kb,--保留的内存sum(virtual_memory_committed_kb)asvm_Committed_kb,--提交的内存sum(awe_allocated_kb)asawe_Allocated_kb,--开启AWE后使用的内存sum(shared_memory_reserved_kb)assm_Reserved_kb,--共享的保留内存sum(shared_memory_committed_kb)assm_Committed_kb,--共享的提交内存sum(single_pages_kb)asSinlgePage_kb,--BufferPool中的Stolen的内存sum(multi_pages_kb)asMultiPage_kb--MemToLeave的内存FROMsys.dm_os_memory_clerksGROUPBYtypeORDERBYtype--查询BufferPool/MemoryToLeaveSELECTsum(virtua...
数据库操作教程 2022-09-23 17:37:58 -
SqlServer实现类似Oracle的before触发器示例
1.插入数据前判断数据是否存在SETANSI_NULLSONGOSETQUOTED_IDENTIFIERONGO--=============================================--Author:<Author,,Name>--Createdate:<CreateDate,,>--Description:<Description,,>--=============================================alterTRIGGERCategoryExistTriggerONProductCategoryinsteadofinsertASdeclare@categoryNamevarchar(50);BEGIN--SETNOCOUNTONaddedtopreventextraresultsetsfrom--interferingwithSELECTstatements...
数据库操作教程 2022-09-23 17:35:39 -
SQLServer中使用SQL语句实现把重复行数据合并为一行并用逗号分隔
一.定义表变量复制代码代码如下:DECLARE@T1table(UserIDint,UserNamenvarchar(50),CityNamenvarchar(50));insertinto@T1(UserID,UserName,CityName)values(1,'a','上海')insertinto@T1(UserID,UserName,CityName)values(2,'b','北京')insertinto@T1(UserID,UserName,CityName)values(3,'c','上海')insertinto@T1(UserID,UserName,CityName)values(4,'d','北京')insertinto@T1(UserID,UserName,CityName)values(5,'e','上海')select*from@T1-----最优的方式SELECTCityName,STUFF((SELECT','+UserNameFROM@T1subTitleWHERECityName=A.CityNameFORXMLPATH('')),1,1,'')ASAF...
数据库操作教程 2022-09-23 17:34:05 -
SQLServer用存储过程实现插入更新数据示例
实现1)有相同的数据,直接返回(返回值:0);2)有主键相同,但是数据不同的数据,进行更新处理(返回值:2);3)没有数据,进行插入数据处理(返回值:1)。【创建存储过程】CreateprocInsert_Update@Idvarchar(20),@Namevarchar(20),@Telephonevarchar(20),@Addressvarchar(20),@Jobvarchar(20),@returnValueintoutputasdeclare@tmpNamevarchar(20),@tmpTelephonevarchar(20),@tmpJobvarchar(20),@tmpAddressvarchar(20)ifexists(select*fromdbo.DemoDatawhereid=@Id)beginselect@tmpName=Name,@tmpTelephone=Telephone,@tmpAddress=Address,@tmpJob=Jobfromdbo.DemoDatawhereid=@Idif((@tmpName=@Name)and(@tmpTelepho...
数据库操作教程 2022-09-23 17:26:55 -
动态SQL中返回数值的实现代码
复制代码代码如下:ALTERproc[dbo].[sp_common_paypal_AddInfo](@paypalsqlvarchar(max),--不包含用户表的paypalsql语句@paypalusersqlvarchar(max),--paypal用户表的sql语句@ebaysqlvarchar(max),--不包含用户表的ebaysql语句@ebayusersqlvarchar(max),--ebay的用户表sql语句@paypaluserwherevarchar(max),--paypal用户表查询ID语句@ebayuserwherevarchar(max),--ebay用户表查询ID语句@websqlvarchar(max),--web除去用户表的sql语句@webusersqlvarchar(max),--web用户表的sql语句@webwherevarchar(max),--web用户表where之后的sql语句@ebaystockflagvarchar(10),--ebay订单号生成规则@webstockflagvarchar(10)--web订单号生成规则)as...
数据库操作教程 2022-09-23 17:26:50 -
执行一条sql语句update多条记录实现思路
通常情况下,我们会使用以下SQL语句来更新字段值:复制代码代码如下:UPDATEmytableSETmyfield='value'WHEREother_field='other_value';但是,如果你想更新多行数据,并且每行记录的各字段值都是各不一样,你会怎么办呢?举个例子,我的博客有三个分类目录(免费资源、教程指南、橱窗展示),这些分类目录的信息存储在数据库表categories中,并且设置了显示顺序字段display_order,每个分类占一行记录。如果我想重新编排这些分类目录的顺序,例如改成(教程指南、橱窗展示、免费资源),这时就需要更新categories表相应行的display_order字段,这就涉及到更新多行记录的问题了,刚开始你可能会想到使用循环执行多条UPDATE语句的方式,就像以下的php程序示例:复制代码代码如下:foreach($display_orderas$id=>$ordinal){$sql="UPDATEcategoriesSETdisplay_order=$ordinalWHEREid=$id";mysql_query($sql);}这种方法...
数据库操作教程 2022-09-23 17:26:24 -
在SQLServer中实现最短路径搜索的解决方法
开始这是去年的问题了,今天在整理邮件的时候才发现这个问题,感觉顶有意思的,特记录下来。在表RelationGraph中,有三个字段(ID,Node,RelatedNode),其中Node和RelatedNode两个字段描述两个节点的连接关系;现在要求,找出从节点"p"至节点"j",最短路径(即经过的节点最少)...
数据库操作教程 2022-09-23 17:24:06 -
sqlserver实现oracle的sequence方法
当然这点小问题是难不倒我们程序员的,“max+1啊”,有人会说这样的方式。是的,这种方式实现起来也比较简单...
数据库操作教程 2022-09-23 17:23:52