SQL SERVER 特殊需求的一个替换实例 --【叶子】

需求贴:

http://topic.csdn.net/u/20120204/10/8b902fd2-8909-4ed9-b534-4a1a72454eff.html#r_77443331

需求简介:

比如:YYYYN,  结果处理为:人1,人2,人3,人4

分析:

貌似就是一个字符串的替换,如果是'Y'替换成'人'+Y的所在位置的编号。

解决方案:

declare @T table (id int,col varchar(5))
insert into @T
select 1,'YYYYN' union all
select 2,'YNNNY' union all
select 3,'NNNYN' union all
select 4,'YYNYN'

--1.第一种方法:case when
--最直观的处理方式 
select id,col=left(col,len(col)-1) from 
(
 select id,col=
 case when left(col,1)='Y' then '人1,' else '' end+
 case when substring(col,2,1)='Y' then '人2,' else '' end+
 case when substring(col,3,1)='Y' then '人3,' else '' end+
 case when substring(col,4,1)='Y' then '人4,' else '' end+
 case when substring(col,5,1)='Y' then '人5,' else '' end
 from @T
) a
/*
id          col
----------- --------------------
1           人1,人2,人3,人4
2           人1,人5
3           人4
4           人1,人2,人4
*/


--2.使用自定义函数 
--创建函数
create function fn_GetPersonCount
(
    @str varchar(5)
)
returns varchar(20)
as
begin
    declare @result varchar(20) set @result=''
    declare @i int set @i=0
    while(charindex('Y',@str)>0)
    begin
        set @result=@result+'人'+ltrim(charindex('Y',@str)+@i)+','
        set @str=right(@str,len(@str)-charindex('Y',@str))
        set @i=@i+1
    end
    set @result=left(@result,len(@result)-1)
    return @result
end

declare @T table (id int,col varchar(5))
insert into @T
select 1,'YYYYN' union all
select 2,'YNNNY' union all
select 3,'NNNYN' union all
select 4,'YYNYN'

select id,col=dbo.fn_GetPersonCount(col) from @T
/*
id          col
----------- --------------------
1           人1,人2,人3,人4
2           人1,人5
3           人4
4           人1,人2,人4
*/


--3.合并列值

declare @T table (id int,col varchar(5))
insert into @T
select 1,'YYYYN' union all
select 2,'YNNNY' union all
select 3,'NNNYN' union all
select 4,'YYNYN'

;with maco as
(
select a.*,'人'+ltrim(b.number+1) as c1 from @T a,master..spt_values b 
where b.type='p' and b.number <5 and substring(col,0+right(number+1,1),1)='Y'
)

select id, col=
stuff((select ','+c1 from maco t where id=maco.id for xml path('')), 1, 1, '')
from maco group by id

/*
id          col
----------- --------------------
1           人1,人2,人3,人4
2           人1,人5
3           人4
4           人1,人2,人4
*/


 

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
你可以按照以下步骤创建一个连接 Sqlserver 数据库的 Django Web 项目实例: 1. 确保已安装 Django 和 pyodbc: ```shell pip install django pyodbc ``` 2. 在 Django 项目的 `settings.py` 文件中配置数据库连接: ```python DATABASES = { 'default': { 'ENGINE': 'sql_server.pyodbc', 'NAME': 'your_database_name', 'HOST': 'your_database_host', 'PORT': 'your_database_port', 'USER': 'your_database_user', 'PASSWORD': 'your_database_password', 'OPTIONS': { 'driver': 'SQL Server Native Client 11.0', # 根据你的 Sqlserver 版本选择驱动 }, }, } ``` 3. 在 `settings.py` 文件中添加 pyodbc 驱动配置: ```python DATABASES['default']['OPTIONS']['driver'] = 'SQL Server Native Client 11.0' # 根据你的 Sqlserver 版本选择驱动 ``` 4. 在项目的 `__init__.py` 文件中添加以下代码: ```python import pyodbc # 配置 Sqlserver 驱动 pyodbc.autocommit = True pyodbc.pooling = False ``` 5. 运行以下命令创建 Django 项目: ```shell django-admin startproject your_project_name ``` 6. 创建一个 Django 应用程序: ```shell cd your_project_name python manage.py startapp your_app_name ``` 7. 在 `settings.py` 文件中将应用程序添加到 `INSTALLED_APPS` 列表中: ```python INSTALLED_APPS = [ ... 'your_app_name', ] ``` 8. 在应用程序的 `models.py` 文件中定义数据库模型: ```python from django.db import models class YourModel(models.Model): # 定义模型字段 field1 = models.CharField(max_length=100) field2 = models.IntegerField() def __str__(self): return self.field1 ``` 9. 运行以下命令创建数据库表: ```shell python manage.py makemigrations python manage.py migrate ``` 10. 在视图中使用模型: ```python from django.shortcuts import render from .models import YourModel def your_view(request): # 从数据库中获取数据 data = YourModel.objects.all() return render(request, 'your_template.html', {'data': data}) ``` 11. 创建模板文件 `your_template.html` 并在其中显示数据: ```html <ul> {% for item in data %} <li>{{ item.field1 }}</li> {% endfor %} </ul> ``` 12. 运行项目: ```shell python manage.py runserver ``` 这样,你就创建了一个连接 Sqlserver 数据库的 Django Web 项目实例。记得根据实际情况修改数据库连接配置和模型字段。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值