• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > 将所有符合条件的结果拼接成一列并用逗号隔开的一个sql语句

将所有符合条件的结果拼接成一列并用逗号隔开的一个sql语句

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了sql语句,逗号隔开等相关知识,希望本文的分享对您有所帮助

把所有符合条件的结果拼接成一列,用逗号隔开的一个sql语句。

代码如下:
create table tb(id int, value varchar(10))
insert into tb values(1, 'aa')
insert into tb values(1, 'bb')
insert into tb values(2, 'aaa')
insert into tb values(2, 'bbb')
insert into tb values(2, 'ccc')
go
create function [dbo].[f_str](@id int) returns nvarchar(1000)
as
begin
declare @str nvarchar(1000)
set @str = ''
select @str = @str + ',' + cast(value as nvarchar(900)) from tb where id = @id
set @str = right(@str , len(@str) - 1)
return @str
end
go
--调用函数
select id , value = dbo.f_str(id) from tb group by id

运行结果:

本来在上面的函数中所有的nvarchar都是varchar类型的,并且上面函数的红色处在调用cast方法时,并未指定长度。朋友测试后发现,结果会在30个字符 时截断,原来以为是varchar和nvarchar的区别,我试着将varchar改成了nvarchar,朋友测试的结果是在54个字符处截断。我查了下,是varchar的默认长度问题,见sql server联机丛书中下面的说明:


char 和 varchar
固定长度 (char) 或可变长度 (varchar) 字符数据类型。

char[(n)]

长度为 n 个字节的固定长度且非 Unicode 的字符数据。n 必须是一个介于 1 和 8,000 之间的数值。存储大小为 n 个字节。char 在 SQL-92 中的同义词为 character。

varchar[(n)]

长度为 n 个字节的可变长度且非 Unicode 的字符数据。n 必须是一个介于 1 和 8,000 之间的数值。存储大小为输入数据的字节的实际长度,而不是 n 个字节。所输入的数据字符长度可以为零。varchar 在 SQL-92 中的同义词为 char varying 或 character varying。

注释
如果没有在数据定义或变量声明语句中指定 n,则默认长度为 1。如果没有使用 CAST 函数指定 n,则默认长度为 30。

将为使用 char 或 varchar 的对象被指派数据库的默认排序规则,除非用 COLLATE 子句另外指派了特定的排序规则。该排序规则控制用于存储字符数据的代码页。

支持多语言的站点应考虑使用 Unicode nchar 或 nvarchar 数据类型以尽量减少字符转换问题。如果使用 char 或 varchar:

如果希望列中的数据值大小接近一致,请使用 char。


如果希望列中的数据值大小显著不同,请使用 varchar。
如果执行 CREATE TABLE 或 ALTER TABLE 时 SET ANSI_PADDING 为 OFF,则一个定义为 NULL 的 char 列将被作为 varchar 处理。

当排序规则代码页使用双字节字符时,存储大小仍然为 n 个字节。根据字符串的不同,n 个字节的存储大小可能小于 n 个字符。
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 浅析mysql 语句的调度优先级及改变
  • SQL语句中SUM与COUNT的区别深入分析
  • 用SQL实现统计报表中的"小计"与"合计"的方法详解
  • 基于sql语句的一些常用语法积累总结
  • Mysql跨表更新 多表update sql语句总结
  • PHP5 mysqli的prepare准备语句使用说明
  • 规范化的SQL数据修改语句总结
  • 在MySQL数据库中使用C执行SQL语句的方法
  • 工作中常用的mysql语句分享 不用php也可以实现的效果
  • SQL语句详解 MySQL update的正确用法

相关文章

  • 2018-12-05实例详解mysql记录耗时的sql语句
  • 2018-12-05Mysql 数据库双机热备的配置方法
  • 2018-12-05浅谈sql语句优化
  • 2018-12-05SQL 时间类型的模糊查询
  • 2017-05-11在Python安装MySQL支持模块的方法
  • 2018-12-05sqlserver帐号被禁用如何处理
  • 2018-12-05隐藏在SQLServer 字段中的超诡异字符解决过程
  • 2018-12-05sql 常用技巧整理
  • 2018-12-05mysql优化配置参数
  • 2018-12-05如何获得MySQL结果集中的第n个最高值?使用MySQL LIMIT的解决案例

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • sql语句中如何将datetime格式的日期转换为yy-mm-dd格式
    • 数据库存储过程分页显示
    • Oracle不同数据库间对比分析脚本
    • 数据库中超键、主键、外键等的定义用法详解
    • MySQL可视化管理工具phpMyAdmin的学习
    • oracle group by语句实例测试
    • [教程]MongoDB 从入门到进阶 (aggregation数据库状态)
    • mysql教程:mysql索引的类型
    • mysql insert语句操作实例讲解
    • 推荐10款drbd8.4.2特效(收藏)

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有