sql--CONVERT、FOR XML PATH解决实际问题
需求:每个平台分类下的门店,每个门店的名称、图片路径、评分,每个门店下的四个产品的名称、图片路径、评分

思路:
一开始门店动态化好写,用Ajax就行了。但是每个门店下面的产品,每个去请求一次查询有点不太现实。
一开始准备用每个门店的Id去发起请求,被自己蠢哭了。
在换个思路用sql语句吧
同时把这么多数据一把查出来。

就是把这两张表拼成一张表,把数据作为一行数据在用符号分割,前台在取出来。
WITH td
AS ( SELECT Hishop_Stores.StoreId ,
Hishop_Stores.StoreName ,
Hishop_Products.FirstraceScore ,
Hishop_Products.StoreId AS id ,
Hishop_Products.ProductName ,
Hishop_Products.ImageUrl1
FROM ( SELECT StoreId ,
StoreName ,
StoreImages,
FirstraceScore
FROM Hishop_Stores
) AS Hishop_Stores
LEFT JOIN ( SELECT StoreId ,
ProductName ,
FirstraceScore ,
ImageUrl1
FROM Hishop_Products
WHERE ProductName IS NOT NULL
) AS Hishop_Products ON Hishop_Stores.StoreId = Hishop_Products.StoreId
)
SELECT B.StoreId ,
B.StoreName ,
B.FirstraceScore ,
B.StoreImages,
( SELECT CONVERT(VARCHAR(100), td.ProductName) + '|'
+ CONVERT(VARCHAR(100), ISNULL(td.FirstraceScore, 0))
+ '|' + CONVERT(VARCHAR(100), ISNULL(td.ImageUrl1, '无'))
+ '='
FROM td
WHERE td.StoreId = B.StoreId
ORDER BY td.FirstraceScore DESC
FOR
XML PATH('')
) AS ProductList
FROM Hishop_Stores B
where ShopTypeId=10
GROUP BY StoreId ,
StoreName ,
StoreImages,
B.FirstraceScore;
--ORDER BY B.FirstraceScore DESC;
结果:

