工作,学习,生活,这里将会有一些记录. 备用域名:http://meisw.wdlinux.cn 注册 | 登陆
浏览模式: 标准 | 列表全部文章

php编译时出libiconv错

/root/php-5.2.12/ext/iconv/iconv.c:2615: undefined reference to `libiconv'
/root/php-5.2.12/ext/iconv/iconv.c:2615: undefined reference to `libiconv'
ext/iconv/.libs/iconv.o:/root/php-5.2.12/ext/iconv/iconv.c:2537: more undefined references to `libiconv' follow
ext/iconv/.libs/iconv.o: In function `php_iconv_stream_filter_ctor':
/root/php-5.2.12/ext/iconv/iconv.c:2491: undefined reference to `libiconv_open'
ext/xmlrpc/libxmlrpc/.libs/encodings.o: In function `convert':
/root/php-5.2.12/ext/xmlrpc/libxmlrpc/encodings.c:73: undefined reference to `libiconv_open'
/root/php-5.2.12/ext/xmlrpc/libxmlrpc/encodings.c:81: undefined reference to `libiconv'
/root/php-5.2.12/ext/xmlrpc/libxmlrpc/encodings.c:101: undefined reference to `libiconv_close'
collect2: ld returned 1 exit status
make: *** [sapi/cli/php] ?.. 1
 
 
处理方法:
./configure ............
 
vi Makefile
找到下面这行:
EXTRA_LIBS = -lcrypt ...
在最后添加-liconv
保存后make通过;make install通过。

Android 固件管理器桌面版

http://zrizhi.com/android-rom-manager-desktop-released.html

制作Android ROM的步骤

制作Android ROM有两种方法:

  • 编译Android源代码的方法,这个比较复杂,以后再介绍;
  • 在已有的ROM基础上制作或者叫定制自己的ROM。

本文介绍的是在已有ROM基础上的定制步骤。

我这里使用的机器是Nexus One,于是下载了第三方的ROM,这里以安卓农夫ROM 2.4为基础。当然也可以用CyanogenMod提供的ROM,实际上安卓农夫的ROM就是在该ROM基础上做的定制。

解压缩ROM,比如安卓农夫ROM 2.4文件名为:

n1_2.4_signed 2.zip

解压缩后,可以看到目录中:

  • boot.img文件,这是系统的镜像,包括Linux内核以及系统启动的一些基本文件。
  • META-INF目录,这里主要有系统更新脚本,路径是:META-INF/com/google/android/updater-script
  • system/app目录,系统自带的应用程序都放在这个目录下,比如日历、联系人、gmail等,你可以把自己的apk文件放在该目录下,这样就可以在刷ROM的时候直接安装上
  • system/bin目录,系统命令,可以通过adb shell登录后执行,比如top
  • system/etc目录,类似linux的/etc目录
  • system/font目录,字体
  • system/framework目录,android框架,是java实现,在dalvik虚拟机下支持用户java开发的框架
  • system/lib目录,android本地共享库,都是so文件,是c、c++编译的本地共享库
  • system/media目录,一些媒体文件,比如bootanimation.zip,压缩包里面是一些png图,用于开机动画,替代这些可以改变开机画面,audio目录下是一些声音文件,用于铃声和通知等

 

其实,本文介绍的定制ROM主要步骤是如何将解开的ROM打包签名,如果只是打包回zip,android是不认的,recovery的时候会在校验ROM包的时候报错。

在将自定义的apk文件放在system/app目录下后,还可以改动比如开机画面,增加自定义铃声,增加命令(在system/bin下)等,然后还是要打包回zip文件。

然后,需要使用签名工具对zip包做签名,签名工具可以在:

http://androidforums.com/developer-101/8665-how-signing-roms.html

下载。需要注册用户登录才能下载。下载的工具是windows下执行的。

运行:

autosign.bat

第一次需要设置CLASS_PATH,将testsign.jar加进去,设置过程很简单,首先要输入2:

image

然后它会猜你的testsign.jar就在当前目录下,因此输入yes:

image

然后选择4,手工输入需要签名的ROM路径,然后输入yes,就可以了:

image

签名过程需要一段时间,需要耐心等待,签名后并不生成新的文件,是通过修改原文件完成的。

编译Android源代码过程中的一些问题解决方法

必要的工具

Git
git版本需在1.5.4之上

sudo pacman -S git             ;archlinux
sudo apt-get install git-core ;debian

Repo
Repo是git命令的Python封装

curl http://android.git.kernel.org/repo > ~/works/bin/repo
chmod a+x ~/works/bin/repo

Python
Python版本应在2.4之上

sudo pacman -S python
sudo apt-get install python

JDK 1.6

sudo pacman -S jdk
sudo apt-get install sun-java5-jdk

然后在~/.bashrc中加入

export ANDROID_JAVA_HOME=$JAVA_HOME

否则在编译过程中可能会出现com.sun.javadoc找不到等错误。

获取Android源代码

1. 初始化要下载的文件列表:

mkdir -p ~/works/android
cd ~/works/android
repo init -u git://android.git.kernel.org/platform/manifest.git

如果想检出除master外其他分支上的代码可以用-b选项:

mkdir -p ~/works/android
cd ~/works/android
repo init -u git://android.git.kernel.org/platform/manifest.git -b cupcake

2. 配置git帐户

git config --global user.email "xxxxx@xxxxxxx"
git config --global user.name "xxxxxx"

3. 同步文件列表:

repo sync

在第一次下载全部代码完成后,可以按模块更新子项目的代码:

repo sync project-path

其中的project-path可以在src/.repo/manifests/default.xml中找到:

<?xml version="1.0" encoding="UTF-8"?>
<manifest>
  <remote  name="korg"
           fetch="git://android.git.kernel.org/"
           review="review.source.android.com" />
  <default revision="master"
           remote="korg" />
 
  <project path="build" name="platform/build">
    <copyfile src="core/root.mk" dest="Makefile" />
  </project>
 
  <project path="kernel"
           name="kernel/common"
           revision="refs/heads/android-2.6.27" />
 
  <project path="bionic" name="platform/bionic" />
 
  <project path="bootable/bootloader/legacy" name="platform/bootable/bootloader/legacy" />
  <project path="bootable/diskinstaller" name="platform/bootable/diskinstaller" />
  <project path="bootable/recovery" name="platform/bootable/recovery" />
  ... ...oject path="build" name="platform/build">
    <copyfile src="core/root.mk" dest="Makefile" />
  </project>
 
  <project path="kernel"
           name="kernel/common"
           revision="refs/heads/android-2.6.27" />
 
  <project path="bionic" name="platform/bionic" />
 
  <project path="bootable/bootloader/legacy" name="platform/bootable/bootloader/legacy" />
  <project path="bootable/diskinstaller" name="platform/bootable/diskinstaller" />
  <project path="bootable/recovery" name="platform/bootable/recovery" />
  ... ...

编译Android源代码

编译映像

cd ~/works/android
make

映像编译成功后会在目录 ~/works/android/out/target/product/generic 下产生一些image文件

ramdisk.img system.img userdata.img android-info.txt

验证,运行这些模块:

export ANDROID_PRODUCT_OUT=/home/yunt/works/android/out/target/product/generic
cd out/host/linux-x86/bin
./emulator

错误处理

java.util.zip.ZipException: duplicate entry: hyts_Foo.c 错误

java.util.zip.ZipException: duplicate entry: hyts_Foo.c
        at java.util.zip.ZipOutputStream.putNextEntry(ZipOutputStream.java:175)
        at java.util.jar.JarOutputStream.putNextEntry(JarOutputStream.java:92)
        at sun.tools.jar.Main.addFile(Main.java:713)
        at sun.tools.jar.Main.update(Main.java:567)
        at sun.tools.jar.Main.run(Main.java:202)
        at sun.tools.jar.Main.main(Main.java:1149)
make: *** [out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar] Error 1
make: *** Deleting file `out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar'

