zoukankan      html  css  js  c++  java
  • 为文本字段实现类似"求和"的效果

    在SQL Server里面,针对数字字段,我们可以用SUM函数求出多个值的总和。有的时候,我们需要为文本值实现类似的效果。例如

    有一个表包含了计算机的基础信息,而另外一个表包含了IP地址信息。一个计算机可能对应了多个IP地址。如果我希望按照计算机分组,然后统计它所有的IP地址,那么该怎么办呢?

    你可以通过下面的范例找到答案。我们的实现手段是通过一个函数来做。该函数接受两个参数,一个就是计算机的编号,一个则是我们希望连接字符串的分隔符。

    这个函数的核心是使用了游标。 值得注意的是,下面的脚本你最好是每段注释下面的代码作为一个单独的批执行,而不要一次性全部执行。方法就是:选择每个注释下面的代码,然后按F5

    --创建范例数据库
    CREATE DATABASE DEMO
    GO 

    USE DEMO
    GO 

    --创建两个表
    CREATE TABLE Computer(ID INT,ComputerName NVARCHAR(10))
    GO 

    CREATE TABLE IPAddress(ComputerID INT,IPAddress NVARCHAR(20))
    GO 

    --增加10笔记算机记录,每个计算机增加2个IP地址
    DECLARE @I INT
    SET @I=1;
    WHILE(@I<10)
    BEGIN
       
    INSERT INTO Computer VALUES(@I,'Computer'+CONVERT(NVARCHAR(2),@I))
       
    INSERT INTO IPAddress VALUES(@I,'IPAddress '+ CONVERT(NVARCHAR(2),@I))
       
    INSERT INTO IPAddress VALUES(@I,'IPAddress '+ CONVERT(NVARCHAR(2),@I+1))
       
    SET @I=@I+1
    END
    GO 

    --查看两个表的资料
    SELECT * FROM Computer
    SELECT * FROM IPAddress

    --合并查看两个表单资料
    SELECT C.*,I.* FROM Computer C JOIN IPAddress I ON C.ID=I.ComputerID

    --创建函数来处理字符串的合并
    CREATE FUNCTION SumString(@ID INT,@Dismember NVARCHAR(10))
    RETURNS NVARCHAR(1000)
    AS
    BEGIN
       
    DECLARE IPCursor CURSOR FOR 
       
    SELECT IPAddress FROM IPAddress WHERE ComputerID=@ID 

       
    DECLARE @RESULT NVARCHAR(1000)
       
    DECLARE @IP NVARCHAR(20)
       
    SET @RESULT=N''   

       
    OPEN IPCursor
       
    FETCH NEXT FROM IPCursor INTO @IP
       
    WHILE @@FETCH_STATUS=0
       
    BEGIN
           
    IF(@RESULT=N'')
               
    SET @RESULT=@IP
           
    ELSE
               
    SET @RESULT=@RESULT+@Dismember+@IP
           
    FETCH NEXT FROM IPCursor INTO @IP
       
    END 

       
    CLOSE IPCursor
       
    DEALLOCATE IPCursor

       
    RETURN @RESULT
    END
    GO 

    --最后做联合查询显示,其实这个时候已经用不着第二个表了
    SELECT ID,ComputerName,dbo.SumString(ID,N',') AS IPAddressList FROM Computer GROUP BY ID,ComputerName



    通过下面三个截图,可以很明显地看到区别

    image image image

  • 相关阅读:
    Centeos7搭建selenium+Chrome浏览器
    数据结构学习篇之栈和队列
    数据结构学习篇之线性表
    Tornado基础学习篇
    Python控制函数运行时间
    python线程实现异步任务
    Python实现几种简单的排序算法
    python爬虫遇到会话存储sessionStorage
    Python 有哪些优雅的代码实现让自己的代码更pythonic?
    Ubuntu查看端口使用情况,使用netstat命令:
  • 原文地址:https://www.cnblogs.com/chenxizhang/p/1228380.html
Copyright © 2011-2022 走看看