如何交叉检验后显示内容
各位大神:我有两个表,A表里面的字段分别是id,content,B里面是id,content,userid,edittime,B表里面的数据是用户通过EDIT页面对A表里面内容的修改。我想实现以下功能:
如果用户没有登录,则按照ID顺序提取A表里面的内容显示;如果用户登录,则仍按A表中ID顺序显示,但如果该ID行里面的内容,该登录用户已经修改,并在B表里面有,则改行显示B表中最新修改的内容。我是这么写的,好像运行起来有点慢,有没有更有效率的方法?重新设计表也可以。总之,我的目的是如用户没有登陆则显示默认内容,如登陆了,则把相关内容替换显示为用户修改后的内容,显示内容的顺寻还是按照A表中ID的顺序。谢谢各位大神。
session_start () ;
include("IncDB.php");
$result=mysql_query("SELECT * FROM contents",$link);
$row=mysql_fetch_row($result);
$abcb=array();
while($row)
{
@$result1=mysql_query("SELECT * FROM usercontents where id='".$row[0]."' and userid='".$_SESSION['id']."' order by edittime desc limit 1",$link);
@$row1=mysql_fetch_row($result1);
if($row1==null)
{
$abcb[]=$row;}
else
{
$abcb[]=$row1;}
$row=mysql_fetch_row($result);
}
foreach($abcb as $v) {
echo "$v[0]$v[1]
";
}
?>
回复讨论(解决方案)
有人能帮忙看看么?
我就想知道是大家没看懂我的需求,还是其他啊?
看着有点绕圈
在用户没登录的情况下显示A表中的数据(默认的数据),用户登陆了显示B表中用户对应修改的数据,是不是这样的
你对 contents 表的所有记录,都执行一次对 usercontents 表的查询
那当然慢啦
回xuzuning,我也这么觉得是这个原因,那该怎么弄呢?有好办法么?谢谢!
回u014202165,是这个意思。每一行的显示都是这个规则,没登陆或用户未修改的,就显示默认,但如果用户登录了,那么该行就显示用户修改的内容。
大概的理解是:
A表是主记录表
B表是修改日志
如果不改表结构,已登录用户的记录可以通过简单的查询完成
select * from contents a left join (select * from usercontents where userid=[用户session_id] order by edittime desc limit 1) b on a.id=b.id
取出来的数据中包含默认的和最新的,页面再进行相应的处理即可。
如果数据量非常大,建议建立一张最后修改结果表,记录用户最后的修改结果,每个用户只保留一条,然后简单的表关联就可以查出来了,不用到日志中去搜。
忘了提醒下,相关字段请记得建索引,不然数据量大了也是很慢的
B表也是这样,每个用户在每个ID项下,只保留一条数据。是不是用您的代码就可以了?我试试看。
如果取出来的数据是包含默认的和最新的,那也没有意义,我其实可以把A和B两张表合一个也可以,只不过A表中的userid显示为空就可以。但下面怎么办呢?我的意思是怎么实现把用户的内容替代显示默认的内容。
好吧,送佛送到西
select a.id, case when b.content is null then a.content else b.content end content from contents a left join (select * from usercontents where userid=【用户session_id】 order by edittime desc limit 1) b on a.id=b.id
满足 userid=$_SESSION['id'] 的只有一条!
To楼主:
对于B表,不论每个用户在每个ID下有多少条,这个查询都是适用的。
因为子查询是按用户ID进行查找的,并且按编辑时间倒排序并只取了最后一条。
谢谢
我好好学习一下
session_start () ; include("IncDB.php"); //$_SESSION['id'] 只有一个,即使能查到多条记录,由于你有 limit 1,所以至多也只会有一个结果$result1=mysql_query("SELECT * FROM usercontents where userid='".$_SESSION['id']."' order by edittime desc limit 1",$link); $row1=mysql_fetch_row($result1); //把登录用户的信息先查出来$result=mysql_query("SELECT * FROM contents",$link); $row=mysql_fetch_row($result); $abcb=array(); while($row) { if($row1==null) { $abcb[]=$row; } else { $abcb[]=$row1;} $row=mysql_fetch_row($result); } foreach($abcb as $v) { echo "$v[0]$v[1] <br>"; }}
contents 是a表;usercontents是b表。我的代码是这么写的,好像不行啊。肯定是我错了,但该怎么改呢?谢谢谢谢!
session_start () ;
include("IncDB.php");
$result=mysql_query(select a.id, case when b.content is null then a.content else b.content end from content a left join
(select * from b where userid='".$_SESSION['id']."' order by edittime desc limit 1) b on a.id=b.id,$link);
$row=mysql_fetch_row($result);
while($row)
{
$abcb[] = $row;
$row=mysql_fetch_row($result);
}
foreach($abcb as $v) {
echo "$v[0]$v[1]
";
}
//mysql_close($link);
?>
回xuzuning,好像不行。另外,语句是不是也少一个while($row1)?因为同一个用户有可能更改多条内容。
都 limit 1 了,多少条数据不也只查得一条?
只查一条出来不能解决问题,因为,有可能用户会修改多条记录。不知道咋办了。

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



Alipay PHP...

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

Article discusses essential security features in frameworks to protect against vulnerabilities, including input validation, authentication, and regular updates.

The article discusses adding custom functionality to frameworks, focusing on understanding architecture, identifying extension points, and best practices for integration and debugging.

Sending JSON data using PHP's cURL library In PHP development, it is often necessary to interact with external APIs. One of the common ways is to use cURL library to send POST�...

The application of SOLID principle in PHP development includes: 1. Single responsibility principle (SRP): Each class is responsible for only one function. 2. Open and close principle (OCP): Changes are achieved through extension rather than modification. 3. Lisch's Substitution Principle (LSP): Subclasses can replace base classes without affecting program accuracy. 4. Interface isolation principle (ISP): Use fine-grained interfaces to avoid dependencies and unused methods. 5. Dependency inversion principle (DIP): High and low-level modules rely on abstraction and are implemented through dependency injection.

Session hijacking can be achieved through the following steps: 1. Obtain the session ID, 2. Use the session ID, 3. Keep the session active. The methods to prevent session hijacking in PHP include: 1. Use the session_regenerate_id() function to regenerate the session ID, 2. Store session data through the database, 3. Ensure that all session data is transmitted through HTTPS.