解决办法:
这个问题是hyts_Foo.c文件重复,在根目录查找哪里重复,然后将其删除保留一个

$ find . -name hyts_Foo.c
./libcore/luni/src/test/resources/hyts_Foo.c
./libcore/support/src/test/resources/hyts_Foo.c
$ rm libcore/luni/src/test/resources/hyts_Foo.c

再次 make 即可

java.util.zip.ZipException: duplicate entry: staffNS.xml 错误

java.util.zip.ZipException: duplicate entry: staffNS.xml
        at java.util.zip.ZipOutputStream.putNextEntry(ZipOutputStream.java:175)
        at java.util.jar.JarOutputStream.putNextEntry(JarOutputStream.java:92)
        at sun.tools.jar.Main.addFile(Main.java:713)
        at sun.tools.jar.Main.update(Main.java:567)
        at sun.tools.jar.Main.run(Main.java:202)
        at sun.tools.jar.Main.main(Main.java:1149)
make: *** [out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar] Error 1
make: *** Deleting file `out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar'

解决办法同上

java.util.zip.ZipException: duplicate entry: staff2.dtd 错误

java.util.zip.ZipException: duplicate entry: staff2.dtd
at java.util.zip.ZipOutputStream.putNextEntry(ZipOutputStream.java:175)
at java.util.jar.JarOutputStream.putNextEntry(JarOutputStream.java:92)
at sun.tools.jar.Main.addFile(Main.java:713)
at sun.tools.jar.Main.update(Main.java:567)
at sun.tools.jar.Main.run(Main.java:202)
at sun.tools.jar.Main.main(Main.java:1149)
make: *** [out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar] Error 1
make: *** Deleting file `out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar'

