mysql和nlsql为啥要联合使用_清晰讲解SQL语句中的内连接,通用于Mysql和Oracle,全是干货哦...

本文章目的:力求清晰明了讲解SQL语句的内连接的各种应用,没有深奥的理解!

前奏:这篇文章和下篇文章会将内连接和外连接讲解清楚

SQL语句的多表查询常用的有以下几种:

两表联合查询

(1)内连接

(2)外连接(分左外连接、右外连接)

(3)全外连接

(4)自连接

三表查询

(1)三表查询

本片讲解两表联合查询的内连接:

第一步:准备表,员工表emp,部门表dept

关联关系:员工表的“deptno”字段关联部门表的“deptno”

建表语句如下:

create tableDEPT

(

DEPTNOint(2) not null,

DNAMEVARCHAR(14),

LOCVARCHAR(13)

);alter tableDEPTadd constraint PK_DEPT primary key(DEPTNO);create tableEMP

(

EMPNOint(4) primary key,

ENAMEVARCHAR(10),

JOBVARCHAR(9),

MGRint(4),

HIREDATE DATE,

SALdouble(7,2),

COMMdouble(7,2),

DEPTNOint(2)

);alter tableEMPadd constraint FK_DEPTNO foreign key(DEPTNO)references DEPT (DEPTNO);

表结构如下:

7f08efc41e74aa43b35817a11344396c.png

插入数据:

insert into DEPT (DEPTNO, DNAME, LOC)values (10, 'ACCOUNTING', 'NEW YORK');insert into DEPT (DEPTNO, DNAME, LOC)values (20, 'RESEARCH', 'DALLAS');insert into DEPT (DEPTNO, DNAME, LOC)values (30, 'SALES', 'CHICAGO');insert into DEPT (DEPTNO, DNAME, LOC)values (40, 'OPERATIONS', 'BOSTON');

insert into DEPT (DEPTNO, DNAME, LOC)values (10, 'ACCOUNTING', 'NEW YORK');insert into DEPT (DEPTNO, DNAME, LOC)values (20, 'RESEARCH', 'DALLAS');insert into DEPT (DEPTNO, DNAME, LOC)values (30, 'SALES', 'CHICAGO');insert into DEPT (DEPTNO, DNAME, LOC)values (40, 'OPERATIONS', 'BOSTON');commit;insert intoEMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)values (7369, 'SMITH', 'CLERK', 7902, '1980-12-17', 800, null, 20);insert intoEMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)values (7499, 'ALLEN', 'SALESMAN', 7698, '1981-02-20', 1600, 300, 30);insert intoEMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)values (7521, 'WARD', 'SALESMAN', 7698, '1981-02-22', 1250, 500, 30);insert intoEMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)values (7566, 'JONES', 'MANAGER', 7839, '1981-04-02', 2975, null, 20);insert intoEMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)values (7654, 'MARTIN', 'SALESMAN', 7698, '1981-09-28', 1250, 1400, 30);insert intoEMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)values (7698, 'BLAKE', 'MANAGER', 7839, '1981-05-01', 2850, null, 30);insert intoEMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)values (7782, 'CLARK', 'MANAGER', 7839, '1981-06-09', 2450, null, 10);insert intoEMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)values (7788, 'SCOTT', 'ANALYST', 7566, '1987-04-19', 3000, null, 20);insert intoEMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)values (7839, 'KING', 'PRESIDENT', null, '1981-11-17', 5000, null, 10);insert intoEMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)values (7844, 'TURNER', 'SALESMAN', 7698, '1981-09-08', 1500, 0, 30);insert intoEMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)values (7876, 'ADAMS', 'CLERK', 7788, '1987-05-23', 1100, null, 20);insert intoEMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)values (7900, 'JAMES', 'CLERK', 7698, '1981-12-03', 950, null, 30);insert intoEMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)values (7902, 'FORD', 'ANALYST', 7566, '1981-12-03', 3000, null, 20);insert intoEMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO)values (7934, 'MILLER', 'CLERK', 7782, '1982-01-23', 1300, null, 10);

第二步:讲解内连接

(1)笛卡尔积现象:(什么是笛卡尔积,在此不在讲解,如果有需要,可以留言,我再补充)

通过关键字:CROSS JOIN

