sql知识点的积累和使用过的例子
2015-06-06 18:12
204 查看
越来越发现自己的sql方面的知识的欠缺,所以只能放低姿态一点一点的学了
一 游标和charIndex的使用。
游标我一直没用过,以前只是在同事们写的存储过程里见过,但是一直没看明白(可是我就是比较笨吧)。今天在写一个东西的时候用到了需要用到游标来处理,于是我就先比葫芦画瓢的写了一个,供以后参考吧。
View Code
charIndex的使用呢其实是我这有这样的一个 int类型的ID判断在类似‘1,2,3...’中就一直再报无法将varchar转换为int类型,我刚开始的时候思路一直是把后者转换为int类型, 但是又觉得似乎走不通,然后我就问了下度娘,在网上看有位前辈说用charIndex(),我就说试一下,这个直到我自己在编辑器里敲出来,才明白过来这个和我的思路正好相反,这个是把只有一个值的int 类型转换成了varchar类型,然后再使用charIndex()来判断是否包含,这样来说就可以要到我要的效果。这个事情除了明白了认识了charindex()的使用,还让我觉得,有时候也许换一条思路就可以做到自己想做的事情,要灵活的去运用sql的函数和编程中的思想。
二 stuff()方法
stuff(@s,1,1,'')这个方法的使用也要多去学习理解一下。
一 游标和charIndex的使用。
游标我一直没用过,以前只是在同事们写的存储过程里见过,但是一直没看明白(可是我就是比较笨吧)。今天在写一个东西的时候用到了需要用到游标来处理,于是我就先比葫芦画瓢的写了一个,供以后参考吧。
declare @t table(id int,value varchar(100)) declare my_cursor cursor local FOR SELECT * FROM (SELECT AnsID, AnsTitle FROM dbo.Answers WHERE charindex(','+CONVERT(NVARCHAR(20),AnsID)+',',','+@qusid+',') > 1) AS tb declare @id_old int , @id int , @value varchar(10) , @s varchar(100) open my_cursor fetch my_cursor into @id , @value select @id_old = @id , @s='' while @@FETCH_STATUS = 0 begin if @id = @id_old select @s = @s + ',' + cast(@value as varchar) else begin insert @t values(@id_old , stuff(@s,1,1,'')) select @s = ',' + cast(@value as varchar) , @id_old = @id end fetch my_cursor into @id , @value END insert @t values(@id_old , stuff(@s,1,1,'')) close my_cursor deallocate my_cursor SELECT @t
View Code
charIndex的使用呢其实是我这有这样的一个 int类型的ID判断在类似‘1,2,3...’中就一直再报无法将varchar转换为int类型,我刚开始的时候思路一直是把后者转换为int类型, 但是又觉得似乎走不通,然后我就问了下度娘,在网上看有位前辈说用charIndex(),我就说试一下,这个直到我自己在编辑器里敲出来,才明白过来这个和我的思路正好相反,这个是把只有一个值的int 类型转换成了varchar类型,然后再使用charIndex()来判断是否包含,这样来说就可以要到我要的效果。这个事情除了明白了认识了charindex()的使用,还让我觉得,有时候也许换一条思路就可以做到自己想做的事情,要灵活的去运用sql的函数和编程中的思想。
二 stuff()方法
stuff(@s,1,1,'')这个方法的使用也要多去学习理解一下。
相关文章推荐
- mysql三学习sql声明学习
- 生产应用Win平台Oracle+WebSphere项目实施_WebSphere视频培训教程
- 介绍一下mysql的日期和时间函数
- oracle表达式
- 修改mysql配置的影响
- oracle单行函数
- mysql,sqlite 联表查询 join
- LNMP 1.2升级Nginx、MySQL/MariaDB、PHP教程
- mysql导入导出
- 数据库集群技术漫谈
- 深入理解Redis数据淘汰策略
- Ping CAP CTO、Codis作者谈redis分布式解决方案和分布式KV存储
- Ping CAP CTO、Codis作者谈redis分布式解决方案和分布式KV存储
- 数据库的查询
- centos6 yum 安装memcached
- mysql服务器(二)
- mysql服务器(一)
- mongodb操作
- memcached—如何在Windows操作系统中安装、启动和卸载memcached
- sql删除一条记录后其他记录的id自动迁移,使id连续