同上

java.util.zip.ZipException: duplicate entry: xhtml1-strict.dtd错误

java.util.zip.ZipException: duplicate entry: xhtml1-strict.dtd
        at java.util.zip.ZipOutputStream.putNextEntry(ZipOutputStream.java:175)
        at java.util.jar.JarOutputStream.putNextEntry(JarOutputStream.java:92)
        at sun.tools.jar.Main.addFile(Main.java:713)
        at sun.tools.jar.Main.update(Main.java:567)
        at sun.tools.jar.Main.run(Main.java:202)
        at sun.tools.jar.Main.main(Main.java:1149)
make: *** [out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar] Error 1
make: *** Deleting file `out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar'

java.util.zip.ZipException: duplicate entry: staff2.xml 错误

java.util.zip.ZipException: duplicate entry: staff2.xml
        at java.util.zip.ZipOutputStream.putNextEntry(ZipOutputStream.java:175)
        at java.util.jar.JarOutputStream.putNextEntry(JarOutputStream.java:92)
        at sun.tools.jar.Main.addFile(Main.java:713)
        at sun.tools.jar.Main.update(Main.java:567)
        at sun.tools.jar.Main.run(Main.java:202)
        at sun.tools.jar.Main.main(Main.java:1149)
make: *** [out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar] Error 1
make: *** Deleting file `out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar'

java.util.zip.ZipException: duplicate entry: hc_staff.xml 错误

java.util.zip.ZipException: duplicate entry: hc_staff.xml
        at java.util.zip.ZipOutputStream.putNextEntry(ZipOutputStream.java:175)
        at java.util.jar.JarOutputStream.putNextEntry(JarOutputStream.java:92)
        at sun.tools.jar.Main.addFile(Main.java:713)
        at sun.tools.jar.Main.update(Main.java:567)
        at sun.tools.jar.Main.run(Main.java:202)
        at sun.tools.jar.Main.main(Main.java:1149)
make: *** [out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar] Error 1
make: *** Deleting file `out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar'

java.util.zip.ZipException: duplicate entry: staff.xml 错误

java.util.zip.ZipException: duplicate entry: staff.xml
        at java.util.zip.ZipOutputStream.putNextEntry(ZipOutputStream.java:175)
        at java.util.jar.JarOutputStream.putNextEntry(JarOutputStream.java:92)
        at sun.tools.jar.Main.addFile(Main.java:713)
        at sun.tools.jar.Main.update(Main.java:567)
        at sun.tools.jar.Main.run(Main.java:202)
        at sun.tools.jar.Main.main(Main.java:1149)
make: *** [out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar] Error 1
make: *** Deleting file `out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar'

