Mysql 操作技巧
- 复制表结构 + 表数据
Mysql> create tables t2 like t1;
Mysql> insert into t2 select * from t1; - mysql 索引
a、Alert Table 用来创建普通索引、Unique 唯一索引 (当前列数值不可重复) 或 Primary Key 主键索引
Mysql> alter table table_name add index index_name(column_list);
Mysql> alter table table_name add Unique(column_list);
Mysql> alter table table_name add Primary Key(column_list);b、creat index (不可处理主键索引)
Mysql> create index index_name on table_name(column_list);
Mysql> create Unique index index_name on table_name(column_list);c、drop index(不可处理主键索引)
Mysql> drop index index_name on table_name;d、alter table drop
Mysql> alter table table_name drop index index_name;
Mysql> alter table table_name drop primary key; - mysql 视图
创建视图 (视图可根据主表实时更新)
Mysql> create view v_t1 as select * from t1 where id>4 and id <11;
Mysql> show tables;
Mysql> show create view v_t1;
Mysql> drop view v_t1; - Mysql 内置函数
concat ("string1","string2") // 链接字符串
lcase(STRING) // 转换小写
ucase(string) // 转换大写
length(string) //string 长度
ltrim(string) // 去除 string 前面空格
rtrim(string) // 去除 string 后面空格
repeat(string,count) // 重复 string count 次
replace(str,search_str,replace_str) //str 中用 replace_str 替换 search_str - mysql 预处理语句
设置 stmt1 预处理,传递一个数据作为 where 判断条件
Mysql> prepare stmt1 from 'select * from t1 where id>?';
设置一个变量
Mysql> set @i=5;
执行 stmt1 预处理
Mysql> execute stmt1 using @i;
删除预处理 stmt1
Mysql> drop prepare stmt1; - mysql 事务处理 (Engine=MyISAM 表引擎不支持事务机制)
查看表引擎是否支持
Mysql> show create table t1;
设置表引擎为 innodb
Mysql> alter table t1 engine=innodb;
关闭自动提交功能
Mysql> set autocommit=0;
查看当前 autocommit 设置
Mysql> select @@autocommit;
提交
Mysql> commit;
从表 t1 中删除了一条记录
Mysql> delete from t1 where id =11;
此时做一个 p1 还原点
Mysql> savepoint p1;
再次从表 t1 中删除一条记录
Mysql> delete from t1 where id =10;
再次做一个 p2 还原点
Mysql> savepoint p2;
此时恢复到 p1 还原点,当然后面 p2 这些还原点自动失效
Mysql> rollback to p1;
退回到最原始的还原点
Mysql>roolback; - Mysql 存储 (批量处理)
例子:创建存储 P1, 创建 100 个用户;
Mysql> \d // 执行 “;” 临时替换为 “//”
Mysql> create proceduce p1()
->begin
->set @i=1;
->while @i<100 do
->insert into t1(name) value(concat("user",@i));
->set @i=@i+1;
->end while;
->end//
Mysql> \d ;
查看存储
Mysql> show procedure status\G
Mysql> show create procedure p1\G
执行
Mysql> call p1(); - Mysql 触发器
修改 delimiter 为 //
Mysql> \d //
例子:创建触发器 tg1,当向 t1 表插入数据时,t2 表也被插入数据
Mysql> create trigger tg1 before insert on t1 for each row
->begin
->insert into t2(name) values(new.name);
->end//
Mysql> \d ;
查看触发器
Mysql> show triggers;
删除触发器
Mysql> drop trigger tg1;
创建触发器 tg2,当向 t1 表删除数据时,t2 表也被删除数据
Mysql> create trigger tg2 before delete on t1 for each row
->begin
->delete from t2 where name=old.name;
->end//创建触发器 tg3,当向 t1 表更新数据时,t2 表也被更新数据
Mysql> create trigger tg3 before update on t1 for each row
->begin
->update t2 set name=new.name where name=old.name;
->end// - 重排 auto_increment
Mysql 数据库自动增长的 ID 恢复重新排序
Mysql> alter table tablename auto_increment = 1;Other:
联合查询
Mysql> select * from t1 union select *from t2
快速删除
Mysql> truncate table tablename;
Mysql 操作技巧的更多相关文章
- (转)防止人为误操作MySQL数据库技巧一例
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://oldboy.blog.51cto.com/2561410/1321061 防止人 ...
- 您的项目引用了最新实体框架;但是,找不到数据链接所需的与版本兼容的实体框架数据库 EF6使用Mysql的技巧
转载至: http://www.cnblogs.com/Imaigne/p/4153397.html 您的项目引用了最新实体框架:但是,找不到数据链接所需的与版本兼容的实体框架数据库 EF6使用Mys ...
- mysql操作1
一.连接MYSQL.格式: mysql -h主机地址 -u用户名 -p用户密码1.连接到本机上的MYSQL.首先打开DOS窗口,然后进入目录mysql\bin,再键入命令mysql -u root - ...
- 用Excel做出比肩任务管理软件的操作技巧
用Excel做出比肩任务管理软件的操作技巧 在项目管理中,网上有各种各样的工具可以选择,到底用哪个,曾一度困扰着我.我是一个有轻度强迫症的人,总是喜欢试用各种各样的系统,以比较他们之间的不同,试图选择 ...
- Mysql操作初级
Mysql操作初级 本节内容 数据库概述 数据库安装 数据库操作 数据表操作 表内容操作 1.数据库概述 数据库管理系统叫做DBMS 1.什么是数据库 ? 答:数据的仓库,如:在ATM的示例中我们创建 ...
- python学习道路(day12note)(mysql操作,python链接mysql,redis)
1,针对mysql操作 SET PASSWORD FOR 'root'@'localhost' = PASSWORD('newpass'); 设置密码 update user set password ...
- 学习笔记:MySQL操作初步
对数据库的操作:SQL语言 一:SQL:Structured Query Language,结构化查询语言! 二:DDL:Data Definition Language,数据定义语言 三:DML:D ...
- ecshop的Mysql操作类
摘要,这是直接摘抄的ecshop的mysql操作类:不过他这里的缓存是用的文件缓存,我们如果想直接使用,可以替换成memcache的或者redis的! <?php /** * ECSHOP MY ...
- MySQL常用技巧
1.查看MySQL版本信息: 1,登上 mysql>status; 2,登上 mysql>select version(); 3,登上 mysql> select @@version ...
随机推荐
- 2017软工实践K班总结
回首一学期的软工实践,从暑假开始陆续布置作业,经历个人.结对与团队等大小作业.也经历了不少同学被吓跑.第一周就退选的情况,能坚持下来的都是胜利者,至少你们有一颗愿意挑战的心.首先感谢助教谢涛付出的巨大 ...
- web网站css,js更新后客户浏览器缓存问题,需要刷新才能正常展示的解决办法
问题描述 最近将公司官网样式进行了调整,部署到服务器后访问发现页面展示不正常,但是刷新之后就会展示正常. 问题分析 研究之后发现可能的原因有 css文件过大,加载缓慢 本地缓存问题,虽然服务器修改了c ...
- Zk搭建(Zookeeper)
第一步: 上传----解压 tar -zxvf zookeeper-3.4.5.tar.gz---- 配置zk的环境变量 ----------配置源码 vim ...
- final域的内存语义
final 一.final的基本语义 final关键字可以用来修饰类.方法和变量(包括成员变量和局部变量) 当用final修饰一个类时,表明这个类不能被继承. 当用final修饰一个方法时,表明这个方 ...
- MySQL 高可用性—keepalived+mysql双主
MySQL 高可用性—keepalived+mysql双主(有详细步骤和全部配置项解释) - 我的博客 - CSDN博客https://blog.csdn.net/qq_36276335/articl ...
- pinpoint vs druid
主流Java数据库连接池分析(C3P0,DBCP,TomcatPool,BoneCP,Druid) - ppjj - 博客园 https://www.cnblogs.com/nizuimeiabc1/ ...
- Nginx负载均衡各种配置方式
Nginx负载均衡 - 小刚qq - 博客园http://www.cnblogs.com/xiaogangqq123/archive/2011/03/04/1971002.html Module ng ...
- Ubuntu 12.04 安装socks5代理服务器dante-server
dante-server是一个很好的socks4/5代理服务器软件. 使用apt-get安装 1 apt-getinstall dante-server 添加一个用户 1 2 useradd ...
- js 移动端 多图上传 预览 删除 base64转为url 传给后端
说下主要的逻辑,首先是利用input type="file",上传文件,然后判断文件类型是否是图片,这里要注意(multiple,安卓一次一张,ios可以多张). 接着把本地图片转 ...
- http1.0 1.1 与2.0
长连接 HTTP 1.0需要使用keep-alive参数来告知服务器端要建立一个长连接,而HTTP1.1默认支持长连接. HTTP是基于TCP/IP协议的,创建一个TCP连接是需要经过三次握手的,有一 ...