【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),是 ...
随机推荐
- Spring @ModelAttribute
正文开始之前,先介绍个东西,Spring能够自动将请求参数封装到对应JavaBean上! 代码比较简单,也没有什么配置要记录,只是开启了<mvc:annotation-driven/>,可 ...
- 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 ...
- eclipse设置成保护眼的背景色
长时间的使用eclipse开发会很累吧 设置一个保护眼睛的豆沙绿色 不刺眼 是不是会更好一些呢 那么如何设置呢现在就教大家 工具/原料 eclipse jdk 方法/步骤 首先打开eclipse ...
- Java - TreeMap源码解析 + 红黑树
Java提高篇(二七)-----TreeMap TreeMap的实现是红黑树算法的实现,所以要了解TreeMap就必须对红黑树有一定的了解,其实这篇博文的名字叫做:根据红黑树的算法来分析TreeMap ...
- 一个很好用的SqlHelper类
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- HDU1054(KB10-H 最小顶点覆盖)
Strategic Game Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- [USACO18FEB]Slingshot
题意可化为: 在二维平面中有n个点,坐标为\((x_i,y_i)\),点权为\(t_i\). 现有m个询问,每次给定点\((x,y)\),求\(\min\{|x-x_i|+|y-y_i|+t_i,|y ...
- 关于flex布局兼容
(做个记录) 一.W3C各个版本的flex 2009 version 标志:display: box; or a property that is box-{*} (eg. box-pack) 201 ...
- Ckeditor失去焦点前保留光标位置
var $selection = CKEDITOR.instances.myEditor.getSelection();//当前选中区域 var $bookmarks = $selection.cre ...
- Oracle查询时15分钟划分
select to_date(to_char(sysdate, 'yyyy-MM-dd hh24') || ':' || floor(to_number(to_char(s ...