从数据库中取数据的问题

非凡棒棒糖 2013-09-05 03:32:58
是个设计公司网站,有关于设计师设计风格的信息,目前每个设计师只能存储一个设计风格(两张表,一个存设计师信息,一个存储风格信息,之间通过风格id关联)现在客户要求一个设计师可以有多个设计风格,我就把设计师存储风格ID的字段改成varchar的了,多个风格ID以逗号隔开,可是我怎么才能在程序中把风格名字给调出来呢???求助,数据库是oracle11G的
...全文
99 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
非凡棒棒糖 2013-09-05
  • 打赏
  • 举报
回复
引用 9 楼 guwei4037 的回复:
4楼小猫给的是sqlserver的,你可以自己百度或谷歌一下,看有没有oracle的版本。 我找了两个,但是不全,要进行改造。 http://www.cnblogs.com/shihujiang/archive/2012/08/09/2630630.html http://blog.csdn.net/xionglang7/article/details/7064842
谢谢
全栈极简 2013-09-05
  • 打赏
  • 举报
回复
4楼小猫给的是sqlserver的,你可以自己百度或谷歌一下,看有没有oracle的版本。 我找了两个,但是不全,要进行改造。 http://www.cnblogs.com/shihujiang/archive/2012/08/09/2630630.html http://blog.csdn.net/xionglang7/article/details/7064842
非凡棒棒糖 2013-09-05
  • 打赏
  • 举报
回复
引用 3 楼 yyantifa 的回复:
现在不是一对多关系吗?有什么问题??
嗯 是的 现在就是一对多的时候数据的存取问题
非凡棒棒糖 2013-09-05
  • 打赏
  • 举报
回复
引用 2 楼 guwei4037 的回复:
你所问的应该就是,字符串分割,并替换为相应名称的问题。比如:"1,2,3",转换为"唯美,浪漫,风情"。 两个思路: 1、在数据库中(不论是oracle还是sqlserver),定义一个函数,直接在sql中调用函数转。 2、在程序中分割字符串,分别替换。
我比较倾向于用第一个方法,因为风格是动态的,客户可能添加一种风格,也可以去掉一种风格,具体的函数怎么写能点拨一下吗?
非凡棒棒糖 2013-09-05
  • 打赏
  • 举报
回复
引用 1 楼 laiyongxin 的回复:
最好在件一张 设计师-设计风格 表 这样以后取数据就方便多了
是个办法,不过程序就需要改动好多了
devmiao 2013-09-05
  • 打赏
  • 举报
回复
select * from table1 where 风格id in (select SplitToTable(风格id) in tanle2) Create FUNCTION [dbo].[SplitToTable] ( @SplitString nvarchar(max), @Separator nvarchar(10)=' ' ) RETURNS @SplitStringsTable TABLE ( [id] int identity(1,1), [value] nvarchar(max) ) AS BEGIN DECLARE @CurrentIndex int; DECLARE @NextIndex int; DECLARE @ReturnText nvarchar(max); SELECT @CurrentIndex=1; WHILE(@CurrentIndex<=len(@SplitString)) BEGIN SELECT @NextIndex=charindex(@Separator,@SplitString,@CurrentIndex); IF(@NextIndex=0 OR @NextIndex IS NULL) SELECT @NextIndex=len(@SplitString)+1; SELECT @ReturnText=substring(@SplitString,@CurrentIndex,@NextIndex-@CurrentIndex); INSERT INTO @SplitStringsTable([value]) VALUES(@ReturnText); SELECT @CurrentIndex=@NextIndex+1; END RETURN; END
yyantifa 2013-09-05
  • 打赏
  • 举报
回复
现在不是一对多关系吗?有什么问题??
全栈极简 2013-09-05
  • 打赏
  • 举报
回复
你所问的应该就是,字符串分割,并替换为相应名称的问题。比如:"1,2,3",转换为"唯美,浪漫,风情"。 两个思路: 1、在数据库中(不论是oracle还是sqlserver),定义一个函数,直接在sql中调用函数转。 2、在程序中分割字符串,分别替换。
lyx266 2013-09-05
  • 打赏
  • 举报
回复
最好在件一张 设计师-设计风格 表 这样以后取数据就方便多了
Redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。 Redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部分场合可以对关系数据起到很好的补充作用。它提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C,Python,Ruby,Erlang等客户端,使用很方便。 Redis支持主从同步。数据可以从主服务器向任意数量的从服务器上同步,从服务器可以是关联其他从服务器的主服务器。这使得Redis可执行单层树复制。存盘可以有意无意的对数据进行写操作。由于完全实现了发布/订阅机制,使得从数据在任何地方同步树时,可订阅一个频道并接收主服务器完整的消息发布记录。同步对读取操作的可扩展性和数据冗余很有帮助。   本课程主要讲解以下内容:1. Redis的基本使用2. Redis数据数据类型3. Redis数据数据管理4. Redis的主从复制5. Redis数据的持久性6. Redis的高可靠性和集群7. Redis的优化和性能测试8. Redis服务器的维护和管理9. Redis服务器的常见问题排错 

110,539

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