老师只让我们建两个,一个表存的是新闻编辑员的信息,名字、密码,和所管理的新闻版块(是数字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本回答被网友采纳
多个数字可以用循环,在一个字段循环替换,如果新闻版块分类少的话可以考虑直接用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本回答被网友采纳