一、数据类型

截图来源: 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】语法复习的更多相关文章

  1. mysql - 语法复习与学习

    //本月的第一天,最后一天 $start=date('Y-m-01', strtotime(date("Y-m-d"))); echo date('Y-m-d', strtotim ...

  2. MYSQL 语法大全自己总结的

    mysql语法大全 --------数据链接---------------------数据库服务启动net start mysql --关闭服务net stop mysql --登录 -u,-p后面不 ...

  3. 学习mysql语法--基础篇(一)

      前  言  mysql  mysql语法--本篇学习都是通过使用Navicat Premium(数据库管理工具),连接mysql数据. 本篇学习主要有两个部分:    一.创建用户,创建数据库,给 ...

  4. 学习mysql语法--基础篇(二)

      前  言  mysql  mysql语法--本篇学习都是通过使用Navicat Premium(数据库管理工具),连接mysql数据. 本篇学习主要有两个部分: [SQL语句的组成]   DML ...

  5. mysql语法之case when then与列转行

    mysql语法中case when then与列转行的使用场景非常丰富. case语句类似java中条件分支语句的作用,可以类比java中的switch语句或者if语句来学习. 其语法如下: case ...

  6. mongo 与 传统mysql语法对比

    MongoDB语法                                  MySql语法 db.test.find({'name':'foobar'})<==> select ...

  7. Mongodb与mysql语法比较

    Mongodb与mysql语法比较   mongodb与mysql命令对比 传统的关系数据库一般由数据库(database).表(table).记录(record)三个层次概念组成,MongoDB是由 ...

  8. mongodb linux基本启动 基础增删改 mysql语法的对比

    一.主流数据源类型 还存在自定义数据源以及REST接口数据,共6中数据源. 二.linux下启动连接数据库 进去mongodb的目录启动服务:mongo --host 192.168.320.826 ...

  9. mysql语法、特殊符号及正则表达式的使用

    http://blog.csdn.net/pipisorry/article/details/46773545 sql语言 结构化的查询语言.(Structured Query Language),是 ...

随机推荐

  1. Spring @ModelAttribute

    正文开始之前,先介绍个东西,Spring能够自动将请求参数封装到对应JavaBean上! 代码比较简单,也没有什么配置要记录,只是开启了<mvc:annotation-driven/>,可 ...

  2. Book Contents Reviews Notes Errata Articles Talks Downloads Resources Code Formatter Cover of C# in Depth Order now (3rd edition) Implementing the Singleton Pattern in C#

    原文链接地址: http://csharpindepth.com/Articles/General/Singleton.aspx#unsafe Implementing the Singleton P ...

  3. eclipse设置成保护眼的背景色

    长时间的使用eclipse开发会很累吧  设置一个保护眼睛的豆沙绿色 不刺眼 是不是会更好一些呢 那么如何设置呢现在就教大家   工具/原料 eclipse jdk 方法/步骤 首先打开eclipse ...

  4. Java - TreeMap源码解析 + 红黑树

    Java提高篇(二七)-----TreeMap TreeMap的实现是红黑树算法的实现,所以要了解TreeMap就必须对红黑树有一定的了解,其实这篇博文的名字叫做:根据红黑树的算法来分析TreeMap ...

  5. 一个很好用的SqlHelper类

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  6. HDU1054(KB10-H 最小顶点覆盖)

    Strategic Game Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  7. [USACO18FEB]Slingshot

    题意可化为: 在二维平面中有n个点,坐标为\((x_i,y_i)\),点权为\(t_i\). 现有m个询问,每次给定点\((x,y)\),求\(\min\{|x-x_i|+|y-y_i|+t_i,|y ...

  8. 关于flex布局兼容

    (做个记录) 一.W3C各个版本的flex 2009 version 标志:display: box; or a property that is box-{*} (eg. box-pack) 201 ...

  9. Ckeditor失去焦点前保留光标位置

    var $selection = CKEDITOR.instances.myEditor.getSelection();//当前选中区域 var $bookmarks = $selection.cre ...

  10. Oracle查询时15分钟划分

    select to_date(to_char(sysdate, 'yyyy-MM-dd hh24') || ':' ||               floor(to_number(to_char(s ...