黑马SSM项目使用mysql建表


写在前面

  • 此篇文章是用于黑马旅游网后台管理系统的相关数据库表,由mysql建立。
  • 注意:下面sql语句中创建触发器的语句中 "//"不是注释,是必须的!!要不然会语法出错。
  • 在项目运行过程中,遇到了一个问题,当我对数据库进行插入数据时,会抛出异常,显示“id列不应为空”,详情如下:
    1. 原先错误的代码:
      CREATE TABLE `product` (
        `id` VARCHAR(36) NOT NULL,
        `productNum` VARCHAR(50) NOT NULL,
        `productName` VARCHAR(50) DEFAULT NULL,
        `cityName` VARCHAR(50) DEFAULT NULL,
        `DepartureTime` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
        `productPrice` DOUBLE DEFAULT NULL,
        `productDesc` VARCHAR(500) DEFAULT NULL,
        `productStatus` INT(11) DEFAULT NULL,
        PRIMARY KEY (`id`),
        UNIQUE KEY `product` (`id`,`productNum`)
      ) ENGINE=INNODB DEFAULT CHARSET=utf8;
      
      /*删除触发器*/
      DROP TRIGGER IF EXISTS `product_before_insert`;
      
      DELIMITER //
      CREATE TRIGGER `product_before_insert` 
      BEFORE INSERT ON `product` FOR EACH ROW 
      BEGIN 
      IF new.id IS NULL THEN 
      SET new.id = UUID();
      END IF;
      END;
      //
      
      
    2. 究其原因: 我们可以从上面看到,在设置主键id时我们设置成非空,而当设置触发器时,我们的判断条件是如果主键为空,则将主键设置为uuid。那么问题来了,我在插入数据的时候语句如下:
      INSERT INTO PRODUCT (productnum, productname, cityname, departuretime, 	productprice, productdesc, productstatus) 
      VALUES ('itcast-002', '北京三日游', '北京', NOW(), 1200, '不错的旅行', 1); 
      
      插入的语句中,id值为空,数据库立马会报错,那你会说,那我给id设置一个不就好了,可是!!!使用uuid就是为了让系统生成一个唯一的机器识别码,你自己写一个那我直接用auto_increment来自增不就好了吗。
    3. 解决办法: 这里有两种,第一种方法,将其他列替换主键列作为触发器判断的标准,成功执行了,下面的代码用的就是这种方法;第二种方法,在建表时把主键列设置一个默认值,然后用触发器对其进行判断,如果不为空则使用uuid进行插入,也能成功解决,当然,此处还可进行进一步优化,既然设置了主键的默认值,那么判断条件可以精确到完全匹配默认值,这样避免把非空作为判断的话可能的意外bug。

壹 | product表

SELECT * FROM product

DROP TABLE IF EXISTS `product`;

CREATE TABLE `product` (
  `id` VARCHAR(36) NOT NULL,
  `productNum` VARCHAR(50) NOT NULL,
  `productName` VARCHAR(50) DEFAULT NULL,
  `cityName` VARCHAR(50) DEFAULT NULL,
  `DepartureTime` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  `productPrice` DOUBLE DEFAULT NULL,
  `productDesc` VARCHAR(500) DEFAULT NULL,
  `productStatus` INT(11) DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `product` (`id`,`productNum`)
) ENGINE=INNODB DEFAULT CHARSET=utf8;

/*删除触发器*/
DROP TRIGGER IF EXISTS `product_before_insert`;

DELIMITER //
CREATE TRIGGER `product_before_insert` 
BEFORE INSERT ON `product` FOR EACH ROW 
BEGIN 
IF new.productDesc IS NOT NULL THEN 
SET new.id = UUID();
END IF;
END;
//

INSERT INTO PRODUCT (productnum, productname, cityname, departuretime, productprice, productdesc, productstatus) 
VALUES ('itcast-002', '北京三日游', '北京', NOW(), 1200, '不错的旅行', 1); 

INSERT INTO PRODUCT (productnum, productname, cityname, departuretime, productprice, productdesc, productstatus) 
VALUES ('itcast-003', '上海五日游', '上海', NOW(), 1800, '魔都我来了', 0); 

INSERT INTO PRODUCT (productnum, productname, cityname, departuretime, productprice, productdesc, productstatus) 
VALUES ('itcast-001', '北京三日游', '北京', NOW(), 1200, '不错的旅行', 1);

