1. 关于多表查询

我的理解:由于MySQL多表查询时表之间的连接是笛卡尔积的方式,所以尽量少使用多表查询,如果使用则使用嵌套语句

例:说明: `tb_notice_message` 表数量百万级别以上,别名是wm表1000条左右

 SELECT COUNT(1) AS TotalNum
FROM `tb_notice_message` nm, (SELECT u.`userid` FROM `xiaoxin`.`tb_ios_whitemobile` m INNER JOIN `user_center`.`tb_user` u ON m.`userid` = u.`userid` WHERE u.`identity` = 1) AS wm
WHERE nm.`deleted` = 0 AND nm.`state` = 1 AND nm.`sender` <> wm.`userid` AND nm.`sid` = 4001 AND nm.sendtime >= '2014-10-22' AND nm.sendtime < '2014-11-1' AND nm.`noticetype` = 1

结果:半个小时内没有查询结果(用过inner join,也不行),不知道<>的查询效率如何,还请各位大神指教

不使用多表查询,使用嵌套

 SELECT COUNT(1) AS TotalNum
FROM `tb_notice_message` nm
WHERE nm.`deleted` = 0 AND nm.`state` = 1 AND nm.`sender` NOT IN(SELECT u.`userid` FROM `xiaoxin`.`tb_ios_whitemobile` m INNER JOIN `user_center`.`tb_user` u ON m.`userid` = u.`userid` WHERE u.`identity` = 1)

结果:一般10秒以内出现查询结果

2. 一次插入多条数据的方式(这里很多人都知道就不多说了),和SQL Server,及Oracle比较

 MySQL:INSERT INTO table VALUES (col1,col2...),(col1,col2...)......
SQL Server:INSERT INTO table VALUES SELECT '','','' UNION ALL SELECT '','',''.......
Oracle:INSERT INTO table SELECT '' FROM DUAL UNION ALL SELECT '' FROM DUAL

3. update MySQL中不允许使用update select 语句使用其他语句替代

update a inner join (select yy from b) c on a.id =b.id set a.xx = c.yy

例:

 UPDATE `tb_user` u INNER JOIN
(
SELECT se.`studentid`, gg.`guardian`
FROM `tb_user` uu INNER JOIN `tb_guardian` gg ON uu.`userid` = gg.`guardian` JOIN `tb_student_ext` se ON se.`userid` = gg.`child` WHERE uu.`account` = '' AND uu.`identity` = 3
) AS b
ON u.`userid` = b.`guardian` SET u.`account` = b.`studentid`
WHERE
u.`account` = '' AND u.`identity` = 3

4. MySQL去除tab和空格

 update et_product set name =trim(name);
update et_product set name =trim(replace(name, ' ', ' '));

例:

 SELECT se.`studentid` AS '学号', REPLACE(REPLACE(u.`name`, '"', ''), '    ', '') AS '姓名', REPLACE(REPLACE(s.`name`, 'n', ''), '    ', '') AS '学校', a.`name` AS '地区'
FROM
`tb_student_ext` se INNER JOIN `tb_user` u ON u.`userid` = se.`userid`
INNER JOIN `tb_school` s ON se.`sid` = s.`sid`
INNER JOIN `tb_area` a ON a.`aid` = s.`aid`
WHERE
u.`deleted` = 0 AND s.`deleted` = 0 AND
u.`state` = 0 AND -- 未激活
a.aid = 33

5. GROUP_CONCAT关键字(查询某个字段所有值,使用逗号进行分割)

SELECT GROUP_CONCAT(`ClassId`) cids FROM `tb_xa_class`

查询结果:

,,,,,...........

6.  insert或者update使用单引号(如果字段是字符串类型)

例:

 StringBuilder sb = new  StringBuilder();
sb.Append(@"INSERT INTO tb_school (name ,aid ,stid ,state ,xaschoolid ) VALUES ");
foreach (var t in sqList)
{
sb.AppendFormat("('{0}',{1},'{2}',{3},'{4}'),",
t.name, t.aid, t.stid, t.state, t.xaschoolid);
}
string sql = sb.ToString().TrimEnd(',');

7. 存储过程变量赋值方式

 DECLARE cnt INT DEFAULT 0;
方式一:
select count(*) into cnt from test_tbl;
方式二:
set @cnt = (select count(*) from test_tbl);
方式三:
select count(*) into @cnt1 from test_tbl;
方式四:
SELECT @Num:= COUNT(*) FROM `tb_class_student_relation`;

8. 拼接字符串的函数CONCATCONCAT_WS

CONCAT:
  CONCAT(str1,str2,…)

  返回结果为连接参数产生的字符串。如有任何一个参数为NULL ,则返回值为 NULL。如果所有参数均为非二进制字符串,则结果为非二进制字符串。 如果自变量中含有任一二进制字符串,则结果为一个二进制字符串。一个数字参数被转化为与之相等的二进制字符串格式;若要避免这种情况,可使用显式类型 cast, 例如: SELECT CONCAT(CAST(int_col AS CHAR), char_col)。

CONCAT_WS:

  CONCAT_WS(separator,str1,str2,…)

  CONCAT_WS() 代表 CONCAT With Separator ,是CONCAT()的特殊形式。 第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是其它参数。如果分隔符为 NULL,则结果为 NULL。函数会忽略任何分隔符参数后的 NULL 值。

