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

电脑资料 时间:2019-01-01 我要投稿
【www.unjs.com - 电脑资料】

   

    复制代码代码如下:

    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方法时,并未指定长度,

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

。朋友测试后发现,结果会在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 数据类型以尽量减少字符转换问题,

电脑资料

将所有符合条件的结果拼接成一列并用逗号隔开的一个sql语句》(https://www.unjs.com)。如果使用 char 或 varchar:

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

    如果希望列中的数据值大小显著不同,请使用 varchar。

    如果执行 CREATE TABLE 或 ALTER TABLE 时 SET ANSI_PADDING 为 OFF,则一个定义为 NULL 的 char 列将被作为 varchar 处理。

    当排序规则代码页使用双字节字符时,存储大小仍然为 n 个字节。根据字符串的不同,n 个字节的存储大小可能小于 n 个字符。

    QQ空间 搜狐微博 人人网 开心网 百度搜藏更多

    Tags:sql语句 逗号隔开

    复制链接收藏本文打印本文关闭本文返回首页

    上一篇:REPLICATE 以指定的次数重复字符表达式

    下一篇:SQL SERVER 2000通讯管道后复用劫持

   

相关文章

2008-12-12对有自增长字段的表导入数据注意事项

2012-05-05SQL 特殊语句(学习笔记)

2010-05-05sqlserver replace函数 批量替换数据库中指定字段内指定字符串参

2013-07-07MSSQL数据库占用内存过大造成服务器死机问题的解决方法

2013-01-01存储过程实现订单号,流水单号(8位)的详细思路

2007-11-11SQL Server 不删除信息重新恢复自动编号列的序号的方法

2011-04-04SQL 复合查询条件(AND,OR,NOT)对NULL值的处理方法

2013-03-03游标删除多个表里脏数据的方法

2009-07-07除MSSQL数据库text字段中恶意脚本的删方法

2011-10-10sql 常用技巧整理

   

文章评论

   

最 近 更 新

   

一些SQL Server存储过程参数及例子

SQL Server 2008 到底需要使用哪些端口?

SqlServer 实用操作小技巧集合

sql带分隔符的截取字符串示例

删除重复的记录,并保存第一条记录或保存最

MSSQL汉字转拼音函数实现语句

SQL截取字符串函数分享

直接循环写入数据

动态给表添加删除字段并同时修改它的插入

SQL Server页类型汇总+疑问汇总

   

热 点 排 行

   

SQL Server 2008图文安装教程

SQL Server 2012 安装图解教程(附

sqlserver中distinct的用法(不重

SQL Server导入、导出、备份数据

SQL语句去掉重复记录,获取重复记

SQL Server数据库入门学习总结

SQL Server错误代码大全及解释(

sql convert函数使用小结

sql 时间函数 整理的比较全了

用SQL语句添加删除修改字段、一些

最新文章