MySQL命令2
索引与外键
// 添加索引
ALTER TABLE orders ADD KEY order_ix_custid(cust_id);
// 删除索引
ALTER TABLE orders DROP KEY order_ix_custid;
// 添加外键
ALTER TABLE orderitem ADD CONSTRAINT fk_orderitem_orders FOREIGN KEY (order_id) REFERENCES orders (id);
// 添加外键,支持级联删除
ALTER TABLE orderitem ADD CONSTRAINT fk_orderitem_orders FOREIGN KEY (order_id) REFERENCES orders (id) ON DELETE CASCADE;
// 删除外键
ALTER TABLE orderitem DROP FOREIGN KEY fk_orderitem_orders;
// 添加唯一索引
ALTER TABLE orderitem ADD UNIQUE KEY uc_orderitem(order_id, product_id);
order是MySQL的一个关键字,不要用来做表名,否则有坑。
触发器
// 创建AFTER INSERT触发器
DELIMITER #
CREATE TRIGGER trigger_new_product AFTER INSERT ON wishitem FOR EACH ROW
BEGIN
DECLARE new_url VARCHAR(128);
SELECT thumbnail_url FROM product WHERE id = NEW.product_id INTO new_url;
UPDATE wish SET thumbnail_url = new_url WHERE id = NEW.wish_id;
END #
DELIMITER ; // 创建AFTER DELETE触发器
DELIMITER #
CREATE TRIGGER trigger_del_product AFTER DELETE ON wishitem FOR EACH ROW
BEGIN
DECLARE prod_url VARCHAR(128);
DECLARE prod_time DATETIME;
SELECT cp.thumbnail_url, wi.add_time FROM wishitem AS wi INNER JOIN product AS cp on wi.product_id =
cp.id WHERE wi.wish_id = OLD.wish_id ORDER BY wi.add_time LIMIT 1 INTO prod_url, prod_time;
IF prod_url IS NULL THEN
SET prod_url = '';
END IF;
UPDATE wish SET thumbnail_url = prod_url WHERE id = OLD.wish_id;
END #
DELIMITER ; // 显示触发器
SHOW TRIGGERS; // 删除触发器
DROP TRIGGER trigger_new_product;
replace into
REPLACE works exactly like INSERT, except that if an old row in the table has the same value as a new row for a PRIMARY KEY or a UNIQUE index, the old row is deleted before the new row is inserted.
INSERT ... ON DUPLICATE KEY UPDATE
If you specify an ON DUPLICATE KEY UPDATE clause and a row to be inserted would cause a duplicate value in a UNIQUEindex or PRIMARY KEY, an UPDATE of the old row occurs.
REPLACE INTO是先删除再插入,如果主键是AUTO_INCREMENT,会导致主键自增。
现有一个表wishitems

可以使用 SHOW CREATE TABLE wishitem 查看表的AUTO_INCREMENT值
CREATE TABLE wishitem (
id bigint(20) unsigned NOT NULL AUTO_INCREMENT,
wish_id bigint(20) unsigned NOT NULL DEFAULT '',
product_id bigint(20) unsigned NOT NULL DEFAULT '',
add_time datetime NOT NULL DEFAULT '1970-01-01 00:00:00',
PRIMARY KEY (id),
UNIQUE KEY uc_wishitem (wish_id, product_id),
CONSTRAINT fk_wishitem_wish FOREIGN KEY (wish_id) REFERENCES wish (id) ON DELETE CASCADE
) ENGINE=InnoDB AUTO_INCREMENT=15000000000000000038 DEFAULT CHARSET=utf8
现在执行
REPLACE INTO wishitem(wish_id, product_id) VALUES(14000000000000000009,99999100000000037)
再次查看表中数据

