1、left join 需要注意的事项

  以左表为基准,匹配右表,如果右表匹配了两条,那么,就生成两条记录,而这两条记录的坐表信息都是一样的。

之前误以为,右表不会影响记录的条数。select 部分,不再是两张表的概念,而是一个大临时表。比如select t2.count(id)  ,会只生成一条记录。

2、order by子句--执行顺序为从左到右排序,很耗资源

3、group by--执行顺序从左往右分组,group by之后在筛选的话用having,例如筛选出分组数大于1的:select count(*) as num from t1 where .. group by t1.id having num>1 

4、where子句--执行顺序为自下而上、从右到左

5、联表的时候,小表(筛选条件后)作为驱动表(后表)

Ps:小表遍历根据两表的关联条件去找大表对应的数据,很快就能找的,有索引就更快了。反之,大表本身遍历就很麻烦,就算有索引,也得遍历一遍大表。

6、count(*) 和 group by 一起使用,count(*) 的值 会有多条,而且是group by分组后各个组的条数,而且,如果没有记录的话,也会返回一条记录,但是这条记录的count(*) =0

7、查询订单中每一天充值的总人数,总次数,总金额,总元宝(由游戏表金额元宝兑换率转换)。

SELECT COUNT(*) AS countUser, createdTime, countNum, countAmount, countGold
FROM (SELECT COUNT(*) AS countNum, SUM(t1.cd_Amount) AS countAmount, SUM(t1.cd_Amount * t2.sd_ExchangeRate) AS countGold, FROM_UNIXTIME(cd_CreatedTime, '%Y-%m-%d')
AS createdTime
FROM CD_Order t1 LEFT JOIN SD_GameInfo t2 ON t1.ga_Gameid = t2.ga_GameID
WHERE t1.cd_PayStatus = 1
AND t1.cd_SendStatus != 0
AND t1.cd_CreatedTime >= ?
AND t1.cd_CreatedTime <= ?
GROUP BY t1.pt_AccountKey, createdTime
) t
GROUP BY t.createdTime

然后,程序得出每一天的数组。

 $chartData = array(); 

while (strtotime($start) <= strtotime($enddate)) {
$chartData[]['createTime'] = $start;
$start = date('Y-m-d', strtotime($start . " +1 day"));
}

最后,根据你的需求,整合这两个数组既可。

8、同步原ms库中主题表
self::$db->query('truncate fg_cms.question_topic');
self::$db->query('insert into fg_cms.question_topic select * from platform.CS_QuestionTopic');

9、把一个表的字段复制到另外一表

 update t1,t2 set t1.na=t2.na where t1.id=t2.id 
 
查看mysql状态:show status;
查看系统变量:show variables; show variables like '%max_connections%';
修改系统变量:set global max_connections=14000;

将文件中的“bind-address  = 127.0.0.1”改为“bind-address  = 0.0.0.0”,让所有IP都能访问

  

linux下导入、导出mysql数据库命令

一、导出数据库用mysqldump命令(注意mysql的安装路径,即此命令的路径):
1、导出数据和表结构:
mysqldump -u用户名 -p密码 数据库名 > 数据库名.sql
#/usr/local/mysql/bin/   mysqldump -uroot -p abc > abc.sql
敲回车后会提示输入密码

2、只导出表结构
mysqldump -u用户名 -p密码 -d 数据库名 > 数据库名.sql
#/usr/local/mysql/bin/   mysqldump -uroot -p -d abc > abc.sql

mysqldump -uroot -p123456 --opt --skip-extended-insert --single-transaction --master-data=2 -R dbname | gzip >/data/dbname.sql.gz

注:/usr/local/mysql/bin/  --->  mysql的data目录

3、只导出某张表

mysqldump -u用户名 -p密码 数据库名 数据表名 > 数据表名.sql

二、导入数据库
1、首先建空数据库
mysql>create database abc;

2、导入数据库
方法一:
(1)选择数据库
mysql>use abc;
(2)设置数据库编码
mysql>set names utf8;
(3)导入数据(注意sql文件的路径)
mysql>source /home/abc/abc.sql;
方法二:
mysql -u用户名 -p密码 数据库名 < 数据库名.sql
#mysql -uabc_f -p abc < abc.sql

 数据复制迁移

1、复制datadir下面的数据库文件夹和mysql文件夹以及ibdata1文件

2、删除原来的ib_logfile0,ib_logfile1

3、重启mysql

如果出现类似错误,证明是复制文件的时候,ibdata1和具体所有文件不对称导致的

2013-11-04 10:02:28 2aaf5d032520  InnoDB: Operating system error number 2 in a file operation.
InnoDB: The error means the system cannot find the path specified.
InnoDB: If you are installing InnoDB, remember that you must create
InnoDB: directories yourself, InnoDB does not create them.
InnoDB: Error: could not open single-table tablespace file ./mysql/innodb_table_stats.ibd
InnoDB: We do not continue the crash recovery, because the table may become
InnoDB: corrupt if we cannot apply the log records in the InnoDB log to it.
InnoDB: To fix the problem and start mysqld:

 解决方法:mysqld下增加innodb_force_recovery=1

