比如:表A里面的一个字段叫做MOBILE 里面存的记录如下 : 123456781 表B里面的一个字段也叫做MOBILE里面存的记录如下 12341910 (1)我们要查询一下A和B里面都有的,以前我使用的是 select A.mobile from A where A.mobile in (select B.mobile from B) 出来结果为: 11234 没关系,去除重复就得到结果1,2,3,4了 现在我们使用另外一种SQL呢: select A.mobile from A,B
mysql 不支持全外连接,那么使用union all进行替换 -- 其他数据库 SELECT * FROM aa aFULL OUTER JOIN bb b ON a.col1=b.col1AND a.col2=b.col2AND a.col3=b.col3AND a.col4=b.col4AND a.col5=b.col5AND a.col6=b.col6WHERE a.col1 IS NULL OR b.col1 IS NULL -- mysql数据库替换方法SELECT COUNT(co
mysql数据库创建,表创建模等模板脚本 -- 用root用户登录系统,运行脚本 -- 创建数据库 create database mydb61 character set utf8 ; -- 选择数据库 use mydb61; -- 添加 dbuser1 用户 -- 创建用户'dbuser61'password为 'dbuser61'拥有操作数据库mydb61的全部权限 GRANT ALL ON mydb61.* TO dbuser61 IDENTIFIED BY "dbuser
对于外连接,Oracle中可以使用“(+)”来表示,9i可以使用LEFT/RIGHT/FULL OUTER JOIN,下面将配合实例一一介绍.1. LEFT OUTER JOIN:左外关联 SELECT e.last_name, e.department_id, d.department_name FROM employees e LEFT OUTER JOIN departments d ON (e.department_id = d.department_id); 等价于 SELECT e
SQL中的连接可以分为内连接,外连接,以及交叉连接 . 1. 交叉连接CROSS JOIN 如果不带WHERE条件子句,它将会返回被连接的两个表的笛卡尔积,返回结果的行数等于两个表行数的乘积: 举例,下列A.B.C 执行结果相同,但是效率不一样: A:SELECT * FROM table1 CROSS JOIN table2 B:SELECT * FROM table1,table2 C:select * from table1 a inner join table2 b A:select a