贰 | traveller表

SELECT * FROM `traveller`;
	
CREATE TABLE traveller( 
	id VARCHAR(32) PRIMARY KEY, 
	NAME VARCHAR(20), 
	sex VARCHAR(20), 
	phoneNum VARCHAR(20), 
	credentialsType INT, 
	credentialsNum VARCHAR(50), 
	travellerType INT 
	)
	
/*删除触发器*/
DROP TRIGGER IF EXISTS `traveller_before_insert`;

DELIMITER //
CREATE TRIGGER `traveller_before_insert` 
BEFORE INSERT ON `traveller` FOR EACH ROW 
BEGIN 
IF new.credentialsNum IS NOT NULL THEN 
SET new.id = UUID();
END IF;
END;
//
	
INSERT INTO TRAVELLER (NAME, sex, phonenum, credentialstype, credentialsnum, travellertype) 
VALUES ('张龙', '男', '13333333333', 0, '123456789009876543', 0); 

INSERT INTO TRAVELLER (NAME, sex, phonenum, credentialstype, credentialsnum, travellertype) 
VALUES ('张小龙', '男', '15555555555', 0, '987654321123456789', 1);	

叁 | member表

SELECT * FROM `member`;
CREATE TABLE member( 
	id VARCHAR(32) PRIMARY KEY, 
	NAME VARCHAR(20), 
	nickname VARCHAR(20), 
	phoneNum VARCHAR(20), 
	email VARCHAR(20) 
	)

/*删除触发器*/
DROP TRIGGER IF EXISTS `member_before_insert`;

DELIMITER //
CREATE TRIGGER `member_before_insert` 
BEFORE INSERT ON `member` FOR EACH ROW 
BEGIN 
IF new.phoneNum IS NOT NULL THEN 
SET new.id = UUID();
END IF;
END;
//

INSERT INTO MEMBER (NAME, nickname, phonenum, email) 
VALUES ('张三', '小三', '18888888888', 'zs@163.com');

肆 | orders表

DROP TABLE IF EXISTS `orders`;

SELECT * FROM `orders`;

CREATE TABLE orders( 
	id VARCHAR(32) PRIMARY KEY, 
	orderNum VARCHAR(20) NOT NULL UNIQUE, 
	orderTime TIMESTAMP, 
	peopleCount INT, 
	orderDesc VARCHAR(500), 
	payType INT, 
	orderStatus INT, 
	productId VARCHAR(32), 
	memberId VARCHAR(32), 
	FOREIGN KEY (productId) REFERENCES product(id), 
	FOREIGN KEY (memberId) REFERENCES member(id) 
	)
	
/*删除触发器*/
DROP TRIGGER IF EXISTS `orders_before_insert`;

DELIMITER //
CREATE TRIGGER `orders_before_insert` 
BEFORE INSERT ON `orders` FOR EACH ROW 
BEGIN 
IF new.orderDesc IS NOT NULL THEN 
SET new.id = UUID();
END IF;
END;
//

INSERT INTO ORDERS (ordernum, ordertime, peoplecount, orderdesc, paytype, orderstatus, productid, memberid) 
VALUES ('12345', NOW(), 2, '没什么', 0, 1, '676C5BD1D35E429A8C2E114939C5685A', 'E61D65F673D54F68B0861025C69773DB'); 

INSERT INTO ORDERS (ordernum, ordertime, peoplecount, orderdesc, paytype, orderstatus, productid, memberid) 
VALUES ('54321', NOW(), 2, '没什么', 0, 1, '676C5BD1D35E429A8C2E114939C5685A', 'E61D65F673D54F68B0861025C69773DB'); 

INSERT INTO ORDERS (ordernum, ordertime, peoplecount, orderdesc, paytype, orderstatus, productid, memberid) 
VALUES ('67890', NOW(), 2, '没什么', 0, 1, '12B7ABF2A4C544568B0A7C69F36BF8B7', 'E61D65F673D54F68B0861025C69773DB'); 

INSERT INTO ORDERS (ordernum, ordertime, peoplecount, orderdesc, paytype, orderstatus, productid, memberid) 
VALUES ('98765', NOW(), 2, '没什么', 0, 1, '12B7ABF2A4C544568B0A7C69F36BF8B7', 'E61D65F673D54F68B0861025C69773DB'); 


完成。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值