重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
mysql支持多个库中不同表的关联查询,你可以随便链接一个数据库
在博山等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供成都网站制作、做网站 网站设计制作按需设计,公司网站建设,企业网站建设,品牌网站设计,营销型网站建设,外贸网站建设,博山网站建设费用合理。
然后,sql语句为:
select * from db1.table1 left join db2.table2 on db1.table1.id = db2.table2.id
只要用数据库名加上"."就能调用相应数据库的数据表了.
数据库名.表名
扩展资料
mysql查询语句
1、查询一张表: select * from 表名;
2、查询指定字段:select 字段1,字段2,字段3....from 表名;
3、where条件查询:select 字段1,字段2,字段3 frome 表名 where 条件表达式;
例:select * from t_studect where id=1;
select * from t_student where age22
4、带in关键字查询:select 字段1,字段2 frome 表名 where 字段 [not]in(元素1,元素2);
例:select * from t_student where age in (21,23);
select * from t_student where age not in (21,23);
5、带between and的范围查询:select 字段1,字段2 frome 表名 where 字段 [not]between 取值1 and 取值2;
例:select * frome t_student where age between 21 and 29;
select * frome t_student where age not between 21 and 29;
mysql
两个表中的信息关联起来使用方法:
1、创建主表:
create
table
UserInfo(
UserID
int
identity(1,1)
primary
key,
--递增主键
UserAccounts
varchar(20),
UserName
varchar(20),
UserPwd
varchar(10));
2、创建附表(含外键)
create
table
News(
NewsID
int
identity(1,1)
primarykey,
UserID
int,
NewsTitle
varchar(
50
),
NewsRelease
varchar(
200
),
NewsReleaseTime
datetime,
FOREIGN
KEY
(UserID)
REFERENCES
UserInfo(UserID));
--外键约束
如果附表已存在,但没外键,可采用以下方法:
alter
table
profession
add
constraint
fk_prov_id
foreign
key(prov_id)
references
province(prov_id)
on
update
cascade
on
delete
cascade;
高级SQL语句INNERJOIN非常实用在接触这个语句之前我要到数据库查询不同表的内容我一般需要执行2次sql语句循环2次。
而现在有了这个语句可以简化成只执行1次语句循环一次
$result=mysql_query(”
SELECTstates.state_id,states.state_name,cities.city_id,cities.city_name,cities.region_idFROM`states`INNERJOINcitiesONstates.state_id=cities.state_idWHEREstates.countrycode=’nl’”
);
我来解说一下,一个数据库中2个表名statesandcities
states目前我所需要的内容是state_id和state_name
cities目前我所需要的内容是city_id和city_name和region_id
为什么特意设定所需要的字段而不全部显示出来呢?因为sql服务器执行的sql语句结果越长解析时间越长执行时间就长套一句我们老板说的话你这样就等于killsqlserver
好了关键的地方来了INNERJOINcitiesINNERJOIN这个命令是将不同表加入到执行中
这样就可以节省sql语句了
ONstates.state_id=cities.state_id这句话好像是重叠在一起应为2个表这个字段都是相同的具体效果自己去试验一下。
方法和操作步骤如下:
1、首先,创建一个测试表,如下图所示,然后进入下一步。
2、其次,插入测试数据,如下图所示,然后进入下一步。
3、接着,完成上述步骤后,查询表中的数据,“select t.* from test_tbl2 t ”,如下图所示,然后进入下一步。
4、最后,完成上述步骤后,编写sql,两个表通过pid与id关联, “select t1.*, t2.* from test_tbl1 t1 join test_tbl2 t2 on t1.p_id = t2.id;”,如下图所示。这样,问题就解决了。
第一:内联(inner join)
如果想把用户信息、积分、等级都列出来,那么一般会这样写:
select * from T1, T3 where T1.userid = T3.userid
(其实这样的结果等同于select * from T1 inner join T3 on T1.userid=T3.userid )。
把两个表中都存在userid的行拼成一行(即内联),但后者的效率会比前者高很多,建议用后者(内联)的写法。
SQL语句:
select * from T1 inner join T2 on T1.userid = T2.userid
运行结果
T1.userid username password T2.userid jifen dengji
1 jack jackpwd 1 20 3
第二:左联(left outer join)
显示左表T1中的所有行,并把右表T2中符合条件加到左表T1中;
右表T2中不符合条件,就不用加入结果表中,并且NULL表示。
SQL语句:
select * from T1 left outer join T2 on T1.userid = T2.userid
运行结果
T1.userid username password T2.userid jifen dengji
1 jack jackpwd 1 20 3
2 owen owenpwd NULL NULL NULL
第三:右联(right outer join)。
显示右表T2中的所有行,并把左表T1中符合条件加到右表T2中;
左表T1中不符合条件,就不用加入结果表中,并且NULL表示。
SQL语句:
select * from T1 right outer join T2 on T1.userid = T2.userid
运行结果
T1.userid username password T2.userid jifen dengji
1 jack jackpwd 1 20 3
NULL NULL NULL 3 50 6
第四:全联(full outer join)
显示左表T1、右表T2两边中的所有行,即把左联结果表 + 右联结果表组合在一起,然后过滤掉重复的。
SQL语句:
select * from T1 full outer join T2 on T1.userid = T2.userid
创建一个用户表和配置表的关联表,里面只需存用户id和配置表id即可,通过中间表实现不同用户配置不同