重启,导出数据库,再导进去一次,然后innodb_force_recovery=0还原。重启即可

不同表更新字段

update user.cdb_user t1,tutu.cdb_area t2 set t1.parentAreaId = t2.upid where t1.areaId = t2.id

  

mysql sql技巧篇的更多相关文章

  1. MYSQL SQL语句技巧初探(一)

    MYSQL SQL语句技巧初探(一) 本文是我最近了解到的sql某些方法()组合实现一些功能的总结以后还会更新: rand与rand(n)实现提取随机行及order by原理的探讨. Bit_and, ...

  2. MySQL基础操作&&常用的SQL技巧&&SQL语句优化

    基础操作     一:MySQL基础操作         1:MySQL表复制             复制表结构 + 复制表数据             create table t3 like t ...

  3. mysql数据库优化课程---14、常用的sql技巧

    mysql数据库优化课程---14.常用的sql技巧 一.总结 一句话总结:其实就是sql中那些函数的使用 1.mysql中函数如何使用? 选择字段 其实就是作用域select的选择字段 3.转大写: ...

  4. MySQL SQL查询优化技巧详解

    MySQL SQL查询优化技巧详解 本文总结了30个mysql千万级大数据SQL查询优化技巧,特别适合大数据里的MYSQL使用. 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 ...

  5. Mysql sql语句技巧与优化

    一.常见sql技巧 1.正则表达式的使用 2.巧用RAND()提取随机行 mysql数据库中有一个随机函数rand()是获取一个0-1之间的数,利用这个函数和order by一起能够吧数据随机排序, ...

  6. mysql第四篇--SQL逻辑查询语句执行顺序

    mysql第四篇--SQL逻辑查询语句执行顺序 一.SQL语句定义顺序 SELECT DISTINCT <select_list> FROM <left_table> < ...

  7. Mysql - 开发技巧(二)

    本文中的涉及到的表在https://github.com/YangBaohust/my_sql中 本文衔接Mysql - 巧用join来优化sql(https://www.cnblogs.com/dd ...

  8. mysql sql语句大全(转载)

      1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- 创建 ...

  9. 学习mysql语法--基础篇(一)

      前  言  mysql  mysql语法--本篇学习都是通过使用Navicat Premium(数据库管理工具),连接mysql数据. 本篇学习主要有两个部分:    一.创建用户,创建数据库,给 ...

随机推荐

  1. JavaEE路径陷阱之getRealPath

    转自:http://blog.csdn.net/shendl/article/details/1427637   JavaEE路径陷阱之getRealPath   本文是<Java路径问题最终解 ...

  2. [整理]android中几种常见的尺寸

    获取屏幕宽高尺寸的三种代码形式 在Android上,目前我知道的获取屏幕尺寸的方法有三种不同的代码形式 方法1.在Activity中最常见的调用方式 WindowManager windowManag ...

  3. LightOJ 1248 Dice (III) 概率

    Description Given a dice with n sides, you have to find the expected number of times you have to thr ...

  4. MySQL命令行查询乱码解决方法:

    MySQL会出现中文乱码的原因不外乎下列几点:1.server本身设定问题,例如还停留在latin1 2.table的语系设定问题(包含character与collation) 3.客户端程式(例如p ...

  5. Lock的基础概念

    锁的相关概念 1.可重入锁 如果锁具备可重入性,则称作为可重入锁.像synchronized和ReentrantLock都是可重入锁,可重入性在我看来实际上表明了锁的分配机制:基于线程的分配,而不是基 ...

  6. 介绍开发Android手持终端PDA盘点APP软件

    介绍开发Android手持终端PDA盘点APP软件 软件需要自动识别我导入的TXT格式或者excl格式的盘点表,然后自动生成一个复盘数据,做AB比对,界面上需要显示的有总数量,单品数量,条码,编码,商 ...

  7. JSON转换为数组 但读取JSON的顺序目前没法保证

    var json = {a : 1, b : 2, c: 3}; var jsonArr = []; for (i in json){ var wrap = []; wrap[0] = i; wrap ...

  8. 【wikioi】1403 新三国争霸(dp+kruskal)

    http://wikioi.com/problem/1403/ 一开始的确感觉和bzoj1003很像,不同的是这里还要求联通,求最小的边. 我们可以想到用最小生成树(为嘛我自己想不到呢..) 我们可以 ...

  9. C#中使用JQueryUI中Autocomplete插件

    服务器端后台代码: 1 private string GetModelNames() { 2 return @"[ 3 { 4 'value': 'jquery', 5 'label': ' ...

  10. Centos python 2.6 升级到2.7.3

    wget http://python.org/ftp/python/2.7.3/Python-2.7.3.tar.bz2 sudo make all sudo mak install sudo mak ...