tp5如何跨数据库查询

tp5如何跨数据库查询,第1张

如果是mysql里面两个不同的数据库,应该是可以直接使用 [数据库名称].[表名]来关联的。TP指定的数据库,是因为他要缓存这个数据库的表字段等。试试看行不行,测试通过: SELECT a.*,b.* FROM table1 a LEFT JOIN db2.table2 b ON a.id=b.id

thinkphp model 必须对应数据库表名是设置错误造成的,解决方法为:

1、打开SQL Developer。

2、右击要 *** 作的数据库,然后选择【连接】。

3、在d出对话框中,输入口令,然后点击【确定】。

4、展开【表】目录,右击要 *** 作的表,然后选择【编辑】。

5、此时进入表编辑界面。

6、输入新的表名,然后点击【确定】。

7、此时数据库表名就修改完成了。

---找出这个表中所有类型为varchar型的字段

---不知道你的str型需要对应哪几种类型,只以varchar型为例,其他类型可以查找systypes

---将所需要的type添加到最后的type筛选语句中

select t2.name from

(

---找到主键为aaa,并且与表中aaa字段的外键相对应的表

select b.id

from

(

---找出表1中aaa外键所对应的主表和主键

select rkeyid,rkey

from

(

---找出表1中的所有外键

select a.id,b.* from sysobjects a inner join sysforeignkeys b

on a.id=b.fkeyid

where xtype='U' and name='表1'

)c

inner join

(

---找出aaa字段所在的所有表

select id from syscolumns

where name='aaa'

)d

on c.id=d.id

)a

inner join

(

---找出aaa字段所在的所有表

select id from syscolumns

where name='aaa'

)b

on a.rkeyid=b.id

)t1

inner join syscolumns t2

on t1.id=t2.id

where t2.type=39

回答修改:

根据需求,修改如下

declare @name varchar(255)

---找出主表的名字

set @name=

(select t2.name from

(---找出SampleDetails中的lngYyGlAID外键所对应的主表

---有可能SampleDetails中不只有一个外键

---如果确定只有一个外键,不用和d相交

select rkeyid

from

(

---找出SampleDetails中的所有外键

select a.id,b.* from sysobjects a inner join sysforeignkeys b

on a.id=b.fkeyid

where xtype='U' and name='SampleDetails'

)c

inner join

(

---找出lngYyGlAID字段所在的所有表

select id from syscolumns

where name='lngYyGlAID'

)d

on c.id=d.id)t1

inner join

sysobjects t2

on t1.rkeyid=t2.id)

---从主表中查出strcode字段的所有信息

declare @sql varchar(255)

set @sql='select strCode from '+@name

exec(@sql)


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10015149.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存