mysql表复制

1.复制表结构
create table student like user;
2.复制表内容
insert into t3 select * from t1;

mysql索引

1.查看索引
show index from user\G

2.普通索引
1)创建
create index i_age on user(age);
2)删除
drop index i_age on user;
3.唯一索引
1)create unique index u_username on user(username);
2)drop index u_username on user;
4.主键索引
--去除auto_increment 主键不能modify
alter table user modify id int unsigned;
1)创建(要自增必须主键)
alter table table_name add primary key (column_list)
2)删除
alter table table_name drop index index_name
alter table table_name drop primary key

mysql视图

视图相当于截图 会随着表变化而变化 没有存储任何数据
1.创建
create view userclass as select user.username,user.age,class.name from user,class where user.class_id=class.id;
2.删除
drop view userclass;
3.查看
show tables ;

  1. select * from userclass;

mysql查看表中未来的自增数
show create table user;

mysql内置函数

1.mysql字符串函数
CONCAT(string [,...]) //连接字符串
LCASE(string2) //转换成小写
UCASE(string2) //转换成大写
LENGTH(string) //string长度
LTRIM(string2) //去除前端空格
RTRIM(string2) //去除后端空格
REPEAT(string2,count) //重复count次
REAPEAT(str,search_str,replace_str) //在str中用replace_str替换search_str
SUBSTRING(str,position,[,length]) //position开始 取length个字符
SPACE(count) //生成count个空格

2.数学函数
bin() //把某一个数转换为二进制
ceiling() //取上一个整数
floor() //取下一个整数
select floor(10.5);

max() //取最大整数
select max(id) from user;

min() //取最小整数
sqrt() //平方根
rand() //随机数

3.日期函数
curdate()
curtime()
now()
unix_timestamp()
from_unixtime()
week(date)
year(date)
datediff()

mysql

sql语句优化
1)优化SQL语句的一般步骤
2)索引优化
3)check与optimize使用方法
4)常用sql优化
检查服务器增删查改使用频次 自启动以来
show status like "%InnoDB_rows%";

通过show status命令了解各种sql执行效率
格式:show[session|global]status;
session(默认)表示当前连接
global表示自数据库启动至今
show status;
show global status;
show status like 'Com_%';
show global status like 'Com_%';

定位执行效率较低的sql语句
1.explain或desc定位一条sql语句的影响行数
desc select * from user where id=1\G
desc select * from user where username='weizai'\G

mysql慢查询

1.查看慢查询次数
show status like "%quer%";
Slow_queries | 0

2.修改慢查询时间(my.ini)
long_query_time=6

show variables like "%query%";
附录:批量插入数万条测试数据(存储过程)
mysql> delimiter $$
mysql> create procedure ptest()
-> begin
-> declare pid int ;
-> set pid = 1000000;
-> while pid>0 do
-> insert into ...... --插入语句
-> set pid = pid-1;
-> end while;
-> end $$
mysql> delimiter ;
mysql> call myFunction();//调用存储过程

优化表空间:

1.optimize table sales;
1).myisam表没有问题
2).innodb表ibdata1文件无法回收空间

索引

create index ind_company2_name on company2(name(4))
索引的存储分类
1).myisam
2).innodb

索引用于快速找出某个列中有特定值的行 对相关列使用索引是提高select操作性能的最佳途径
1.使用索引
1)对于创建的多列索引 只要查询的条件中用到最左边的列
索引一般会被使用

如下复合索引(比较少)
create index ind_sales2_com_mon on sales2(company_id,moneys);
然后按照company_id进行查询 发现使用了复合索引
explain select * from sales2 where company_id=2006\G
使用下面的查询就没有使用到复合索引
explain select * from sales2 where moneys=1\G

2)like关键词
当使用like进行搜索时 %在前索引可能会失效
desc select * from student_big where username like '%inux%'\G
desc select * from student_big where username like 'linux%'\G

3)如果对大的文本进行搜索 使用全文索引而不使用like % %

4)如果列名是索引 使用column_name is null将使用索引

