- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经尝试了几个小时来添加具有引用完整性的查询,但它指示错误,但如果我删除它们,查询运行良好。我只把它们放在lotes和operaciones table 上。
CREATE DATABASE alamilla;
USE alamilla;
CREATE TABLE cat_niveles(
id INT(11) AUTO_INCREMENT,
nombre VARCHAR(255),
PRIMARY KEY (id)
)ENGINE=INNODB;
INSERT INTO cat_niveles VALUES(NULL, 'ADMINISTRADOR');
INSERT INTO cat_niveles VALUES(NULL, 'VENTA');
INSERT INTO cat_niveles VALUES(NULL, 'ALTA');
CREATE TABLE categorias_medicamentos(
id INT(11) AUTO_INCREMENT,
nombre VARCHAR(255),
PRIMARY KEY(id)
)ENGINE=INNODB;
CREATE TABLE corte_cajas(
id INT(11) AUTO_INCREMENT,
fecha_corte DATETIME,
PRIMARY KEY(id)
)ENGINE=INNODB;
CREATE TABLE proveedores(
id INT(11) AUTO_INCREMENT,
nombre VARCHAR(255) NOT NULL,
apellidos VARCHAR(255) NOT NULL,
compania VARCHAR(100) NOT NULL,
direccion VARCHAR(100) NULL,
telefono1 VARCHAR(100) NULL,
telefono2 VARCHAR(100) NULL,
fecha_alta DATETIME DEFAULT CURRENT_TIMESTAMP,
PRIMARY KEY(id)
)ENGINE=INNODB;
CREATE TABLE medicamentos(
cve_medicamento VARCHAR(255) NOT NULL,
nombre_generico VARCHAR(255) NOT NULL,
nombre_comercial VARCHAR(255) NULL,
descripcion VARCHAR(255) NULL,
imagen VARCHAR(255) NULL,
presentacion VARCHAR(255) NULL,
precio_adquisitivo DECIMAL(15,2) NOT NULL,
precio_venta DECIMAL(15,2) NOT NULL,
unidades_caja INT(11) NOT NULL,
stock_minimo INT(11) NOT NULL,
fecha_alta DATETIME DEFAULT CURRENT_TIMESTAMP,
id_proveedor INT(11) NULL,
id_categoria INT(11) NULL,
PRIMARY KEY(cve_medicamento),
FOREIGN KEY(id_proveedor) REFERENCES proveedores(id)
)ENGINE=INNODB;
CREATE TABLE tipo_operaciones(
id INT(11) AUTO_INCREMENT,
nombre VARCHAR(255) NOT NULL,
PRIMARY KEY(id)
)ENGINE=INNODB;
CREATE TABLE lotes(
cve_lote VARCHAR(255) NOT NULL,
fecha_alta DATETIME DEFAULT CURRENT_TIMESTAMP,
fecha_caducidad DATE,
cve_medicamento VARCHAR(255) NOT NULL,
PRIMARY KEY(cve_lote),
FOREIGN KEY(cve_medicamento) REFERENCES medicamentos(cve_medicamento) ON DELETE SET NULL ON UPDATE CASCADE
)ENGINE=INNODB;
CREATE TABLE pedidos(
id INT(11) AUTO_INCREMENT,
dinero DECIMAL(15, 2) NULL,
total DECIMAL(15,2) NULL,
descuento DECIMAL(15, 2) NULL,
fecha DATETIME NULL,
id_tipo_operacion INT(11) NULL,
id_proveedor INT(11) NULL,
id_corte_caja INT(11) NULL,
id_usuario INT(11) NULL,
PRIMARY KEY(id),
FOREIGN KEY(id_tipo_operacion) REFERENCES tipo_operaciones(id),
FOREIGN KEY(id_proveedor) REFERENCES proveedores(id),
FOREIGN KEY(id_corte_caja) REFERENCES corte_cajas(id)
)ENGINE=INNODB;
CREATE TABLE operaciones(
id INT(11) AUTO_INCREMENT,
cantidad INT(11) NULL,
descuento DECIMAL(15,2) NULL,
precio DECIMAL(15,2) NULL,
id_tipo_operacion INT(11) NULL,
id_medicamento VARCHAR(255) NULL,
id_pedido INT(11) NULL,
cve_lote VARCHAR(255) NULL,
PRIMARY KEY(id),
FOREIGN KEY(id_tipo_operacion) REFERENCES tipo_operaciones(id),
FOREIGN KEY(id_medicamento) REFERENCES medicamentos(cve_medicamento) ON DELETE SET NULL ON UPDATE CASCADE,
FOREIGN KEY(id_pedido) REFERENCES pedidos(id),
FOREIGN KEY(cve_lote) REFERENCES lotes(cve_lote) ON DELETE SET NULL ON UPDATE CASCADE
)ENGINE=INNODB;
CREATE TABLE usuarios(
id INT(11) AUTO_INCREMENT,
nick VARCHAR(100) NOT NULL,
pass VARCHAR(255) NOT NULL,
nombre VARCHAR(100) NOT NULL,
apellidos VARCHAR(100) NOT NULL,
bloque TINYINT(2) NOT NULL,
foto VARCHAR(255),
id_nivel INT(11) NOT NULL,
PRIMARY KEY(id),
FOREIGN KEY(id_nivel) REFERENCES cat_niveles(id)
)ENGINE=INNODB;
INSERT INTO usuarios VALUES(NULL, 'admin','d033e22ae348aeb5660fc2140aec35850c4da997','ALBERTO','ALAMILLA MURILLO', 1, 'foto_perfil/ADMINISTRADOR.png', 1);
INSERT INTO `categorias_medicamentos` (`id`, `nombre`) VALUES
(null, 'BAÑOS'),
(null, 'COLUTORIOS'),
(null, 'COMPRIMIDOS'),
(null, 'ELIXIRES'),
(null, 'GOTAS'),
(null, 'GOTAS NASALES'),
(null, 'INHALADORES'),
(null, 'JARABE'),
(null, 'LOCIONES'),
(null, 'MEDICAMENTO DE PRUEBA'),
(null, 'NEBULIZACIONES'),
(null, 'PARCHES TRANDERMICOS'),
(null, 'POLVOS'),
(null, 'POMADAS RECTALES'),
(null, 'SELLOS'),
(null, 'SUPOSITORIOS'),
(null, 'SUSPENSION'),
(null, 'TABLETAS');
我总是收到错误#1215 无法添加外键约束一只手不是一个坏主意,谢谢。 PS:我已经头疼了,因为没找到问题
最佳答案
lotes
表的 CREATE
语句中存在矛盾。
CREATE TABLE lotes(
cve_lote VARCHAR(255) NOT NULL,
fecha_alta DATETIME DEFAULT CURRENT_TIMESTAMP,
fecha_caducidad DATE,
cve_medicamento VARCHAR(255) NOT NULL,
PRIMARY KEY(cve_lote),
FOREIGN KEY(cve_medicamento) REFERENCES medicamentos(cve_medicamento) ON DELETE SET NULL ON UPDATE CASCADE
) ENGINE=INNODB;
问题出在这里:
cve_medicamento VARCHAR(255) NOT NULL
这里:
FOREIGN KEY(cve_medicamento) ... ON DELETE SET NULL
在第一行中,您已明确声明 cve_medicamento
不应该为 NULL
。在第二行中,您明确指出当删除外键引用时,cve_medicamento
应设置为 NULL
。
通过消除 NOT NULL
并将该行更改为
lotes
表的查询
cve_medicamento VARCHAR(255)
从 MySQL documentation... 中了解更多信息.
If you specify a
SET NULL
action, make sure that you have not declared the columns in the child table asNOT NULL
.
关于mysql - 错误 #1215 - 无法在 DELETE SET NULL 上添加外键约束,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53490571/
我创建了一个用户可以添加测试的字段。这一切运行顺利我只希望当用户点击(添加另一个测试)然后上一个(添加另一个测试)删除并且这个显示在新字段中。 所有运行良好的唯一问题是点击(添加另一个字段)之前添加另
String[] option = {"Adlawan", "Angeles", "Arreza", "Benenoso", "Bermas", "Brebant
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我正在努力将 jQuery 滚动功能添加到 nav-tab (Bootstrap 3)。我希望用户能够选择他们想要的选项卡,并在选项卡内容中有一个可以平滑滚动到 anchor 的链接。这是我的代码,可
我正在尝试在用户登录后再添加 2 个 ui 选项卡。首先,我尝试做一个之后。 $('#slideshow').tabs('remove', '4'); $("#slideshow ul li:last
我有一个包含选择元素的表单,我想通过选择添加和删除其中一些元素。这是html代码(这里也有jsfiddle http://jsfiddle.net/txhajy2w/):
正在写这个: view.backgroundColor = UIColor.white.withAlphaComponent(0.9) 等同于: view.backgroundColor = UICo
好的,如果其中有任何信息,我想将这些列添加到一起。所以说我有 账户 1 2 3 . 有 4 个帐户空间,但只有 3 个帐户。我如何创建 java 脚本来添加它。 最佳答案 Live Example H
我想知道是否有一种有效的预制算法来确定一组数字的和/差是否可以等于不同的数字。示例: 5、8、10、2,使用 + 或 - 等于 9。5 - 8 = -3 + 10 = 7 + 2 = 9 如果有一个预
我似乎有一个卡住的 git repo。它卡在所有基本的添加、提交命令上,git push 返回所有内容为最新的。 从其他帖子我已经完成了 git gc 和 git fsck/ 我认为基本的调试步骤是
我的 Oracle SQL 查询如下- Q1- select hca.account_number, hca.attribute3, SUM(rcl.extended_amou
我正在阅读 http://developer.apple.com/iphone/library/documentation/iPhone/Conceptual/iPhoneOSProgrammingG
我正在尝试添加一个“加载更多”按钮并限制下面的结果,这样投资组合页面中就不会同时加载 1000 个内容,如下所示:http://typesetdesign.com/portfolio/ 我对 PHP
我遇到这个问题,我添加了 8 个文本框,它工作正常,但是当我添加更多文本框(如 16 个文本框)时,它不会添加最后一个文本框。有人遇到过这个问题吗?提前致谢。 Live Link: JAVASCRIP
add/remove clone first row default not delete 添加/删除克隆第一行默认不删除&并获取正确的SrNo(例如:添加3行并在看到问题后删除SrNo.2)
我编码this ,但删除按钮不起作用。我在控制台中没有任何错误.. var counter = 0; var dataList = document.getElementById('materi
我有一个类似数组的对象: [1:数组[10]、2:数组[2]、3:数组[2]、4:数组[2]、5:数组[3]、6:数组[1]] 我正在尝试删除前两个元素,执行一些操作,然后将它们再次插入到同一位置。
使用的 Delphi 版本:2007 你好, 我有一个 Tecord 数组 TInfo = Record Name : String; Price : Integer; end; var Info
我使用了基本的 gridster 代码,然后我声明了通过按钮添加和删除小部件的函数它工作正常但是当我将调整大小功能添加到上面的代码中时,它都不起作用(我的意思是调整大小,添加和删除小部件) 我的js代
title 323 323 323 title 323 323 323 title 323 323 323 JS $(document).keydown(function(e){
我是一名优秀的程序员,十分优秀!