【MYSQL】语法复习
一、数据类型



截图来源: http://www.runoob.com/mysql/mysql-data-types.html
二、基本语句
1、创建数据表
-- 主键自增,T_User
CREATE TABLE IF NOT EXISTS `T_User`(
`Id` INT UNSIGNED AUTO_INCREMENT,
`Name` VARCHAR(100) NOT NULL,
`CardNo` VARCHAR(40) NOT NULL,
`Birthday` DATE,
PRIMARY KEY ( `Id` )
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
2、删除数据表
DROP TABLE T_School;
3、表字段修改
-- 新增字段
ALTER TABLE T_User ADD ClassName VARCHAR(100) NOT NULL; -- 删除字段
ALTER TABLE T_User DROP CardNo; -- 修改字段数据属性
ALTER TABLE T_User MODIFY Name BIGINT NOT NULL DEFAULT 100; -- 修改字段名称
ALTER TABLE T_User CHANGE Name RealName VARCHAR(100);
4、新增表数据
INSERT INTO T_User (Name, CardNo, BirthDay) VALUES('大王', '0001', NOW());
5、删除数据
-- 条件删除
DELETE FROM T_User WHERE Id=3; -- 重置表格,自增主键重新计算
TRUNCATE TABLE T_User;
6、更新数据
UPDATE T_User SET Name='女王', CardNo='NX_01' WHERE Id=4;
7、查询数据
-- 条件查询
SELECT * FROM T_User WHERE Id>2 AND Name IS NOT NULL; -- 分组
SELECT Name FROM T_User GROUP BY Name; -- 排序,默认ASC,顺序
SELECT * FROM T_User ORDER BY Id DESC; /*
INNER JOIN(内连接,或等值连接:获取两个表中字段匹配关系的记录。
LEFT JOIN(左连接:获取左表所有记录,即使右表没有对应匹配的记录。
RIGHT JOIN(右连接:与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。
*/
SELECT TU.* FROM T_User TU
INNRT JOIN T_School TS ON TS.Id = TU.SchoolId
WHERE TS.`LEVEL` = 1; /*
UNION ALL: 返回所有结果集,包含重复数据
UNION DISTINCT: 删除结果集中重复的数据,默认去重
*/
SELECT Id, Name FROM T_User WHERE ClassName='三年二班'
UNION ALL
SELECT Id, Name FROM T_User WHERE ClassName='三年五班' -- 统计行数
SELECT COUNT(1) FROM T_User;
三、其他函数
1、判断
SELECT
IF(SEX = 1, '男', '女') SEX
FROM T_USER;
2、逗号拼接
SELECT
GROUP_CONCAT(Name)
FROM T_User
LIMIT 10;
3、判空
SELECT
IFNULL(CardNo, '') CardNo
FROM T_User
WHERE Id>10;
4、转换数据类型
//类型转换
SELECT CAST(Id AS CHAR) FROM T_User;
//拼接个空字符串,隐式转换
SELECT CONCAT(Id,'') FROM T_User;
5、分页及统计行数
//方法一
SELECT
TAB.*,
@i Total
FROM
(SELECT
(@i := @i + 1) AS RowNum,
B.*
FROM
book B,
(SELECT @i := 0) AS it
) TAB
WHERE TAB.RowNum BETWEEN 5 AND 10
//方法二:
SET @i=0;
SELECT
TAB.*,
@i Total
FROM
(SELECT
(@i := @i + 1) AS RowNum,
B.*
FROM
book B
) TAB
WHERE TAB.RowNum BETWEEN 5 AND 10;
SET @i:=NULL;
6、时间格式转换
//yyyy-MM-dd HH:mm:ss
date_format(Birthday, '%Y-%m-%d %H:%i:%s')
7、分组拼接
SELECT
GROUP_CONCAT( CONCAT( CreateBy, ':', Remark ) )
FROM
book
GROUP BY
`Name`
【MYSQL】语法复习的更多相关文章
- mysql - 语法复习与学习
//本月的第一天,最后一天 $start=date('Y-m-01', strtotime(date("Y-m-d"))); echo date('Y-m-d', strtotim ...
- MYSQL 语法大全自己总结的
mysql语法大全 --------数据链接---------------------数据库服务启动net start mysql --关闭服务net stop mysql --登录 -u,-p后面不 ...
- 学习mysql语法--基础篇(一)
前 言 mysql mysql语法--本篇学习都是通过使用Navicat Premium(数据库管理工具),连接mysql数据. 本篇学习主要有两个部分: 一.创建用户,创建数据库,给 ...
- 学习mysql语法--基础篇(二)
前 言 mysql mysql语法--本篇学习都是通过使用Navicat Premium(数据库管理工具),连接mysql数据. 本篇学习主要有两个部分: [SQL语句的组成] DML ...
- mysql语法之case when then与列转行
mysql语法中case when then与列转行的使用场景非常丰富. case语句类似java中条件分支语句的作用,可以类比java中的switch语句或者if语句来学习. 其语法如下: case ...
- mongo 与 传统mysql语法对比
MongoDB语法 MySql语法 db.test.find({'name':'foobar'})<==> select ...
- Mongodb与mysql语法比较
Mongodb与mysql语法比较 mongodb与mysql命令对比 传统的关系数据库一般由数据库(database).表(table).记录(record)三个层次概念组成,MongoDB是由 ...
- mongodb linux基本启动 基础增删改 mysql语法的对比
一.主流数据源类型 还存在自定义数据源以及REST接口数据,共6中数据源. 二.linux下启动连接数据库 进去mongodb的目录启动服务:mongo --host 192.168.320.826 ...
- mysql语法、特殊符号及正则表达式的使用
http://blog.csdn.net/pipisorry/article/details/46773545 sql语言 结构化的查询语言.(Structured Query Language),是 ...
随机推荐
- [error] 1507#0: *22 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream, client: 10.0.0.1, server: www.wordpress.com, request: "GET /info.p
字体比较小,如果你遇到这个问题请仔细的把下面的总结看完. 环境:CentOS6.7.2.6.32-573.el6.x86_64.nginx1.12.2 .php5.5.38 问题:nginx能解析静态 ...
- CentOS qt5 /usr/lib/libstdc++.so.6: version `GLIBCXX_3.4.15' not found
1.下载QT5 SDK 下载地址:http://qt-project.org/downloads. 2.安装QT5 下载完后,假设放在Download/,切换到该目录,输入:./qt-linux-op ...
- Java @Repeatable
查看@PropertySource注解时候,发现了@Repeatable,从来没见过的注解,学习了下: 首先介绍下@Repeatable注解: JDK1.8出现的,作用是解决一个类上不能标注重复的注解 ...
- Python中的单例模式的几种实现方式的及优化
单例模式 单例模式(Singleton Pattern)是一种常用的软件设计模式,该模式的主要目的是确保某一个类只有一个实例存在.当你希望在整个系统中,某个类只能出现一个实例时,单例对象就能派上用场. ...
- 我的菜单在母版页,如何更改菜单点击后的效果 Ver2
很久之前,Insus.NET使用ASP.NET实现一个功能,非javascript.<我的菜单在母版页,如何更改菜单点击后的效果>http://www.cnblogs.com/insus/ ...
- new~mac os 给终端命令写alias(及其他常用命令)及软连接
配置执行顺序 优先级 配置 说明 1 /etc/profile 系统级别 —— 不推荐修改 2 /etc/paths 系统级别 —— 不推荐修改 3 ~/.profile 用户设置 4 ~/.bash ...
- Redis 缓存设计原则
基本原则 只应将热数据放到缓存中 所有缓存信息都应设置过期时间 缓存过期时间应当分散以避免集中过期 缓存key应具备可读性 应避免不同业务出现同名缓存key 可对key进行适当的缩写以节省内存空间 选 ...
- Hexo的搭建
Hexo的安装与初始化 1.确保电脑已经安装Node.js,Git 打开GUI Bash,输入以下代码安装Hexo: npm install -g hexo-cli 2.运行以下命令在目标文件夹初始化 ...
- Java面试题—初级(6)
71,谈谈你对Struts的理解. 1. struts是一个按MVC模式设计的Web层框架,其实它就是一个Servlet,这个Servlet名为ActionServlet,或是ActionServle ...
- redis主从|哨兵|集群模式
关于redis主从.哨兵.集群的介绍网上很多,这里就不赘述了. 一.主从 通过持久化功能,Redis保证了即使在服务器重启的情况下也不会损失(或少量损失)数据,因为持久化会把内存中数据保存到硬盘上,重 ...