优点:有助于理解多表查询

缺点:交叉连接会产生笛卡尔积,产生多条无用结果

解决方案:(1)使用natural子句,即自然连接

(2)使用using子句

(3)使用on 子句

86f5277758df297b37c6bbd6b024ba1c.png

方案一:使用自然连接

优点:会自动的按照所有的同名列进行匹配,并且同名列只显示一次,简便

缺点:会自动的按照“所有的”同名列进行匹配,如果希望按照某一个同名列进行匹配,自然连接无能为力

解决方案:使用using

3296020424b540392d1d7bbcc715d696.png

方案(2):使用using子句

优点:只显示指定的同名字段

缺点:如果两张表的关联字段不同名怎么办?

解决方案:使用on

9e5c9ec3df249603adfecacc8359ae50.png

方案(3):使用on子句

优点:不管是否有同名列,都可以使用;虽然稍显复杂,但是可读性高,很好的解决了自然连接和using子句的缺陷

因此,在开发中,推荐使用on子句

aebd2e12df1d7dbb3efecfba02592484.png

至此,多表查询的内连接讲解完毕,总结一下:

交叉连接(cross join):会产生笛卡尔积,产生大量无用数据,无用

自然连接(natural):会自动的按照所有的同名列进行匹配,并且同名列只显示一次,显示繁琐

使用(using):按照某一个同名列进行匹配,指定了同名列,一定程度减少了自然连接的显示量

使用(on):如果两张表的关联字段不同名,自然连接和using无能为力,只有通过on子句。推荐使用on子句

完结!

注:下篇文章,讲解外连接,有问题要交流的欢迎留言,有则改之无则加勉。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用Java的JDBC来连接OracleMySQL数据库,然后通过执行SQL语句Oracle的数据导入到MySQL。 下面是一个简单的Java代码示例,假设你已经准备好了OracleMySQL的JDBC驱动程序: ```java import java.sql.*; public class OracleToMySQL { public static void main(String[] args) { String oracleUrl = "jdbc:oracle:thin:@localhost:1521:ORCL"; String oracleUser = "username"; String oraclePassword = "password"; String mysqlUrl = "jdbc:mysql://localhost:3306/mysql"; String mysqlUser = "root"; String mysqlPassword = "password"; try { // Connect to Oracle database Connection oracleConnection = DriverManager.getConnection(oracleUrl, oracleUser, oraclePassword); Statement oracleStatement = oracleConnection.createStatement(); // Connect to MySQL database Connection mysqlConnection = DriverManager.getConnection(mysqlUrl, mysqlUser, mysqlPassword); Statement mysqlStatement = mysqlConnection.createStatement(); // Export tables from Oracle to MySQL String[] tableNames = { "table1", "table2", "table3" }; for (String tableName : tableNames) { // Export table schema ResultSet rs = oracleStatement.executeQuery("SELECT * FROM " + tableName + " WHERE 1=0"); ResultSetMetaData rsmd = rs.getMetaData(); int numColumns = rsmd.getColumnCount(); StringBuilder createTableSql = new StringBuilder("CREATE TABLE " + tableName + " ("); for (int i = 1; i <= numColumns; i++) { String columnName = rsmd.getColumnName(i); String columnType = rsmd.getColumnTypeName(i); int columnSize = rsmd.getColumnDisplaySize(i); createTableSql.append(columnName + " " + columnType + "(" + columnSize + "),"); } createTableSql.setLength(createTableSql.length() - 1); createTableSql.append(")"); mysqlStatement.execute(createTableSql.toString()); // Export table data rs = oracleStatement.executeQuery("SELECT * FROM " + tableName); while (rs.next()) { StringBuilder insertSql = new StringBuilder("INSERT INTO " + tableName + " VALUES ("); for (int i = 1; i <= numColumns; i++) { String value = rs.getString(i); insertSql.append("'" + value + "',"); } insertSql.setLength(insertSql.length() - 1); insertSql.append(")"); mysqlStatement.execute(insertSql.toString()); } } // Close connections mysqlStatement.close(); mysqlConnection.close(); oracleStatement.close(); oracleConnection.close(); } catch (SQLException e) { e.printStackTrace(); } } } ``` 需要注意的是,该代码仅供参考,实际应用需要考虑更多的细节和异常情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值