注意:CONCAT_WS()不会忽略任何空字符串。(然而会忽略所有的 NULL)。

9. MySQL定时备份

资料:http://www.pc6.com/infoview/Article_53398.html

10. MySQL API

下载

MySQL 一些小知识的更多相关文章

  1. MySQL不常用、易忽略的小知识

    笔者从事开发也有一段时间了,关于数据库方面的一些小知识在这里总结一下 1.count(*),count(1)与count(column)区别 count(*)对行的数目进行计算,包含NULL coun ...

  2. HTML+CSS中的一些小知识

    今天分享一些HTML.CSS的小知识,希望能够对大家有所帮助! 1.解决网页乱码的问题:最重要的是要保证各个环节的字符编码一致! (1)编辑器的编辑环境的字符集(默认字符集):Crtl+U 常见的编码 ...

  3. mysql 索引相关知识

    由where 1 =1 引发的思考 最近工作上被说了 说代码中不能用 where 1=1,当时觉得是应该可以用的,但是找不到什么理据, 而且mysql 语句优化这方面确实很薄弱   感觉自己mysql ...

  4. mysql数据库相关知识

    什么是数据库?                数据库(Database)是按照数据结构来组织.存储和管理数据的建立在计算机存储设备上的仓库.(来自:百度) 什么是sql? 结构化查询语言(Struct ...

  5. MySQL学习基础知识1

    什么是数据库? 数据库就是存储数据的仓库. 存储方式: 变量 无法永久存储 文件处理,可以永久存储,弊端:文件只能在自己的计算机读写,无法被分享(局域网除外) 数据库分类: 1.关系型数据库 提供某种 ...

  6. 简述Python入门小知识

    如今的Python开发工程师很受企业和朋友们的青睐,现在学习Python开发的小伙伴也很多,本篇文章就和大家探讨一下Python入门小知识都有哪些. 扣丁学堂简述Python入门小知识Python培训 ...

  7. python小技巧 小知识

    python小技巧 小知识 python系统变量(修改调用shell命令路径)或用户空间说明 20150418 python调用系统命令,报找不到.怎么办? 类似执行shell的: [ -f /etc ...

  8. MySQL数据库基础知识及优化

    MySQL数据库基础知识及优化必会的知识点,你掌握了多少? 推荐阅读: 这些必会的计算机网络知识点你都掌握了吗 关于数据库事务和锁的必会知识点,你掌握了多少? 关于数据库索引,必须掌握的知识点 目录 ...

  9. 蓝牙Bluetooth技术小知识

    蓝牙Bluetooth技术以及广泛的应用于各种设备,并将继续在物联网IoT领域担任重要角色.下面搜集整理了一些关于蓝牙技术的小知识,以备参考. 蓝牙Bluetooth技术始创于1994年,其名字来源于 ...

随机推荐

  1. input事件以及中文输入法的处理

    在项目的开发过程中,相信大家都处理过监听用户输入的事情,一般我们会用到onkeyup.onkeydown.onkeypress.onchange.oninput事件,虽然都很熟悉了,但是还是有必要巩固 ...

  2. javascript获取标签样式(获取背景为例)

    function getStyle(el){ if(window.getComputedStyle){ return window.getComputedStyle(el,null); } retur ...

  3. Cretiria查询应用(二)

    1.条件查询,动态查询 public void conditionQuery(){ Session session=null; try { session=HibernateUtil.currentS ...

  4. 转载——CLR标量函数、表值函数和聚合函数(UDA)

    本节主要介绍使用CLR创建标量函数,表值函数和聚合函数. 所谓标量函数指的就是此函数只返回一个值.表值函数返回值是一个表.聚合函数是在select语句中使用的,用来聚合一个结果集,类似于Sum()或是 ...

  5. 使用 Intel HAXM 为 Android 模拟器加速,媲美真机(转)

    源:http://www.cnblogs.com/beginor/archive/2013/01/13/2858228.html 慢的问题. Intel HAXM (Hardware Accelera ...

  6. oracle 优化——索引与组合索引

    1.索引结构.第一张图是索引的官方图解,右侧是存储方式的图解. 图中很清晰的展示了索引存储的状况. 在leaf 节点中存储了一列,索引所对应项的 :值,rowId,长度,头信息(控制信息) 这样我们就 ...

  7. 在Ajax中将数组转换成字符串(0517-am)

    一.如何在Ajax中将数组转换成字符串 1. 主页面; <head> <meta http-equiv="Content-Type" content=" ...

  8. php 之 房屋租赁练习(0509)

    做出以下页面并实现其对应的功能: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "h ...

  9. php开发客服系统(持久连接+轮询+反向ajax)

    欢迎在php严程序 - php教程学习AJAX教程, 本节课讲解:php开发客服系统(持久连接+轮询+反向ajax) php开发客服系统(下载源码) 用户端(可直接给客户发送消息)客服端(点击用户名. ...

  10. 认识 web 服务器端脚本语言 PHP

    ---恢复内容开始--- 变量 定义:定义之后,值可以改变的量.PHP中的变量可以先后赋值为不同类型的值. 语法格式:$变量名 = 值; 常量 定义:常量:一旦声明之后,值就不能再改变的量. 语法格式 ...