现象 MySQL在删除一张表时出现 ERROR 1217 (23000): Cannot delete or update a parent row: a foreign key constraint...fails 原因 可能是在Mysql中,删除的表和另一张表设置了foreign key的关联,造成无法更新或删除数据; 解决方案 可以通过设置FOREIGN_KEY_CHECKS变量来避免这种情况。...禁用外键约束 SET FOREIGN_KEY_CHECKS = 0; 然后就可以删除表了 删除完成后再启动外键约束 SET FOREIGN_KEY_CHECKS = 1; 查看当前FOREIGN_KEY_CHECKS...的值可用如下命令 SELECT @@FOREIGN_KEY_CHECKS; 注意 这样设置只会影响当前会话, 不会影响全局 若想设置全局变量的话,可以这样写 SET GLOBAL FOREIGN_KEY_CHECKS
我用的MySQL数据库,使用MySQL Workbench管理。下面简单介绍一下如何使用MySQL Workbench建立数据库,建立新的表,为表添加数据。...一下刚刚建立好的数据库mydatabase,然后再创建表,不然会出错,右键点击Tables 然后点击Create new tables ,填写表名,以及表列的信息,之后点击 apply ,一张表就建完了...PK: primary key (column is part of a pk) 主键 NN: not null (column is nullable) 是否为空 -UQ: unique (...column is part of a unique key) 外键 AI: auto increment (the column is auto incremented when rows are...Numeric Types”) 出现如下页面 接下来向建好的tb_student表中添加数据 右键点击tb_student,再点击select rows limit 1000 在mysql workbench
MySQL 临时表在我们需要保存一些临时数据时是非常有用的。临时表只在当前连接可见,当关闭连接时,Mysql会自动删除表并释放所有空间。...临时表在MySQL 3.23版本中添加,如果你的MySQL版本低于 3.23版本就无法使用MySQL的临时表。不过现在一般很少有再使用这么低版本的MySQL数据库服务了。...MySQL临时表只在当前连接可见,如果你使用PHP脚本来创建MySQL临时表,那每当PHP脚本执行完成后,该临时表也会自动销毁。...如果你使用了其他MySQL客户端程序连接MySQL数据库服务器来创建临时表,那么只有在关闭客户端程序时才会销毁临时表,当然你也可以手动销毁。...如果你退出当前MySQL会话,再使用 SELECT命令来读取原先创建的临时表数据,那你会发现数据库中没有该表的存在,因为在你退出时该临时表已经被销毁了。
mysql数据库基本语法 DDL操作 创建数据库 语法:create database 数据库名; 查看所有数据库 语法:show databases; 切换(使用)数据库 语法:use + 数据库名...; 查看表的结构 语法:desc 表名; 添加字段 语法:alter table 表名 add 字段名 字段类型 删除字段 语法:alter table 表名 drop 字段名 修改表名 语法:...rename table 旧的表名 to 新的表名 修改字段类型 语法:alter table 表名 modify 字段名 新的字段类型 字段重命名 语法:alter table 表名 change...,相当于先drop这张表在create这张表 约束 主键约束特点:唯一性,非空性 设置主键和自动增长 主键:在创建表时,在要设置为主键的字段后面 添加上主键(primary key) 自增长:在创建表时...auto_increment 非空约束:不能为空 在约束位置加上 not null 外键约束: 要基于主表的主键去创建 在字段定义后 添加外键 Constraint (外键名称) foreign key
新增数据表和字段是很常见的,在如果表已经存在或者字段存在时就会报错, 在升级程序时往往是一大堆的sql语句,而单一的sql语句是没法在新增时判断表或字段是否存在的,必须写成存储过程 下面是一个存储过程的例子
insert buffer背景知识 insert buffer是一种特殊的数据结构(B+ tree),当辅助索引页面不在缓冲池中时,它会将更改缓存起来,稍后在页面被其他读取操作加载到缓冲池中时合并。...如果检测到大于0,意味着还有依赖的I/O未完成,睡眠20ms后重试; 此时认为已经没有冲突的操作了,刷出所有脏页面或删除所有给定的表空间的页面; 从表空间缓存删除指定space的记录; 删除对应数据文件...不出意外的话,在打中断点时必然有线程在执行对应表的删除操作。...具体代码参考MariaDB commit:8edbb1117a9e1fd81fbd08b8f1d06c72efe38f44 影响版本 察看相关信息,这个问题是修改Bug#19710564时删除表空间版本引入的...,space id占4个字节,低于0xFFFFFFF0UL,分配时读取系统表空间保存的值,然后加一,具有唯一性)。
PARTITION pm11_ix VALUES LESS THAN (12) PARTITION pm12_ix VALUES LESS THAN (MAXVALUE)); 分区表和一般表一样可以建立索引...,分区表可以创建局部索引和全局索引。...当分区中出现许多事务并且要保证所有分区中的数据记录的唯一性时采用全局索引。...全局索引建立时global 子句允许指定索引的范围值,这个范围值为索引字段的范围值: SQL> create index dinya_idx_t on dinya_test(item_id) 2 ...SQL> 本例中对表的item_id字段建立索引分区,当然也可以不指定索引分区名直接对整个表建立索引,如: SQL> create index dinya_idx_t on dinya_test
阅读量: 153 该问题是插入数据表中遇到键重复 1.IGNORE INSERT IGNORE INTO Table_name(…..)...2.REPLACE REPLACE INTO Table_name() VALUES(1,1),(2,2),(3,3) 使用replace当插入的记录遇到主键或者唯一重复时先删除表中重复的记录行再插入...*ON DUPLICATE KEY UPDATE *NAME1=VALUES(ID)+1 INSERT TO Table_name() VALUES(1,1),(1,2) ON DUPLICATE KEY...UPDATE NAME1=NAME1+1; ON DUPLICATE KEY UPDATE后面使用VALUES指的是插入记录的值,而不使用VALUES指的是表的自身值。
-- 新建表时判断表是否存在 CREATE TABLE If Not Exists `表名` ( `id` int(10) NOT NULL AUTO_INCREMENT , `plan_id` ...int(10) NULL , `bet_num` varchar(255) NULL , `vr_win_data` varchar(255) NULL COMMENT , PRIMARY KEY... (`id`) ); -- 新建字段时判断字段是否存在 CREATE PROCEDURE sp_update_888() BEGIN IF NOT EXISTS (SELECT * FROM information_schema.columns... WHERE table_schema = DATABASE() AND table_name = '表名' AND column_name = '字段名') THEN ALTER TABLE..._888; -- 新建索引时判断索引是否存在 CREATE PROCEDURE sp_update_888() BEGIN IF NOT EXISTS (SELECT * FROM information_schema.statistics
有时候我们会在一个工作簿中建立很多工作表,怎样才能简单明了的管理工作表呢,当然能建一个目录最好了,这里我们就学习一种给工作表创建目录的方法。 1、在工作簿中新建一个工作表,命名为“目录”。...A1",MID(目录,FIND("]",目录)+1,99)),"") 现在可以看到效果了,单击目录中的工作表名称,就会自动跳转到相应工作表。...注意:GET.WORKBOOK函数是宏表函数,可以提取当前工作簿中的所有工作表名,需要先定义名称后使用。...当单击函数 HYPERLINK 所在的单元格时,Excel将打开链接的文件或跳转到指定的工作表的单元格,本例中是跳转到目录&"!A1"。 IFERROR函数用于屏蔽错误。...注意:工作表保存时需要选择保存类型为“Excel 启用宏的工作簿(*.xlsm)”,同时需要在Excel选项中将宏安全性设置为中,否则会不能正常使用了。
线上数据库难免会有修改表结构的需求,MySQL 在修改表结构时会锁表,这就会影响读写操作,小表还好,一会儿就修改完成了,但大表会比较麻烦,下面看一个解决方案 解决思路 (1)新建一个表,结构就是要修改后的结构...(2)在旧表上建立触发器,旧表更新数据时同步到新表 (3)把旧表数据复制到新表 (4)数据同步完成后,执行重命名操作,交换新旧表 (5)删除旧表及触发器 实现方式 这个解决思路已经有了很成熟的工具,数据库服务公司...Percona 提供了 MySQL Toolkit 工具集,其中的 pt-online-schema-change 就是用来进行线上的表结构修改,不会阻塞读写 使用示例 pt-online-schema-change...test modify name varchar(60); 这个参数的值就是 “alter table test ”后面的部分 D=sakila,t=test 指定数据库和表名 --execute...percona-toolkit/ centos7 安装示例 下载 rpm 版本 安装依赖包 yum install epel-release-7-5.noarch yum install perl-DBD-MySQL
我建立了两张表,一张员工表,一张部门表,员工表中有部门id 这个属性,将这两张表关联起来。...EXISTS 子查询其实在执行时,MySql 已经对它做了一些优化并不是对每条数据进行对比。 二、总结 在实际操作过程中我们要对两张表的dept_id 都设置索引。...在一开始我们就讲了一个优化原则即:小表驱动大表,在我们使用IN 进行关联查询时,通过上面IN 操作的执行顺序,我们是先查询部门表再根据部门表查出来的id 信息查询员工信息。...但是我们使用EXISTS 查询时,首先查询员工表,然后根据部门表的查询条件返回的TRUE 或者 FALSE ,再决定员工表中的信息是否需要保留。...当t_emp 表中数据多于 t_dept 表中的数据时,这时我们使用IN 优于 EXISTS。
0.目录 1.前言 2.建立数据库 2.1 通过SSMS建立数据库 2.2 通过SQL语句建立数据库 3.建立表 3.1 通过SSMS建立表 3.2 通过SQL语句建立表 1.前言 配置是...3.建立表 3.1 通过SSMS建立表 3.1.1打开刚刚建立的SSMSTest数据库,找到表(数据库->SSMSTest->表)。 右键单击表,选择新建表。...3.1.6在 数据库->SSMSTest->表 那里刷新一下,就会发现刚刚建立的三张表了。...(选择 数据库->SSMSTest->表->dbo.student 右键单击选择设计,就可以查看刚刚建立的表的具体信息了。)...(选择 数据库->SQLTest->表->dbo.student 右键单击选择设计,就可以查看刚刚建立的表的具体信息了。)
Oracle建立表空间和用户 建立表空间和用户的步骤: 用户 建立:create user username identified by "password"; 授权...username; grant create tablespace to username; grant create view to username; 表空间...建立表空间(一般建N个存数据的表空间和一个索引空间): create tablespace 表空间名 datafile ' 路径(要先建好路径)\***.dbf ' size *M tempfile...size *M autoextend on --自己主动增长 --另一些定义大小的命令,看须要 default storage( initial 100K, next 100k, ); 样例:创建表空间...unlimited on 表空间; 或 alter user username quota *M on 表空间; 完整样例: --表空间 CREATE TABLESPACE sdt DATAFILE
执行truncate table xxx时提示: [Err] 1701 -Cannot truncate a table referenced in a foreign key constraint …...解决办法 删除之前先执行 删除外键约束 SET foreign_key_checks = 0; 删除完之后再执行 启动外键约束 SET foreign_key_checks = 1; 查询 谢谢 @unxeer...的补充 用来检查状态 SELECT @@FOREIGN_KEY_CHECKS; 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/148864.html原文链接
1.建立数据库,建立一个“学生”表student。 2.设计思想:首先利用create database语句建立一个数据库,再用create table语句按要求建立基本表,再按照规则添加数据。...3.实验代码及注释: 创建数据库 mysql> create database ymz; Query OK, 1 row affected (0.03 sec) 使用数据库 mysql> use...ymz; Database changed 创建学生基本表 mysql> create table student( -> Sno CHAR(9) PRIMARY KEY, -> Sname...Ssex CHAR(2), -> Sage SMALLINT, -> Sdept CHAR(20)); Query OK, 0 rows affected (0.08 sec) 插入数据 mysql...insert into student -> values(‘201215121’,‘李勇’,‘男’,20,‘CS’); Query OK, 1 row affected (0.02 sec) mysql
DUPLICATE KEY UPDATE batch执行时出死锁错误 背景知识 一、 mysql insert 与 duplicate key: 典型的插入语句: 多条:INSERT INTO tablename...(1, 10), (2, 15) ON DUPLICATE KEY UPDATE data=data+VALUE(data) 二、innodb表提高插入效率 查询表使用的引擎: show create...insert 语句马上执行,其实数据都被放在内存的队列中,并没有真正写入磁盘;这比每条语句分别插入要快的多;LOW_PRIORITY 刚好相反,在所有其他用户对表的读写完后才进行插入; 在项目中遇到的问题时,...使用了这种insert处理,但是分库分表,数据表类型为innodb, tablename各不相同,duplicate key只是用于合并update和insert语句。 ...貌似mysql有这个bug(http://bugs.mysql.com/bug.php?
Navicat for MySQL导入数据时报错 1:导入的是Excel2007表格格式的数据。 2: 报错以后数据加进去了。(选择了错误继续执行) 3:这个错误对我的数据有影响吗?...自己多尝试,多看Mysql文档。 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
错误提示是长度太长了:Specified key was too long; max key length is 767 bytes 来查看下创建表的语句: CREATE TABLE `xxl_job_registry...如果系统变量innodb_large_prefix开启了,就会对使用dynamic或者是comperssed行格式的InnoD表,索引键长度限制为3072个字节了。...如果没有开启这个,InnoDB会对,无论什么表索引键长度限制都是767了。 解决方案有两种: 1:mysql系统变量innodb_large_prefix开启。...Mysql优化的时候: 在做 sql 优化时,对之前的表添加个索引,却给出了 Specified key 'idx_t' was too long; max key length is 767 bytes... 提示,后来通过查询资料,发现: 由于 MySQL Innodb 引擎表索引字段长度的限制为 767 字节,因此对于多字节字符集的大字段(或者多字段组合索引),创建索引会出现上面的错误。
出现相同的字段报错:SQLSTATE[23000]: Integrity constraint violation: 1052 Column 'company_...
领取专属 10元无门槛券
手把手带您无忧上云