mysql设计-优化的更多相关文章

  1. MYSQL设计优化

    本文将从各方面介绍优化mysql设计的一些方式. 1.优化sql语句 (1)定位须要优化的sql语句 1)show status统计SQL语句频率 对Myisam和Innodb存储引擎都计数的參数: ...

  2. Mysql数据库优化

    to be add... --------------------------------------------------------------------------------------- ...

  3. Mysql数据库优化总结2

    说明:本文的环境为CENTOS 5.5 64 Bit /Mysql 5.1.50 简介:使用Mysql有一段时间了,期间做了不少关于Mysql优化.设计.维护的工作,这两天有时间做一下简单的总结,方便 ...

  4. MySQL性能优化总结___本文乃《MySQL性能调优与架构设计》读书笔记!

    一.MySQL的主要适用场景 1.Web网站系统 2.日志记录系统 3.数据仓库系统 4.嵌入式系统 二.MySQL架构图: 三.MySQL存储引擎概述 1)MyISAM存储引擎 MyISAM存储引擎 ...

  5. mysql数据库优化课程---3、数据库设计是什么

    mysql数据库优化课程---3.数据库设计是什么 一.总结 一句话总结: 就是设计各个字段及各个字段类型 1.char,varchar,text同存'ABC'的存储空间为多少? char(255): ...

  6. MySQL性能优化(二):优化数据库的设计

    原文:MySQL性能优化(二):优化数据库的设计 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.n ...

  7. mysql设计与优化以及数据库表设计与表开发规范

    一.设计问题? 1.主键是用自增还是UUID ? Innodb 中的主键是聚簇索引. 如果主键是自增的,那么每次插入新的记录,记录就会顺序添加到当前索引节点的后续位置,当一页写满,就会自动开辟一个新的 ...

  8. MySQL数据库优化、设计与高级应用

    MySQL数据库优化主要涉及两个方面,一方面是对SQL语句优化,另一方面是对数据库服务器和数据库配置的优化. 数据库优化 SQL语句优化 为了更好的看到SQL语句执行效率的差异,建议创建几个结构复杂的 ...

  9. Mysql学习总结(17)——MySQL数据库表设计优化

    1.选择优化的数据类型 MySQL支持很多种不同的数据类型,并且选择正确的数据类型对于获得高性能至关重要.不管选择何种类型,下面的简单原则都会有助于做出更好的选择: (1).更小通常更好 一般来说,要 ...

随机推荐

  1. Hibernate4.3.5入门HelloWorld

    本文给出一个简单的Hibernate4.3.5入门实例,配置方式采用XML文件方式(这种方式已经不是主流了,目前越来越多采用Annotation方式映射POJO实体) 代码结构如下图所示:主要用到hi ...

  2. 并发模型(二)——Master-Worker模式

    Master-Worker模式是常用的并行模式之一,它的核心思想是,系统有两个进程协作工作:Master进程,负责接收和分配任务:Worker进程,负责处理子任务.当Worker进程将子任务处理完成后 ...

  3. python学习——练习题(1)

    """ 题目:有四个数字:1.2.3.4,能组成多少个互不相同且无重复数字的三位数?各是多少? """ import itertools d ...

  4. Mybatis系列(四)映射文件

    转自:https://blog.csdn.net/chris_mao/article/details/48811507 Mybatis的真正强大,在于她对SQL的映射,这也是她吸引人的地方.实现相同的 ...

  5. [原创]JMeter初次使用总结

    引言 最近开发 java 后端项目,对外提供Restful API接口,完整功能开发现已完成. 目前通过单测(68%行覆盖率)已保证业务逻辑正确性,同时也尝试使用JMeter进行压力测试以保证并发性能 ...

  6. delphi 手电筒

    Self.CameraComponent1.TorchMode := TTorchMode.ModeOn;

  7. selenium2 用testNG对百度首页输入框进行测试 (三)

    如果还没有安装testNG的亲,可以点击http://www.cnblogs.com/milanmi/p/4346580.html查看安装过程. 这节主要是对百度首页的输入框进行输入测试. packa ...

  8. Unity ios、android、pc一键打包(一)

    http://www.cnblogs.com/miaoshujiang/p/5289223.html http://blog.csdn.net/ynnmnm/article/details/36774 ...

  9. 多线程编程为什么要sleep

    以前在分析程序的时候就遇到很多sleep,当时很觉得很奇怪?不直到为什么要调用这个sleep,现在明白了,这种情况一般是应用程序有多个线程,那怎么手动切换线程呢?调用sleep即可.

  10. Linux pkg-config命令

    一.简介 pkg-config用来检索系统中安装库文件的信息.典型的是用作库的编译和连接. 二.实例 http://blog.chinaunix.net/uid-20595934-id-1918368 ...