首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【MySQL】表的增删查改(CRUD)(上)

    大写表示关键字; []表示可写可不写; 这里我们先学会一下查看表中的数据: 查看数据: select* from 表名 示例:查看courses表中的数据 我还未在select表中添加数据,所以显示为空...全列查询 在之前我们其实已经学会了全列查询也就是: select * from 表名; select和from表示关键词; * 表示要查询表中的所有列; 如果在生产环境中,查询表是一个很危险的操作...selsect 字段1,字段2,表达式 from 表名; 写法一:表达式中不包含字段 示例: 写法二:表达式中包含一个字段 示例: null与任何数运算都为null 写法三:表达式包含多个字段...示例: 注意: 指定列的顺序与表的顺序无关; 除表达式外,如果查找该表中不存在的字段名,那么就会报错; 为查询结果指定别名 语法: SELECT column [AS] alias_name...from 表名; 先查看一下表中的数据 示例: 接下来对chinese、math、english中的元素进行去重 如果我们要同时加上id,name并且对chinese、math、english中的元素进行去重

    9210

    MySQL删除表的三种方式

    ,不删除表的结构,速度排第二,但不能与where一起使用 例如删除 user 表: truncate table user; delete from delete 是删除表中的数据,不删除表结构,速度最慢...,但可以与where连用,可以删除指定的行 例如删除user表的所有数据 delete from user; 删除user表的指定记录 delete from user where user_id =...1; 三种方式的区别 相同点 truncate和不带where子句的delete,drop都会删除表内的数据; drop,truncate都是DDL语句(数据定义语言),执行后会自动提交;...:truncate和delete 只删除数据不删除表结构,truncate 删除后将重建索引(新插入数据后id从0开始记起),而 delete不会删除索引 (新插入的数据将在删除数据的索引后继续增加),...drop语句将删除表的结构包括依赖的约束,触发器,索引等; 安全性:drop和truncate删除时不记录MySQL日志,不能回滚,delete删除会记录MySQL日志,可以回滚; 返回值:

    1.3K10

    MySQL删除表的三种方式

    ,不删除表的结构,速度排第二,但不能与where一起使用 例如删除 user 表: truncate table user; delete from delete 是删除表中的数据,不删除表结构,速度最慢...,但可以与where连用,可以删除指定的行 例如删除user表的所有数据 delete from user; 删除user表的指定记录 delete from user where user_id =...1; 三种方式的区别 相同点 truncate和不带where子句的delete,drop都会删除表内的数据; drop,truncate都是DDL语句(数据定义语言),执行后会自动提交; 不同点 语句类型...delete 只删除数据不删除表结构,truncate 删除后将重建索引(新插入数据后id从0开始记起),而 delete不会删除索引 (新插入的数据将在删除数据的索引后继续增加),drop语句将删除表的结构包括依赖的约束...,触发器,索引等; 安全性:drop和truncate删除时不记录MySQL日志,不能回滚,delete删除会记录MySQL日志,可以回滚; 返回值:delete 操作后返回删除的记录数,而 truncate

    4.3K20

    恢复MySQL slave上的某几张表的方法

    恢复slave上的某几张表的方法 摘录自《MySQL管理之道》Page126 有时候,slave上只是几张表有些问题,如果从master上dump一份进行恢复的话,对于体积很大的数据库,则要花费很长的时间...,长时间的持锁还容易影响到业务。...下面介绍一种方法,恢复test_DB下的3张表tb1、tb2、tb3,操作如下: 1、在slave上先停止复制 > stop slave; 2、在主库上导出3张需要恢复的表,并记录下同步的binlog...mnysql-bin.000010',master_LOG_POS=10020;” 4、做change master to操作: > start slave until master_LOG_FILE='mysql-bin...=1; start slave; 5、把/root/tb123.sql复制到slave机器上,并在slave机器上导入/root/tb123.sql # mysql -uroot -proot test_DB

    1K20

    MySQL中使用undrop来恢复drop的表(上)

    MySQL中可以使用编程语言(比如Python)来解析binlog中DML的逆操作来达到闪回的效果,如果数据不多,手工解析也可以。这也是现在大家碰到的很多DML Flashback的一个基本原理。...mysql_config --cflags` `$basedir/bin/mysql_config --libs` -o sys_parser sys_parser.c 这个工具的一个基本原理就是解析ibdata...SYS_COLUMNS | SYS_FIELDS | SYS_INDEXES | SYS_TABLES 这个工具功能蛮丰富,在目录下有个sakila的文件夹,是一些示例的脚本,我们可以创建一些看起来和业务相关的表...,不过实际上我们可以做个减法,只创建一个我们需要重点关注的表,然后导入数据即可。...整个初始化的工作,我们以表actor为例,手工摘取出actor的建表语句,然后运行sakila-data.sql脚本即可。

    2.2K50

    技术分享 | 详解 MySQL 三表 JOIN

    常听说 MySQL 中三表 JOIN 的执行流程并不是前两张表 JOIN 得出结果,再与第三张表进行 JOIN;而是三表嵌套的循环连接。 那这个三表嵌套的循环连接具体又是个什么流程呢?...这结论与我们通常认为的三表 JOIN 实际上是三表嵌套的循环连接不一样,接着往下看。...图示(这里展示的是索引嵌套循环算法时三表 JOIN 的流程,块循环嵌套算法不一样): 注意:由于造的数据比较特殊,所以第 3 步得出的中间结果集实际上只有 1 行,所以最终 t2 表的查找次数是 20...其实拆解来看,“三表嵌套循环” 和 “前两表 JOIN 的结果和第三张表 JOIN” 两种算法,成本是一样的,而且如果要按三表嵌套循环的方式展示每张表的成本将非常复杂,可读性不强。...4总结 总的来说,对于三表 JOIN 或者多表 JOIN 来说,“三表嵌套循环” 和 “先两表 JOIN,结果和第三张表 JOIN” 两种算法,成本是一样的。

    1.1K10

    ABAP 取两个内表的交集 比较两个内表的不同

    SAP自带的函数: CTVB_COMPARE_TABLES和BKK_COMPARE_TABLES; 似乎可以比较两个内表,得出第二个内表不同于第一个内表的部分...因为,我在测试数据时,发现这两个函数的效果不那么简单。 如果上述函数确实可以,提取两个内表不同部分,则我可以据此做两次比较,得到两个内表的交集。...所以,我先用另外一种方式解决了-自己写了一个提取两个内表交集的函数,供大家检阅: *" IMPORTING *" VALUE(ITAB1) TYPE INDEX TABLE...,做为内表行是否为增加的判断条件。...输出参数: TABLE_DEL:被删除的行 TABLE_ADD:被增加的行 TABLE_MOD:被修改的行 NO_CHANGES:表没有被修改的标记,如果这个标记为 “X”,就不必去读前面三个内表了

    3.1K30

    SQL学习笔记三之MySQL表操作

    一 存储引擎介绍 存储引擎即表类型,mysql根据不同的表类型会有不同的处理机制 https://www.cnblogs.com/JetpropelledSnake/p/9094125.html 二...表介绍 表相当于文件,表中的一条记录就相当于文件的一行内容,不同的是,表中的一条记录有对应的标题,称为表的字段 ?...id,name,qq,age称为字段,其余的,一行内容称为一条记录 三 创建表 #语法: create table 表名( 字段名1 类型[(宽度) 约束条件], 字段名2 类型[(宽度) 约束条件],...3 | NULL | NULL | NULL | | 4 | NULL | NULL | NULL | +------+------+------+--------+ 注意注意注意:表中的最后一个字段不要加逗号...对已经存在的表增加复合主键 mysql> alter table service2 -> add primary key(host_ip,port); 7.

    37730

    MySQL 锁机制(上) -- 全局锁与表级锁

    2. mysql 中锁的分类 mysql 中的锁可以按照多个维度进行分类。 2.1....Shared Locks) 意向排它锁(IX 锁 — Intention Exclusive Locks) 也就是说,无论是我们通常称的行锁还是表锁,最终实际上无外乎都是加的上面这几种锁,从而实现不同的功能...按照锁定范围分 按照锁定范围,mysql 的锁可以分为: 全局锁 — 锁定整个 mysql 的全局执行 表级锁 — 锁定单个表 行级锁 — 锁定单条或多条行记录 行级锁又可以进一步细分为: 记录锁 —...表级锁 MySQL 中有两种表级锁: 表锁 元数据锁 — MDL(meta data lock) 5.1....后记 本文介绍了 MySQL 的全局锁、表级锁以及各种锁的基本实现,但事实上,在 innodb 引擎中,我们最为常用的锁是行级锁。 行级锁也是所有的锁中相对最为复杂的,敬请期待我们下一篇文章的讲解。

    2.1K10

    【MySql】表的约束

    一个主键可以被添加到一列,或者多列上 主键;主键所在的列通常是整数类型 创建表的时候直接在字段上指定主键 mysql> create table if not exists test_key (...而唯一键更多的是保证在业务上,不要和别的信息出现重复。...而我们设计员工工号的时候,需要一种约束:而所有的员工工号都不能重复。 具体指的是在公司的业务上不能重复,我们设计表的时候,需要这个约束,那么就可以将员工工号设计成为唯一键。...外键foreign key 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。...因为此时两张表在业务上是有相关性的,但是在业务上没有建立约束关系,那么就可能出现问题。 解决方案就是通过外键完成的。

    21530

    MySQL表的操作

    collate 校验规则,如果没有指定校验规则,则以所在数据库的校验规则为准 2、创建表的案例 create table users ( id int, name varchar(20) comment...MyISAM; 3、查看表结构 desc 表名 示例: 4、修改表 在项目实际开发中,经常修改某个表的结构,比如字段名字,字段大小,字段类型,表的字符集类型,表的存储引擎等等。...案例: 4.1.在users表中添加两条记录 mysql> insert into users values(1,'a','b','1982-01-04'),(2,'b','c','1984-01- 04...'); 4.2.在users表添加一个字段,用于保存图片路径 mysql> alter table users add assets varchar(100) comment '图片路径' after...(100) | YES | | NULL | | +----------+--------------+------+-----+---------+-------+ 插入新字段后,对原来表中的数据没有影响

    5710

    MySQL表与表之间的关系

    表与表之间的关系 表1 foreign key 表2 则表1的多条记录对应表2的一条记录,即多对一 利用foreign key的原理我们可以制作两张表的多对多,一对一关系 多对多: 表1的多条记录可以对应表...2的一条记录 表2的多条记录也可以对应表1的一条记录 一对一: 表1的一条记录唯一对应表2的一条记录,反之亦然 分析时,我们先从按照上面的基本原理去套,然后再翻译成真实的意义,就很好理解了...1、先确定关系 2、找到多的一方,把关联字段写在多的一方 一对多  多对一或者一对多(左边表的多条记录对应右边表的唯一一条记录)  需要注意的: 1.先建被关联的表,保证被关联表的字段必须唯一。...图片 创建表 书要关联出版社 被关联的表 create table press(id int primary key auto_increment, name char(20)); 关联的表 create...用户组,主机表 创建三张表 -- 用户表 create table user (id int primary key auto_increment,username varchar(20) not null

    3.6K10

    【MYSQL】表的约束

    关键字:default 默认值 案例: create table test2( No int default 0, name varchar(5) default '张三' ); 创建好表之后如果我们插入数据时...三、列描述 没有实际含义,专门用来描述字段(相当于注释),会根据表创建语句保存,用来给程序员或DBA来进行了解。...而唯一键更多的是保证在业务上,不要和别的信息出现重复。...而我们设计员工工号的时候,需要一种约束:而所有的员工工号都不能重复。 具体指的是在公司的业务上不能重复,我们设计表的时候,需要这个约束,那么就可以将员工工号设计成为唯一键。...int auto_increment primary key, name varchar(5) unique ); 八、外键 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或

    25340

    MySQL:表的约束

    反过来,站在MySQL角度,凡是插入进来的数据,都是符合数据约束的! 约束的最终目标:保证数据的完整性和可预期性。 二....而如果为我们没有在创建表的时候显示声明默认值,MySQL会优化,自动加上默认值为NULL。 四....比如一个班一百多号同学,编号时,有一位数,有两位、三位数。我们就可以设置zerofill让其等宽。...关于唯一键和主键的区别: 我们可以简单理解成,主键更多的是标识唯一性的。而唯一键更多的是保证在业务上,不要和别的信息出现重复。 九....外键 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null。

    6710

    【MySQL】表的约束

    三、列描述 列描述:comment,没有实际含义,专门用来描述字段,会根据表创建语句保存,用来给程序员或 DBA 来进行了解。...而唯一键更多的是保证在业务上,不要和别的信息出现重复。...而我们设计员工工号的时候,需要一种约束:而所有的员工工号都不能重复。具体指的是在公司的业务上不能重复,我们设计表的时候,需要这个约束,那么就可以将员工工号设计成为唯一键。...id 会报错,因为 id 字段具有唯一键: 但是可以插入空: 八、外键 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或 unique 约束。...建立外键的本质其实就是把相关性交给 mysql 去审核了,提前告诉 mysql 表之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql 不允许你插入。

    15510
    领券