再次使用 SHOW CREATE TABLE wishitem 查看表的AUTO_INCREMENT值
CREATE TABLE wishitem (
id bigint(20) unsigned NOT NULL AUTO_INCREMENT,
wish_id bigint(20) unsigned NOT NULL DEFAULT '',
product_id bigint(20) unsigned NOT NULL DEFAULT '',
add_time datetime NOT NULL DEFAULT '1970-01-01 00:00:00',
PRIMARY KEY (id),
UNIQUE KEY uc_wishitem (wish_id, product_id),
CONSTRAINT fk_wishitem_wish FOREIGN KEY (wish_id) REFERENCES wish (id) ON DELETE CASCADE
) ENGINE=InnoDB AUTO_INCREMENT=15000000000000000039 DEFAULT CHARSET=utf8
果然,主键ID自增了。
INSERT ... ON DUPLICATE KEY UPDATE不会出现这个问题。
AUTO_INCREMENT
对应表下一个要插入的id
You can retrieve the most recent automatically generated AUTO_INCREMENT value with the LAST_INSERT_ID() SQL function
# 重新设置AUTO_INCREMENT
ALTER TABLE tablename AUTO_INCREMENT = 1
参考资料:
Insert into a MySQL table or update if exists
truncate foreign key constrained table
How to reset AUTO_INCREMENT in MySQL?
MySQL命令2的更多相关文章
- Mysql命令大全
格式: mysql -h主机地址 -u用户名 -p用户密码 1.连接到本机上的MYSQL.首先打开DOS窗口,然后进入目录mysql\bin,再键入命令mysql -u root -p,回车后提示你输 ...
- ****Linux MySQL命令运用个人总结
1.xampp在linux下如何使用mysql命令 A: 解决方法(推荐第二个方法): 1.xampp中的命令工具在/opt/lampp/bin/目录中,所以可以这样运行mysql命令 /opt/la ...
- MySQL命令行登录的例子
环境:MySQL Sever 5.1 + MySQL命令行工具 问题:MySQL命令行登录 解决: 命令 行登录语法: mysql –u用户名 [–h主机名或者IP地址] –p密码 说明:用户名是你登 ...
- MySQL命令行下执行.sql脚本详解
本文主要介绍一个在MySQL命令行下执行脚本文件的例子,通过这个例子让我们来了解一下在命令行下MySQL是怎样执行脚本的吧.现在我们开始介绍这一过程. 1.首先编写sql脚本,保存为的:book.sq ...
- Mysql 命令大全
1.连接Mysql 格式: mysql -h主机地址 -u用户名 -p用户密码1.连接到本机上的MYSQL.首先打开DOS窗口,然后进入目录mysql\bin,再键入命令mysql -u root - ...
- mysql 在windows下,使用 net start mysql 命令发生错误 服务名无效 或 1067
mysql 在windows下,使用 net start mysql 命令发生错误 :服务名无效 或 1067 先使用mysqld -install安装一下 删除data目录下的日志等文件(因为之前 ...
- MySQL命令大全:MySQL常用命令手册、MySQL命令行大全、查询工具
1.连接Mysql 格式: mysql -h主机地址 -u用户名 -p用户密码 1.连接到本机上的MYSQL.首先打开DOS窗口,然后进入目录mysql\bin,再键入命令mysql -u root ...
- MYSQL命令行使用指南
一.连接MYSQL. 格式: mysql -h主机地址 -u用户名 -p用户密码 1.例1:连接到本机上的MYSQL. 首先在打开DOS窗口,然后进入目录 mysqlbin,再键入命令mysql -u ...
- mysql命令行以及mysql workbence查询结果中文乱码的解决方法
最近正在学习mysql,安装环境是windows server 2003 32位操作系统+mysql 5.1.47同时也安装了mysql命令行以及mysql workbench这里是test数据库cr ...
- MySQL命令行导出数据库
MySQL命令行导出数据库:1,进入MySQL目录下的bin文件夹:cd MySQL中到bin文件夹的目录如我输入的命令行:cd C:\Program Files\MySQL\MySQL Server ...
随机推荐
- Linux不同时钟的区别
今天发现项目中调用 clock_gettime 函数传入时钟类型参数时有 CLOCK_MONOTONIC.CLOCK_MONOTONIC_RAW.CLOCK_BOOTTIME.CLOCK_REALTI ...
- mysql的事务四个特性以及事务的四个隔离级别
一.事务四大属性 分别是原子性.一致性.隔离性.持久性. 1.原子性(Atomicity) 原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚,因此事务的操作如果成功就必须要完全应用到数据库, ...
- python初学(三)
1.以软科中国最好大学排名为分析对象,基于requests库和bs4库编写爬虫程序,对2015年至2019年间的中国大学排名数据进行爬取,并按照排名先后顺序输出不同年份的前10位大学信息,要求对输出结 ...
- PHP xml 外部实体注入漏洞学习
XML与xxe注入基础知识 1.XMl定义 XML由3个部分构成,它们分别是:文档类型定义(Document Type Definition,DTD),即XML的布局语言:可扩展的样式语言(Exten ...
- kubernetes的headless service介绍
headless service是一个特殊的ClusterIP类service,这种service创建时不指定clusterIP(--cluster-ip=None),因为这点,kube-proxy不 ...
- Win10桌面美化
捯饬了几个小时终于捯饬好了,没什么特效,就是看起来干净了许多. 用到的小软件: 链接:https://pan.baidu.com/s/1_PSTn0JZ22ZGiMDOdvdWEw提取码:329c 1 ...
- c++动态数组的使用
在c++中,有的时候会遇到变长的数组(不管是一维的还是二维的),这个时候就需要用到动态数组了,并且要用new和delete两个操作符,这俩操作符一般成对使用. 先说一维的动态数组吧,直接上代码 #in ...
- Scrapy模拟登录信息
携带cookie模拟登录 需要在爬虫里面自定义一个start_requests()的函数 里面的内容: def start_requests(self): cookies = '真实有效的cookie ...
- vue.js click点击事件获取当前元素对象
Vue.js可以传递$event对象 <body id="app"> <ul> <li v-on:click="say('hello!', ...
- Centos史上新版最详细步骤-Linux无脑命令式oracle11g静默安装
1. 关闭selinux 1.1 sed -i "s/SELINUX=enforcing/SELINUX=disabled/" /etc/selinux/config 1.2 或者 ...