OK
其中用到了CONVERT来转换格式,FOR XML PATH('')来实现行转列。
最后Ajax
$(function () {
var shopTypeId = getParam('shopTypeId');
$.ajax({
type: "post", url: "/API/StoreProductAJAX.ashx", data: { action: 'storelist',shopTypeId:shopTypeId },
async: false,
success: function (data)
{
for (var i = 0; i < data.length; i++)
{
var msg = data[i];
var score = msg.FirstraceScore;
var name = msg.StoreName;
var list = msg.ProductList;
var strs = new Array(); //定义一数组
var strsnew = new Array(); //定义一数组
var strlist = new Array();
strs=list.split("="); //字符分割
for (ii = 0; ii < strs.length; ii++)
{
strsnew = strs[ii].split("|"); //字符分割
for (j = 0; j < strsnew.length; j++)
{
strlist.push(strsnew[j]);
}
//document.write(strs[i] + "<br/>"); //分割后的字符输出
}
//document.write( strlist+ "<br/>"); //分割后的字符输出
//alert(strsnew);
//if (name == "")
//{
// continue;
//}
if (score == 0)
{
if (strlist[0] == "")
{
$("#store").append($(' <div class="list-lump border-t" id="' + msg.StoreId + '"><dl class="border-b"><dt><em><img src="'+msg.StoreImages+'" onerror="this.src=\'/Storage/master/depot/img-1.jpg\'"></em></dt><dd><span class="list-n1">' + msg.StoreName + '</span><a href="/vShop/StoreProductList?storeId=' + msg.StoreId + '">进店逛逛</a></dd></dl><ul class="clearfix border-b" id="product"> </li></ul></div>'));
continue;
}
。。。。
这边感觉自己写的有点蠢 不知道怎么去分割输出比较好
sql--CONVERT、FOR XML PATH解决实际问题的更多相关文章
- 使用SQL SERVER FOR XML PATH将多个结果集转换成一行并进行去重处理
在一个医药行业的系统中需要根据患者的接触记录ID获取不同接触类型的集合,效果像这样 --患者接触记录信息,一个患者可以有N个不同的接触记录,每个接触记录又有N个接触类型记录 IF OBJECT ...
- 二、sql新增后返回主键|sql 使用 FOR XML PATH实现字符串拼接|sql如果存在就修改不存在就新增
一.sql新增后返回主键 1,返回自增的主键: INSERT INTO 表名 (字段名1,字段名2,字段名3,…) VALUES (值1,值2,值3,…) SELECT @@IDENTITY 2,返回 ...
- 灵活运用 SQL SERVER FOR XML PATH 转
灵活运用 SQL SERVER FOR XML PATH FOR XML PATH 有的人可能知道有的人可能不知道,其实它就是将查询结果集以XML形式展现,有了它我们可以简化我们的查询语句实现一些 ...
- SQL Server FOR XML PATH 语句的应用---列转行
经常在论坛看到高手使用了 for xml path,由于是搜索一下,记录了详细的使用方法.在SQL Server中利用 FOR XML PATH 语句能够把查询的数据生成XML数据,下面是它的一些应用 ...
- 问题:sqlserver有没有类似Oracle的LISTAGG;结果: 灵活运用 SQL SERVER FOR XML PATH
灵活运用 SQL SERVER FOR XML PATH FOR XML PATH 有的人可能知道有的人可能不知道,其实它就是将查询结果集以XML形式展现,有了它我们可以简化我们的查询语句实现一些以前 ...
- 使用 SQL的 for xml path来进行字符串拼接
本篇主要讲怎么利用SQL的FOR XML PATH 参数来进行字符串拼接,FOR XML PATH的用法很简单,它会以xml文件的形式来返回数据. 我的讲解步骤: 1:构造初始数据 2:提出问题 3: ...
- sqlserver -- 学习笔记(八)体验charindex、stuff 和 for xml path在实际问题中的应用及几个问题的探讨
写在前面 之前做了个微信端顾客扫码评价员工的功能,除了打分数,还可以打标签. 需要统计分数和统计各个员工每种标签被点击的次数. 后来加了个要求,需要查看客户对某个员工一次服务所打出的标签组合. 在不 ...
- sql 使用 FOR XML PATH实现字符串拼接
sql中经常需要把多个行数据合成一行下面是利用 FOR XML PATH来实现的简单介绍. 1,把图一的转换为图二: SELECT articleID, (),tagID)+',' FROM arti ...
- 使用 SQL的 for xml path来进行字符串拼接 (group by)
参考: http://www.cnblogs.com/repository/archive/2011/01/18/1938418.html select convert(varchar(10),c.[ ...
随机推荐
- Clearsigned file isn't valid, got 'NOSPLIT' (does the network require authentication?)
ubuntu16在运行sudo apt-get update 命令后,报出错误: Clearsigned file isn't valid, got 'NOSPLIT' (does the netwo ...
- asp.net webapi 自托管插件式服务
webapi问世已久,稀里糊涂的人哪它都当mvc来使,毕竟已mvc使用级别的经验就可以应对webapi. webapi和mvc在asp.net5时代合体了,这告诉我们,其实 它俩还是有区别的,要不现在 ...
- C# 查找其他应用程序并打开、显示、隐藏、关闭
软件开发中,有时迫不得已要用到第三方的软件,这时就涉及到在C#应用程序需要对第三方软件打开.显示.隐藏以及关闭. 下面列举了几个常用的方式 打开应用程序,下面是2种简单用法: 第一种: public ...
- C#串口编程测试收发
原文:http://www.cnblogs.com/vsdot/archive/2013/04/23/3263348.html 基本传递方法:RS232传输要有1位起始位,8位数据位.1位校验位( ...
- IOS AudioServicesPlaySystemSound 后台锁屏播放
AudioServicesPlaySystemSound 想在锁屏后台播放报警提示音. 添加了UIBackgroundModes,audio,官方审核不通过! IOS的闹钟是怎么实现的,锁屏不能播放声 ...
- springboot+shiro+jwt
1.添加依赖 <dependency> <groupId>org.apache.shiro</groupId> <artifactId>shiro-sp ...
- 90. Subsets II (Back-Track, DP)
Given a collection of integers that might contain duplicates, nums, return all possible subsets. Not ...
- JS如何判断浏览器类型,如何模拟浏览器类型(模拟微信浏览器)
一.前言 在编写前端代码时,为了页面兼容性,我们往往需要考虑不同的浏览器类型 而这就需要在前端代码中进行识别和区分 接下来就来谈谈对浏览器类型的识别 二.正文 (一).查看浏览器类型的核心代码 var ...
- 滑动窗口的中位数 · Sliding Window Median
[抄题]: 给定一个包含 n 个整数的数组,和一个大小为 k 的滑动窗口,从左到右在数组中滑动这个窗口,找到数组中每个窗口内的中位数.(如果数组个数是偶数,则在该窗口排序数字后,返回第 N/2 个数字 ...
- static变量和static函数
在C语言编程中,static的一个作用是信息屏蔽! 比方说,你自己定义了一个文件 -- 该文件中有一系列的函数以及变量的声明和定义! 你希望该文件中的一些函数和变量只能被该文件中的函数使用,那么,你可 ...