sql中往一个表中插入数据但是其中一列需要从另一张表查状态,求指导
其中T_Message表中有(id,sender,receiver,hasAttachment,state)hasAttachment是bit类型,只有0或者1T_Att...
其中T_Message表中有(id,sender,receiver,hasAttachment,state)hasAttachment是bit类型,只有0或者1
T_AttachMessage表中有(id,msgId,filename,filesize,filedesc)
现在是往T_AttachMessage表中插入数据,但是msgId是从T_Message中查询(如果T_Message表中的hasAttachment为1那么将T_Message表中的id插入到T_AttachMessage表中)T_AttachMessage表中的其他数据另外插入.求指点呀!急! 展开
T_AttachMessage表中有(id,msgId,filename,filesize,filedesc)
现在是往T_AttachMessage表中插入数据,但是msgId是从T_Message中查询(如果T_Message表中的hasAttachment为1那么将T_Message表中的id插入到T_AttachMessage表中)T_AttachMessage表中的其他数据另外插入.求指点呀!急! 展开
展开全部
你这个问题问的很含糊,你要明确T_AttachMessage除msgId的其他字段来自哪个表?且这个表与T_Message的关联条件是什么?这样sql就好写了。还有要求不明确,如果hasAttachment为1那么将T_Message表中的id插入到T_AttachMessage表中,那如果为0呢?是不插入吗?还是插入了记录但是为0的这个地方的msgId为空?你需要明确以上问题后,才能让别人写出正确的sql,你也可以把题目直接拷进去,别人能看得懂。我觉得你的msgId要插入是有关联条件的,不是随便选一个hasAttachment为1的就能插入
更多追问追答
追问
T_AttachMessage除msgId的其他字段是在页面自己手动填入的,如果hasAttachment为1那么将T_Message表中的id插入到T_AttachMessage表中的msgId,如果为0的话 ,什么都不插入!
追答
这样,我举个例子你看一下:
如果是页面添加数据的话,那么就是说id,filename,filesize,filedesc相当于这些数据是页面代入的值,插入数据这样就可以了,
insert into T_AttachMessage(id,msgId,filename,filesize,filedesc)
select 页面id, b.id, 页面filename, 页面filesize, 页面filedesc
from T_Message a, T_AttachMessage b
where a.** = b.**
and a.hasAttachment = 1
and b.id = 页面id;
我说的意思其实就是你代码代入的数据要跟某些表关联才能产生结果啊?不然怎么会有数据呢?
你总不可能比如我在页面添加了数据,然后可以随便从T_Message找个hasAttachment为1的相关id插入吧?
展开全部
insert into T_AttachMessage (xx,xx) select xx,xx from T_Message where T_Message.hasAttachment
=1
=1
追问
这样不行呀,这样只能插入T_MessageAttach中的(MsgID)
语句难道这样?这样写在后台代码里,貌似有点别扭呀!
insert into T_MessageAttach(MsgID,[FileName],FileDesc,FileSize) values('select ID from T_Message where HasAttachment=1','aa','bb','100')
追答
有哪些列你就 select 哪些列啊
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询