java.util.zip.ZipException: duplicate entry: staff.dtd 错误

java.util.zip.ZipException: duplicate entry: staff.dtd
        at java.util.zip.ZipOutputStream.putNextEntry(ZipOutputStream.java:175)
        at java.util.jar.JarOutputStream.putNextEntry(JarOutputStream.java:92)
        at sun.tools.jar.Main.addFile(Main.java:713)
        at sun.tools.jar.Main.update(Main.java:567)
        at sun.tools.jar.Main.run(Main.java:202)
        at sun.tools.jar.Main.main(Main.java:1149)
make: *** [out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar] Error 1
make: *** Deleting file `out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar'

java.util.zip.ZipException: duplicate entry: staffNS.dtd 错误

java.util.zip.ZipException: duplicate entry: staffNS.dtd
        at java.util.zip.ZipOutputStream.putNextEntry(ZipOutputStream.java:175)
        at java.util.jar.JarOutputStream.putNextEntry(JarOutputStream.java:92)
        at sun.tools.jar.Main.addFile(Main.java:713)
        at sun.tools.jar.Main.update(Main.java:567)
        at sun.tools.jar.Main.run(Main.java:202)
        at sun.tools.jar.Main.main(Main.java:1149)
make: *** [out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar] Error 1
make: *** Deleting file `out/target/common/obj/JAVA_LIBRARIES/core-tests_intermediates/javalib.jar'

分享在Linux下编译Android源代码并修改调试系统自带应用的方法

 

下面的内容是在看过了很多的文章还有经过了很多的尝试之后得出的总结, 也作为自己以后可能重复这个过程的笔记.
从哪里引用到的内容都加上链接了.欢迎大家讨论.

首先下载并编译Android源码是必须的, 这就要求你必须要安装Linux, 我自己用的是Ubuntu 11.04,
在虚拟机装Ubuntu的话, 我给1个G的内存而已, 感觉已经是足够了, 不像网上说的需要至少1.5个G,
因为我的内存只有2G,如果分给虚拟机1.5的话,反而会卡得完全动不了.

