mysql,php 中多对多关系的问题

老师只让我们建两个,一个表存的是新闻编辑员的信息,名字、密码,和所管理的新闻版块(是数字1,2,3,这样,可能是多个)。
另一个表示放新闻版块的 id 和版块名。
现在要我们显示所有编辑员信息,请问怎么实现?不用写具体代码……说一下方法行了
你们说的我明白,但是那是在新闻版块是单独一个数字的时候……,现在新闻版块里面可能有多个数字,逗号分隔开的。

用一条sql语句就行


设表结构如下:

编辑员表 editor: id, name,pwd,newsblocks

新闻版块表 news : id, name


sql语句如下:

SELECT editor.*,GROUP_CONCAT(news.`name`) AS newsblock_name  FROM editor

LEFT JOIN news ON INSTR(editor.`newsblocks`, news.`id`)

GROUP BY editor.id

这是查询结果:

其中 newsblock_name就是对应的新闻版块名

温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-10-26

用你的新闻版块表中的版块id和第一个表的新闻版块id左关联,

然后出编辑员相关信息字段就可以了


针对你说的这种情况,你看你是用php中的split()函数(或者是explode()函数,记不太清楚了),来把字段内容拆分,还是想直接在mysql中直接将字段内容拆分开了,反正就是字段内容中的例如1,2,3这样的1行,拆分成3行,

我这有个原来写的sqlserver中的split()函数实现,你可以看下,改成mysql中的就可以了

create FUNCTION [dbo].[split](@Long_str varchar(8000),@split_str varchar(100))    
RETURNS  @tmp TABLE(           
    short_str varchar(8000)    
)    
AS   
BEGIN   
    DECLARE @long_str_Tmp varchar(8000),
@short_str varchar(8000),
@split_str_length int
    SET @split_str_length = LEN(@split_str) 
    IF CHARINDEX(@split_str,@Long_str)=1 
         SET @long_str_Tmp=SUBSTRING(@Long_str,@split_str_length+1,LEN(@Long_str)-@split_str_length)
    ELSE
         SET @long_str_Tmp=@Long_str
    IF CHARINDEX(REVERSE(@split_str),REVERSE(@long_str_Tmp))>1    
        SET @long_str_Tmp=@long_str_Tmp+@split_str    
    ELSE   
        SET @long_str_Tmp=@long_str_Tmp
    WHILE CHARINDEX(@split_str,@long_str_Tmp)>0    
        BEGIN   
            SET @short_str=SUBSTRING(@long_str_Tmp,1,
     CHARINDEX(@split_str,@long_str_Tmp)-1)    
            DECLARE @long_str_Tmp_LEN INT,@split_str_Position_END int   
            SET @long_str_Tmp_LEN = LEN(@long_str_Tmp)    
            SET @split_str_Position_END = LEN(@short_str)+@split_str_length    
            SET @long_str_Tmp=REVERSE(SUBSTRING(REVERSE(@long_str_Tmp),1,
     @long_str_Tmp_LEN-@split_str_Position_END))
            IF @short_str<>'' INSERT INTO @tmp SELECT @short_str    
        END   
    RETURN     
END
--select * from dbo.split('1/2/3/4/5/6/','/')

第2个回答  2013-10-26
通过一个表的新闻版块数字(就是ID)关联另一个表的新闻版块ID,把版块名找出来,然后就可以显示所有编辑员的信息,包括信息,名字、密码,和所管理的新闻版块ID,版块名

多个数字可以用循环,在一个字段循环替换,如果新闻版块分类少的话可以考虑直接用update,省事点。

下面是一个例子
--创建表结构
IF(OBJECT_ID('TA') IS NOT NULL) DROP TABLE TA
CREATE TABLE TA(id INT,[value] VARCHAR(100), class VARCHAR(10))
INSERT INTO TA(id,[value],class)
SELECT 1,'3,2,4,5','no' UNION ALL
SELECT 2,'5,1,1+2','yes'
--查询结果
SELECT T.id
,SUBSTRING(T.[value],R.number,CHARINDEX(',',T.[value]+',',R.number)-R.number) AS value
,T.class
,ROW_NUMBER() OVER (PARTITION BY T.id ORDER BY T.id) AS code
FROM TA AS T
JOIN (
SELECT TOP 10 number FROM [master].dbo.spt_values
WHERE [type]='P' ORDER BY number)AS R ON (CHARINDEX(',',','+T.[value],R.number)=R.number)
--运行结果
id value class code
----------- ---------------------------- ---------- --------------------
1 3 no 1
1 2 no 2
1 4 no 3
1 5 no 4
2 5 yes 1
2 1 yes 2
2 1+2 yes 3本回答被网友采纳

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网