mysql之UPDATE,SELECT,INSERT语法
一 :UPDATE语法
UPDATE
是一个修改表中行的DML语句。
#单表语法(常用)
UPDATE [LOW_PRIORITY] [IGNORE] table_reference
SET assignment_list
[WHERE where_condition]
[ORDER BY ...] #例如 ORDER BY id DESC; 若ID不重复且自增,故需要先增加的最大的id后增较小id避免因为重复id保存(不常用)
[LIMIT row_count]
#多表语法
UPDATE [LOW_PRIORITY] [IGNORE] table_references #若为多表需要‘,’分割 例如 table_reference , table_reference2
SET assignment_list [WHERE where_condition]
value: ()
{expr | DEFAULT} #值可以是表达式或默认值 例如 col1 = col1 + 1,(这就是表达式) assignment:
col_name = value # col_name 列名 assignment_list:
assignment [, assignment] ...
二:SELECT语法(常用语法,与官方有点差别,主要是删除了一些可选参数)
SELECT
用于检索从一个或多个表中选择的行
SELECT
select_expr [, select_expr ...]
[FROM table_references] #可以是多表
[WHERE where_condition] #条件表达式
[GROUP BY {col_name | expr | position} #分组
[ASC | DESC], ... [WITH ROLLUP]]
[HAVING where_condition] #包含
[ORDER BY {col_name | expr | position} #排序
[ASC | DESC], ...]
[LIMIT {[offset,] row_count | row_count OFFSET offset}] #分页
注意:除select_expr其他都是可选参数
语法解析:
1.select_expr 选择表达式 (多个表达式需要用‘,’分割)
例如: table.列名 (映射)
例如: CONCAT(last_name,', ',first_name) AS full_name (聚合函数和别名 连接多列的字段),和直接调用其他集合函数
例如:(CASE WHEN t3.`CATEGORY` = 2 THEN `T`.`ADDRES` ELSE NULL END) AS `ADDRES` (选择表达式,可选着显示内容 例 当''t3.CATEGORY = 2 " 为真时显示THEN后值 为false时显示ELSE的值)
2.where_condition 条件表达式
例如 :id = 2 (当id等于2时为真时显示该数据)
例如 :NOT EXISTS ( select id form classes where id = 5) (即一个子查询并判断查询的结果是否显示数据) 注意子查询可用父查询的表数据作为条件
3. GROUP BY 分组 根据列进行分组(列的类型可以是字符串。。。。)
例如 :对单列分组》group by id (默认是ASC升序,)指定分组方式 group by id ASC
例如: 对多列进行分组 GROUP BY c.id ASC ,t.`tid` DESC; (并按不同方式)
4. HAVING 包含
5. ORDER BY 排序可参考group by 都有按不同方式排序
6. LIMIT 分页
三:INSERT语法
语法1 (常用插入方式 构造器插入)
INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE]
[INTO] tbl_name #表明必选
[(col_name [, col_name] ...)]
{VALUES | VALUE} (value_list) [, (value_list)] ... #必选
[ON DUPLICATE KEY UPDATE assignment_list] #此次忽略 语法2 ()
INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE]
[INTO] tbl_name
[(col_name [, col_name] ...)]
SELECT ...
[ON DUPLICATE KEY UPDATE assignment_list]
语法3 (set插入)
INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE]
[INTO] tbl_name
[PARTITION (partition_name [, partition_name] ...)]
SET assignment_list
[ON DUPLICATE KEY UPDATE assignment_list]
value:
{expr | DEFAULT}
#解析 expr 可用算数运算符 如 score=score+1
value_list:
value [, value] ...
assignment:
col_name = value
assignment_list:
assignment [, assignment] ...
解析语法:
语法1 除table(表名)和value(值) 为必选其他都是可选
例如 : INSERT INTO tbl_name () VALUES(); 即插入一条数据(所有值都为默认值)
例如 : INSERT INTO tbl_name (col1,col2) VALUES(15,col1*2); #运用了算数运算符 (注意:col2(第二列)引用的第一列的值 ,因为第一列先插入了值所以第二列可以引用,若反过来VALUES(col2*2,15) 则不合法)
语法2 :可把select 语句查询出来的值 理解为语法1中的value (可用于快熟复制一天记录)
例如 : INSERT INTO classes(id) SELECT NULL FROM classes c WHERE c.id=4; # 插入一条空数据 ,因为id 不能为空所以需值定该值
语法3:通过关键字set 已key=value 的形式插入到表中
例如: insert into test set a='abc';
可选参数
1:[ IGNORE ] : 顾名思义 ignore是忽略的意识,结合官方文档和自己的理解如下
如果用insert 插入数据,并且用‘ignore’关键字修饰了insert,则当插入数据发生错误时mysql服务器会忽略该错误并转换为warning信息,并继续执行下条插入信息。
例如 : 执行插入 INSERT IGNORE INTO teacher(tid,class_id,NAME) VALUES(14,1,'teacher12'),(15,1,'teacher11'); (teacher表信息 tid 为主键 且tid=14已经存在,tid=15不存在)
执行结果:
分析:当执行插入tid=14时发生了错误,服务器忽略了该错误并转化为警告信息,并继续执行了tid=15的数据
可利用该特性:插入或忽略,即当该条数据(id)已经存在发出警告,否则就执行插入
2:[ ON DUPLICATE KEY UPDATE assignment_list ] : 当key发生DUPLICATE (重复错误)时执行 update语句 》插入或更新
例如:INSERT INTO teacher(tid,class_id,NAME) VALUE(14,1,'teacher12') ON DUPLICATE KEY UPDATE class_id=1,NAME='teacher1233333';
即当tid=14已经存在就执行更新语句,否则就执行insert语句;
mysql之UPDATE,SELECT,INSERT语法的更多相关文章
- MySQL触发器 Update触发Insert失败
今天工作需要,想要实现将仅对状态更新的表进行历史记录显示,于是考虑在原表中建立触发器,将更新的内容同时写入另一张表 于是进行测试 --建立测试表CREATE TABLE `triggletest_tr ...
- mysql中update+select
mysql中不支持嵌套查询后更新操作. 但是可以使用inner join来解决自身的更新问题,参考如下例子: update hera_job a inner join( ),'"') as ...
- Update、Insert注入技巧
title: Update.Insert注入技巧 date: 2017-10-23 18:07:57 tags: ["注入"] 审计了不少代码,再看代码的时候最多出现的就是注入,很 ...
- SQL基础语法的单表操作 select|insert|update|delete(增删改查) 简单使用
以下案列以此表举例 1.select(查询) select简单的查询分为两种 注:字段也就是表结构中的列的名称 第一种: select 字段名 from 表名 此种查询只列出你所需要查询的字段, ...
- SQL基础语法select|insert|update|delete(增删改查) 简单使用
以下案列以此表举例 1.select(查询) select简单的查询分为两种 注:字段也就是表结构中的列的名称 第一种: select 字段名 from 表名 此种查询只列出你所需要查询的字段, ...
- C++使用Mysql的详细步骤及各个常用方法的代码演示:select,insert,update,delete
这几天一直在学习C++下使用Mysql的方法及其中各种的问题,也看了很多Mysql的API函数,当然自己看的还是很基础的.其实对于每种数据库的操作,基本的方法都是非常类似的,大多都是connect,s ...
- insert、update select from
1.insert select from <一棵树-博客园> 收集整理,转载请注明出处! 使用SELECT INTO 和 INSERT INTO SELECT 表复制语句了. 1.INSE ...
- 数据操纵:SELECT, INSERT, UPDATE, DELETE
SELECT 句法 SELECT [STRAIGHT_JOIN] [SQL_SMALL_RESULT] [SQL_BIG_RESULT] [SQL_BUFFER_RESULT] [SQL_CACHE ...
- mysql插入数据时 insert IGNORE、ON DUPLICATE KEY UPDATE、replace into
转: mysql insert时几个操作DELAYED .IGNORE.ON DUPLICATE KEY UPDATE的区别 博客分类: mysql基础应用 mysql insert时几个操作DE ...
随机推荐
- CentOS6.8 使man支持显示中文
1.安装显示中文的man命令 wget https://src.fedoraproject.org/repo/pkgs/man-pages-zh-CN/manpages-zh-1.5.1.tar.gz ...
- 【python原理解析】gc原理初步解析
python的gc是会用到:引用计数.标记-清除和分代收集,首先说明一下什么是引用计数 可以通过sys模块中的getrefcount()方法获取某个对象的引用计数 python本身的数据类型有基础类型 ...
- flex布局实现elment容器布局
一.flex布局是什么 flex布局,意为"弹性布局",是一种响应式的布局方法 采用 Flex 布局的元素,称为 Flex 容器,它的所有子元素自动成为容器成员. 先放上一个ele ...
- cnetos 下 rar 解压
第一步:http://www.rarlab.com/rar/rarlinux-x64-5.3.0.tar.gz 下载 文件 或 wget http://www.rarlab.com/rar/rarli ...
- yum提示Another app is currently holding the yum lock
使用yum grouplis列举系统中以组安装的包,结果提示: # yum grouplist Loaded plugins: fastestmirror, refresh-packagekit, s ...
- mysql开启调试日志general_log开启跟踪日志
general_log = 1 general_log_file = /tmp/umail_mysql.log 有时候,不清楚程序执行了什么sql语句,但是又要排除错误,找不到原因的情况下, 可以在m ...
- JavaScript 函数定义和调用
普通的函数定义方法: function abs(x):{ if (x >= 0){ return x; }else { return -x ; } } 两种方法是等价的 var abs = fu ...
- poj1860
刚上来一堆英文着实有点蒙逼,仔细分析是一个Bellman的变形,只要能找出一个无限增大的环这个题就好解决了,我这里用的SPFA,用邻接链表进行储存,直接套用的模板,部分变量名字没有改的很好 #incl ...
- 数据库-mysql语句-查
复习: 列类型: 数值类型: 20 '20' tinyint / smallint / int / bigint float / double / decimal(m,d) bool (TRU ...
- 手动上传图片到nginx下可访问,程序上传后访问图片报403
1. 首先查看文件权限 2. 初步确定是服务器权限问题 2.1 解决方案一:更改文件权限 2.2 解决方案二:修改nginx运行用户 1. 首先查看文件权限 #指令如下 ls -l 2. 初步确定是服 ...