而且整个过程我都是在root下执行的, 如果不是root, 建议使用sudo -sH来进行以下所有操作.
虽然官方是要求64位的操作系统才能编译, 但是我用的是32位的, 如何修改我会在下文说明.
还有一个问题是只有用Ubuntu 11.04这个特定版本编译的时候才会出现的,不知道会不会在新版的源码已经被修复了,
如果编译的时候出现出现的"field 'arch' has incomplete type"错误可以看我之前的这篇文章:
( http://www.blogjava.net/jayslong/archive/2011/05/12/fix_the_problem_that_android_source_code_wont_compile_in_ubuntu_11_04.html )


具体如何repo获取源码网上到处都是教程,我就不说了.严格按官方的教程来是没问题的.
另外提醒一点,repo的时候用参数 "-j 数字" 可以使用多线程下载.

需要注意的一点的还有很多教程还在说必须用JDK1.5 编译源码, 1.6编译SDK之类的,
其实是已经不需要了, 最新版的Android 只要直接装sun-java6-jdk就好了. (apt-get找不到就更新你的源或者直接去官网下)

然后如果你用的是32位的Linux, 编译之前必须做如下修改: (方法来自: http://blog.csdn.net/yihui8/archive/2011/03/10/6237433.aspx )


.
/external/clearsilver/cgi/Android.mk 
.
/external/clearsilver/java-jni/Android.mk 
.
/external/clearsilver/util/Android.mk 
.
/external/clearsilver/cs/Android.mk

四个文件中的
LOCAL_CFLAGS 
+= -m64 
LOCAL_LDFLAGS 
+= -m64 
注释掉,或者将“
64”换成“32
LOCAL_CFLAGS 
+= -m32 
LOCAL_LDFLAGS 
+= -m32 

   然后,将
.
/build/core/main.mk 中的
ifneq (
64,$(findstring 64,$(build_arch))) 
改为:
ifneq (i686,$(findstring i686,$(build_arch))) 


做完以上修改之后, 就可以开始编译源码了, cd到源码根目录下, 打"make". 然后去看场电影吧. 回来就编好了..
这一步会在android/out/target/product/generic/下面生产3个后缀为img的文件,建议拷贝一份出来吧,
我就遇到过这几个文件莫名消失结果需要重新make的情况.

然后回来如果你愿意的话,再执行一下make sdk. 具体查看这里的第6和第7点吧.
( http://blog.csdn.net/jackyu613/archive/2010/07/31/5778646.aspx )
如果你跟我一样只需要自己修改并编译和测试系统app, 是不需要make sdk这一步的

然后工作之前需要配置一下环境变量:  

gedit ~/.bashrc 注意修改成你自己放源码的路径, 将以下2行添加到文件末尾:

export PATH
=$PATH:/home/xxx/android/out/host/linux-x86/bin
export ANDROID_PRODUCT_OUT
=/home/xxx/android/out/target/product/generic

最后记得执行一下
source ~
/.bashrc


并且在源码根目录下执行一下:

. build/envsetup.sh

会帮你启用几个新的命令.比如下面我们要用到的"mmm"

然后就可以去修改你想要修改的系统app了, 全部都在android/packages下面.
具体修改的例子我会另外写一个文章来说,这次先说整个流程吧.
参考自( http://www.devp.com/home.php?mod=space&uid=11248&do=blog&id=1040 )

比如我修改的是系统的英文输入法, 位于android/packages
修改完后直接在android目录下执行, 指定到包含有Android.mk文件的目录就对了 :

mmm packages/imputmethods/LatinIME/

很快就会编译好了
(千万不要在根目录不加任何参数直接执行"mmm",不然你会后悔的,这等同于之前花了好长时间的"make")

然后就要把编译好的文件安装到模拟器中, 你可以之前就启动了模拟器, 也可以现在才启动, 都可以的,
安装前后也不需要重启模拟器, 执行了adb install 直接可以看到效果.

启动模拟器可以在android/out/target/product/generic/ 下直接执行这个命令:

emulator -image system.img -data userdata.img -ramdisk ramdisk.img

然后用这个命令把自己编译好的apk文件传入模拟器:  

adb install -/home/xxx/android/out/target/product/generic/system/app/***.apk

到这里基本就可以实现整个修改和调试系统app的流程啦,
其实前面都是一劳永逸的环境配置工作,实际上一直要用到的就是mmm和adb install -r 这两个命令而已

因为有些系统app涉及到jni的部分, 在Eclipse下面查看项目是会出错的, 我也不知道怎么实现在Eclipse正常调试,
所以只能是在文本编辑器里直接修改再install到模拟器里查看效果.

auto-sign下载,以及android签名使用方法

使用方法!
安装并配置好JAVA(这个不说了,网上很多!)
将auto-sign解压到任意目录(自己能找到的!)
将改好的包改名为update.zip
并将update.zip 文件复制到签名工具的目录下!
运行Sign.bat
会需要一点时间,过一会,目录下会多出一个update_signed.zip文件!
这个文件就是已经经过签名的刷机包!
比特网论坛将文件复制出来,改成update.zip 就可以用这个包刷机了!
具体改包中的何种文件会达到何种效果以后慢慢说!(我也只知道几个,呵呵)

sign.bat文件内容如下!

  1. @ECHO OFF
  2. Echo Auto-sign Created By Dave Da illest 1
  3. Echo Update.zip is now being signed and will be renamed to update_signed.zip
  4.  
  5. java -jar signapk.jar testkey.x509.pem testkey.pk8 update.zip update_signed.zip
  6.  
  7. Echo Signing Complete
  8.  
  9. Pause
  10. EXIT
复制代码


看完这些,大家应该明白了!
其实,这个命令完全可以再CMD下自己手动打上去。
就是通过signapk.jar testkey.x509.pemtestkey.pk8
这三个文件,将update.zip包签名,并保存为update_signed.zip
两个包的名字其实自己可以随便弄,反正到最后还是要改成update.zip 才能刷的!

php绘图库jpgraph

 jpgraph这个强大的绘图组件能根据你的需要画出任意图形,甚至"aleax的网站访问量统计图"这种也相当简单好画.只要你能提供数据,它就能画图.  简单的说, 画图就像你刚学数据结构时候编写的一些处理数据算法, 而这里只是多了几个调用绘图函数的过程来把处理的数据填进去自动画图.

  除了简单易用, 它还有一个好处: 支持中文。

  先到官方网站下载相应的库,注意有支持php4.*和php5.*两种版本的, 选择合适你的下载,然后先了解一下文件的组织结构最上层目录有doc 和 src 两个文件夹, doc 里面是文档和类库说明, src 是一些配置文件和绘制某一 "图元" 的php文件,注意,我说的"图元"的意思就是它们是一张图的基本组成部分,你完全可以自由组合画出复杂的图形。 src里还有一个example文件夹, 里面有几百个例子,都是相当简单的,我们完全可以不必看文档只要模仿里面的例子就可以快速画出图来。 运行几个图形,挑几个能抓住你眼睛的图形,看一下代码,组合一下功能,就出来了,画图简单到只要五分钟,中文支持就更简单了,内置支持simsun字附,在要图上写中文时SetFont(FF_SIMSUN,FS_BOLD) 就可以了.

  下面是我组合的一个例子,代码很简单,因为数据我没有处理, 这里只演示画图的功能代码 , 当然,填充的数据是很灵活的,可以来自数据库,可以由你重新写算法处理,X轴显示的数据也一样,至于画曲线图,柱图,饼图,还是混合图,就随你选了

    include ("date/jpgraph.php");
    include ("date/jpgraph_line.php");
    include ("date/jpgraph_error.php");
    $datay = array(1,3,13,5,8,6,17,21,15,7,4,1); //填充的数据  
    $graph = new Graph(400,200,"auto");
    $graph->img->SetMargin(35,35,35,35);  
    $graph->img->SetAntiAliasing();
    $graph->SetScale("textlin");
    $graph->SetShadow();
    $graph->title->Set("**曲线图");
    $graph->xaxis->title->Set("$year");
    $graph->xaxis->title->SetFont(FF_SIMSUN,FS_BOLD);
    $graph->yaxis->title->Set("身高(cm)");
    $graph->SetMarginColor("lightblue");
    $graph->yaxis->title->SetFont(FF_SIMSUN,FS_BOLD);
    $graph->title->SetFont(FF_SIMSUN,FS_BOLD);
    $graph->xaxis->SetPos("min");
    $graph->yaxis->HideZeroLabel();
    $graph->ygrid->SetFill(true,'#EFEFEF@0.5','#BBCCFF@0.5');
    $a=array("1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月");//X轴
    $graph->xaxis->SetTickLabels($a);
    $graph->xaxis->SetFont(FF_SIMSUN);
    $graph->yscale->SetGrace(20);    
    $p1 = new LinePlot($datay);
    $p1->mark->SetType(MARK_FILLEDCIRCLE);
    $p1->mark->SetFillColor("red");
    $p1->mark->SetWidth(4);
    $p1->SetColor("blue");
    $p1->SetCenter();
    $graph->Add($p1);
    $graph->Stroke();

http://tech.ddvip.com/2008-10/122449617280389.html

 

-------------------

比如我想让x轴标上time,y轴标上flux

$g   =   new   Graph(500,400);
$g-> xaxis-> title-> Set( "time ");
$g-> yaxis-> title-> Set( "flux ");

 

--------------------

http://www.docin.com/p-113240144.html

http://www.leapsoul.cn/?p=1367

MYSQL子查询的五种形式

mysql从4.1版开始支持子查询功能,在此版本前,可以用join写连表查询来进行替代,但不推荐这么写,相当的麻烦。以下是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,而且经实验证明其执行效率相当不理想,在一般的情况下,还是不推荐是用子查询。