mysql之SQL入门与提升(二)
在mysql之SQL入门与提升(一)我们已经有了些许基础,今天继续深化
先造表
SET NAMES utf8;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for `access_log`
-- ----------------------------
DROP TABLE IF EXISTS `access_log`;
CREATE TABLE `access_log` (
`aid` int(11) NOT NULL AUTO_INCREMENT,
`site_id` int(11) NOT NULL DEFAULT '0' COMMENT '网站id',
`count` int(11) NOT NULL DEFAULT '0' COMMENT '访问次数',
`date` date NOT NULL,
PRIMARY KEY (`aid`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;
-- ----------------------------
-- Records of `access_log`
-- ----------------------------
BEGIN;
INSERT INTO `access_log` VALUES ('1', '1', '45', '2016-05-10'), ('2', '3', '100', '2016-05-13'), ('3', '1', '230', '2016-05-14'), ('4', '2', '10', '2016-05-14'), ('5', '5', '205', '2016-05-14'), ('6', '4', '13', '2016-05-15'), ('7', '3', '220', '2016-05-15'), ('8', '5', '545', '2016-05-16'), ('9', '3', '201', '2016-05-17');
COMMIT;
SET FOREIGN_KEY_CHECKS = 1;
一.SQL进阶篇
1.1SQL 别名
列的 SQL 别名语法
SELECT column_name AS alias_name FROM table_name;
表的 SQL 别名语法
实例
实例
FROM Websites
INNER JOIN access_log
ON Websites.id=access_log.site_id
ORDER BY access_log.count;
在使用 join 时,on 和 where 条件的区别如下:
- 1、 on 条件是在生成临时表时使用的条件,它不管 on 中的条件是否为真,都会返回左边表中的记录。
- 2、where 条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有 left join 的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉。
1.2.2 left join 右表没匹配左边字段也会显示,只不过为null(一句话,左边的为主,右边的为辅)
实例
以下实例中我们把 Websites 作为左表,access_log 作为右表:
FROM Websites
LEFT JOIN access_log
ON Websites.id=access_log.site_id
ORDER BY access_log.count DESC;
实例
FROM Websites
FULL OUTER JOIN access_log
ON Websites.id=access_log.site_id
ORDER BY access_log.count DESC;
实例
UNION 只显示不同的字段
UNION
SELECT country FROM apps
ORDER BY country;
UNION ALL
SELECT country FROM apps
ORDER BY country;
1.2.6 复制表结构及插入数据
复制表结构
CREATE TABLE websitesbackup2019 LIKE websites ;
复制旧表的数据到新表(假设两个表结构一样)
INSERT INTO websitesbackup2019 SELECT * FROM websites;
INSERT INTO websitesbackup2019(id,name) SELECT id,name FROM websites
最新文章
- java static静态方法的并发性
- DevExpress--xtraTabbedMdiManager控件
- vios 虚拟光驱 安装vioc
- C++编程优化心得(持续更新)
- iOS开发 UIWebView+JavaScript 交互总结
- 在View页面,使用@if(){ }输出判断正确的内容
- Delphi2010的RTTI增强
- MYSQL中取当前年份的第一天和当前周,月,季度的第一天/最后一天
- SQL Server日志文件庞大收缩方法(实测好用)
- ant脚本
- drawRect &; 内存 ->; 深究
- Apache Shiro 核心概念
- 在 Mac 中安装 MySQLdb (Python mysql )
- 关于如何在电脑上安装adb来操作手机(Android)的方法及步骤
- ModelState 错误信息输出
- tensorflow相关API的学习
- JDBC和hibernate,mybatis的比较
- 子窗口访问父页面iframe中的iframe,top打开的子窗口访问父页面中的iframe中的iframe
- Oracle触发器简单使用记录
- Qt窗口及控件-QTreeview/QTableView排序问题
热门文章
- Java企业微信开发_01_接收消息服务器配置
- tomcat报错:Wrapper cannot find servlet class ...
- jQuery插件:图片放大镜--jQuery Zoom
- freeMarker(十一)——模板语言之指令
- HihoCoder1663双阶乘的末尾数字([Offer收割]编程练习赛40)(暴力||数学)
- ACM学习历程——ZOJ 3822 Domination (2014牡丹江区域赛 D题)(概率,数学递推)
- 分立元件封装尺寸及PCB板材工艺与设计实例
- Operating System-Kickoff:什么是操作系统&;&;操作系统的核心概念
- bzoj 2597 剪刀石头布 —— 拆边费用流
- DataGrid 支持字符截断显示