MySQL 8.0 语法记录
SQL又杂又烦,记不住,网上搜到的语句还未必正确。这里做一个Record
基本操作
数据库操作
数据表操作
create index [索引名] on [表名]([列名]); /* 以选定列为索引信息,建立普通索引 */
create view [视图名] as [select子句]; /* 建立视图 */
-- 语法上有点类似于使用临时派生表, select出的东西当作一个视图
数据行操作
insert into [表名] values ([对应数据]) /* 插入数据(对应数据需按顺序全部填写) */
insert into [表名]([列名]) values ([对应数据]) /* 插入数据(部分列数据) */
update [表名] set [待修改列名]=[修改值] where [条件,where子句选择行] /* 更新行中某数据 */
delete from [表名] where [条件,where子句选择行] /* 删除行数据 */
数据列操作
desc [表名]; /* 查看列 */
alter table [表名] add [列名+完整描述] [具体位置]; /* 插入列 */
alter table [表名] drop [列名]; /* 删除列 */
alter table [表名] modify [列名+完整描述] [具体位置]; /* 移动列的位置 */
-- e.g.
-- alter table user_account modify Permission tinyint not null unsigned after CodeName;
alter table [表名] modify [列名] [新描述]; /* 修改列属性 */
alter table [表名] change [列名] [新列名] [新描述]; /* 修改列名字+属性 */
-- 列中数据不会被重置(不管是改名字、属性还是约束)
alter table [表名] add unique([列名]); /* 给已有表某列添加约束 */
/* 解释 */
[具体位置] : after [列名] | first
[列名+完整描述] : 完整描述包括:类型、约束等,例如 Permission tinyint not null unsigned
在操作(如 add drop)后也可再多写一个 column
进阶操作
一些非直接的选择操作
1.获取表c_table中a字段最大的两个数字: 可以排序后限制输出,使用order by和limit
select a from `c_table` order by a desc limit 2;
2.使用临时派生表(记得,必须提供别名,Every derived table must have its own alias)
3.update操作的条件又对目标表进行了select,则需要将该select外包一层才行
设置变量
触发器
delimiter $$
create trigger [触发器名] /* 命名规则trig_[表名]_[属性名]_[触发含义]_[触发行为],如trig_teacher_age_lowest_i */
[before/after] [insert/update/delete] on [表名]
[for each row] /* 行级:sql影响的每一行都会执行; 语句级:单条sql一次 */
begin
statement
end $$
delimiter ;
常用搭配语句:异常报错
signal sqlstate [异常编解码,字符串] set message_text=[异常信息,字符串]
存储过程
MySQL 8.0 语法记录的更多相关文章
- MySQL 8.0 新增SQL语法对窗口函数和CTE的支持
尝试了一下MySQL 8.0的部分新特性. 如果用过MSSQL或者是Oracle中的窗口函数(Oracle中叫分析函数), 然后再使用MySQL 8.0之前的时候,就知道需要在使用窗口函数处理逻辑的痛 ...
- MySQL的sql_mode参数之NO_AUTO_VALUE_ON_ZERO对主键ID为0的记录影响
最近遇到一个不合理使用数据库进行项目开发最终导致项目进度受阻的一个问题,某天几位开发人员找到我并告知数据库中某张表数据无法写入,又告知某行记录被删除了,因为被删除的记录对开发框架影响很大,他们已尝试重 ...
- mysql 8.0.18 手工安装记录
mysql 8.0.18 手工安装记录 为了日常方便,特记录如下. 一.安装系统依赖包 #.系统依赖包安装 yum -y install make gcc-c++ cmake bison-devel ...
- MySQL 8.0.13安装修改密码的一个问题,记录一下。
https://blog.csdn.net/qq_37350706/article/details/81707862 关于安装MySQL 8.0.13,本人就不多说了,上面这个链接讲的非常详细 请参考 ...
- PHP定时备份MySQL,mysqldump语法大全
几个常用操作: 1.备份 # 只导出表结构 d:/PHP/xampp/mysql/bin/mysqldump -h127.0.0.1 -P3306 -uroot -p123456 snsgou_sns ...
- mysql防止重复插入记录方法总结
mysql防止重复插入记录方法总结 防止mysql重复插入记录的方法有很多种,常用的是ignore,Replace,ON DUPLICATE KEY UPDATE,当然我们也可以在php中加以判断了. ...
- MySQL的一些语法总结
初学MySQL,今天遇到了一个问题,然后汇总了一下MySQL的一些语法 1. date和datetime类型是不同的 date只记录日期(包括年月日),datetime记录日期和时间(包括年月日时分秒 ...
- sql点滴41—mysql常见sql语法
原文:sql点滴41-mysql常见sql语法 ALTER TABLE:添加,修改,删除表的列,约束等表的定义. 查看列:desc 表名; 修改表名:alter table t_book rename ...
- MySQL create table 语法
MySQL中create table语句的基本语法是: CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name [(create_definitio ...
- What's New In MySQL 8.0
由于8.0内有很多C++11特性.需要gcc4.8版本以上.Rhel6系列默认gcc是4.7.在安装gcc6.1之后仍然检查不过. 原因可能是6.1版本不一定高于4.7,暂不讨论.鉴于升级gc ...
随机推荐
- 第1章04节 | 常见开源OLAP技术架构对比
https://zhuanlan.zhihu.com/p/266402829 1. 什么是OLAP OLAP(On-line Analytical Processing,联机分析处理)是在基于数据仓库 ...
- Alpine中安装telnet
lpine Linux是一个基于musl libc和busybox的安全轻量的Linux发行版. 在Alpine中安装telnet,并不是apk add telnettelnet被移入子包busybo ...
- Qt编写安防视频监控系统28-摄像机点位
一.前言 摄像机点位的功能主要是在图片地图和在线离线地图上设置对应摄像机的位置,然后双击可以实时预览对应摄像机的视频,在图片地图上拖动摄像机图标到对应位置,系统会自动保存位置信息,在网页地图上的摄像机 ...
- Spring Data JPA中使用Example进行动态查询
Spring Data JPA中使用Example进行动态查询主要涉及:实体对象.ExampleMatcher和Example等三种类类型.基于实例的动态查询所包含的三要素如下:1.实体对象:在ORM ...
- 基于开源IM即时通讯框架MobileIMSDK:RainbowChat v8.2版已发布
关于MobileIMSDK MobileIMSDK 是一套专门为移动端开发的开源IM即时通讯框架,超轻量级.高度提炼,一套API优雅支持UDP .TCP .WebSocket 三种协议,支持iOS.A ...
- 【狂神说Java】Java零基础学习笔记-Java方法
[狂神说Java]Java零基础学习笔记-Java方法 Java方法01:何谓方法? System.out.println(),那么它是什么呢? Java方法是语句的集合,它们在一起执行一个功能. 方 ...
- blast只保留一个最优结果
使用blast比对时,只保留一个最优结果 代码: blastn -db nt.blast.db -query seq.fa -out blast.nt.result -evalue 1e-5 -out ...
- js脚本实现文本文件格式批量转换
问题: 在Windows环境下,从某些软件中导出的文本格式的数据,选择了默认的ANSI格式.双击打开数据文件后,一切正常,没乱码问题.但是为什么自己的代码里,先按照ANSI格式打开,在转换为UTF8, ...
- 用SignalR和Layui搭建自己的web聊天网站
1.开发背景 之前是做项目一直有一个困扰,就是如何进行及时通讯,本人.Net开发,不太想用别人的接口,然后偶然的机会知道了SignalR,那么什么是SignalR呢? 2.SignalR简介 ASP. ...
- MySQL查看、修改字符集及Collation
前言在使用MySQL的过程中,可能会出现初始设计使用的字符集或Collation不符合当前需求的情况.如使用utf8的表(MySQL中的utf8即utf8mb3)要支持emoji,而utf8mb3不支 ...