MYSQL子查询的五种形式

mysql从4.1版开始支持子查询功能,在此版本前,可以用join写连表查询来进行替代,但不推荐这么写,相当的麻烦。mysql子查询的几种常见写法:

1. select * from xxx where col = [any|all](select * from xxxx);

该句法可分为加关键词和不加关键词的写法,当不加关键词的时候,子查询语句返回的是一个离散值(注意是一个),查询语句 将以子查询语句的结果作为自 己 where子句的条件进行查询,该句法可以在子查询语句前加入any、all、some等关键字,此时子查询语句返回的是一组离散值。any则表示,查询 语句是以子查询返回的值作为一个范围,在此值范围内进行查询,其与in关键字相像;all关键不太好了解,表示起全部匹配啥的。

2. select * from xxx where col in (select * from xxxx);

该 句法相当的明了,就是查询语句的where子句是以子查询语句的结果作为其范围的,与上一种语法的any相似。

3. select row(value1,value2…..) = [any](selectcol1,col2..);

该语句的执行实质是:子查询语句的执行所得的结果与查询的结果集匹配,若能找到匹配的返回真,否则返回假,并且两边的结果集都是一组离散值。

4. select  …. where col = [not] exists (select……);

该语句比较蹩脚,其执行是这样的:当子查询进行操作,有返回结果的时候,该语句才会执行,而且有多少个结果,语句就执行几次。

5. select …. from (select …..) as name where ……

该句法,在平时用的比较少,而且并不好理解。其实是这么一回事,通过子查询执行的结果来构造一张新的表(这个表是一张衍生数据表,是一张虚拟的表),其用来作为主句的查询的对象,该句法功能非常强大,在一些复杂的查询中会经常用到。

子查询虽然挺方便,但其有不少缺点,其不支持limit,而且经实验证明其执行效率相当不理想,在一般的情况下,还是不推荐是用子查询。

Posted in mysql, 学习笔记 | Tagged , | 2 Comments

壹互联垃圾?团购不搭理人啊…情以何堪_壹互联_壹互联虚拟主机评测

看我购买时间额

 

今天我再次联系那哥…那个说没看见我说话……

 

 

而且态度极其不好…….亲们!!!!千万不要买哦~~~~

 

 

Posted in 工作日志 | Tagged , | 1 Comment

DIRECTORY_SEPARATOR

定义

php的内置变量DIRECTORY_SEPARATOR是一个显示系统分隔符的命令,DIRECTORY_SEPARATORphp的内部常量,不需要任何定义与包含即可直接使用。
说明

 众所周知,在windows下路径分隔符是\(当然/在部分系统上也是可以正常运行的),在linux上路径的分隔符是/,这就导致了一个问题,比如开发机器是windows,有一个图片上传程序,调试机器上指定的上传文件保存目录是:define(‘ROOT’, dirname(__FILE__).”\upload”),在本地调试都很正常,但是上传到linux服务器的时候会发现会出错。
  这个问题就是出在文件的分隔符上,windows上习惯性的使用\作为文件分隔符,但是在linux上人家是不认识这个标识的,人家只认识/,于是就要引入下面这个php内置变量了:DIRECTORY_SEPARATOR
  上面的写法可以改写为以下无错写法:
  define(‘ROOT’, dirname(__FILE__).DIRECTORY_SEPARATOR.”upload”);
  这样就可以确保不会出错了。
  例如discuz里面是这样写的:define(‘S_ROOT’, dirname(__FILE__).DIRECTORY_SEPARATOR);
  回到问题本身上,DIRECTORY_SEPARATOR是一个返回跟操作系统相关的路径分隔符的php内置命令,在windows上返回\,而在linux或者类unix上返回/,就是这么个区别,通常在定义包含文件路径或者上传保存目录的时候会用到。

例子

 const DIR_SEP = DIRECTORY_SEPARATOR;// 路径分割 win下\ linux下/
  private function __construct()
  {
  $this->_options = array(
  ’template_dir’ => ‘templates’ . self::DIR_SEP, //模板文件所在目录
  ’cache_dir’ => ‘templates’ . self::DIR_SEP . ‘cache’ . self::DIR_SEP, //缓存文件存放目录
  ’auto_update’ => false, //当模板文件改动时是否重新生成缓存
  ’cache_lifetime’ => 0, //缓存生命周期(分钟),为 0 表示永久
  ’suffix’ => ‘.html’, //模板文件后缀
  );
  }

Posted in phpopen, 学习笔记 | Tagged , | Leave a comment

C语言的bzero函数介绍

C语言的bzero函数介绍

bzero(将一段内存内容全清为零)
相关函数 memset,swab

表头文件 #include

定义函数 void bzero(void *s,int n);

函数说明 bzero()会将参数s所指的内存区域前n个字节,全部设为零值。相当于调用memset((void*)s,0,size_tn);

返回值

附加说明 建议使用memset取代

范例 参考memset()。

Posted in c语言, 个人收集, 学习笔记 | Tagged , , | Leave a comment

ubuntu12.04下面编译c文件

#include<stdio.h>
int main()
{
   printf("Hello~");
}

存成hello.c
然后用gcc hello.c -o hello;
执行 ./hello
return Hello~;

Posted in c语言, linux, 学习笔记 | Tagged , , , , | 1 Comment