首发于:http://www.zzzzy.com/201406053158.html

       /**
      * Mysql表字段一键生成创建sqlite的SQL 2      * @author: Skiychan <contact@zzzzy.com>
      * $db 数据库
      * $tbname 表名
      * $is_blob 需要保存的图片二进制数组 array("img1","img2","img3")形式,默认为false
      * $retbname 自定义生成sqlite的表名
      * return SQL的语句形式
      */

     public function creat_sqlite($db, $tbname, $is_blob = false, $retbname = false){

         $runsql1 = $db->query("SELECT * FROM `$tbname` limit 1");
         $fields_rows = $runsql1->columnCount();

         $tb_fields_info = array();
         $tb_string = "";
         $dot = "";

         for ($i = 0; $i < $fields_rows; $i++) {
             if ($i == 1) {
                 $dot = ", ";
             }

             $tb_meta = $runsql1->getColumnMeta($i);
             $tb_string .= $dot.$tb_meta['name'];
             //var_dump($tb_meta);

             //如果存在数据且字段存在需要取消的字段中
             if ($is_blob && in_array($tb_meta['name'], $is_blob)) {
                 $tb_string .= " "."blob";
             } else {
                 //如果不需要保存为二进制
                 switch($tb_meta['native_type']){
                     case "VAR_STRING":
                         $tb_string .= " "."varchar";
                         break;

                     case "LONG":
                         $tb_string .= " "."integer";
                         break; 

                     case "BLOB":
                         $tb_string .= " "."text";
                         break;
                     case "TINY":
                         $tb_string .= " "."smallint";
                         break;
                 }
             }

             if (isset($tb_meta['flags'][1]) && ($tb_meta['flags'][1] === "primary_key")) {
                 $tb_string .= " "."PRIMARY KEY";
             }

             if (isset($tb_meta['flags'][0]) && ($tb_meta['flags'][0] === "not_null")) {
                 $tb_string .= " "."NOT NULL";
             }    

             //var_dump($tb_meta);
         }

         //生成的sqlite表名
         $retbname = $retbname == true ? $retbname : $tbname;

         //创建数据的SQL语句
         $creat_data = "CREATE TABLE  IF NOT EXISTS {$retbname} ($tb_string);";  

         return $creat_data;
     }

PHP通过(PDO)Mysql表字段一键生成创建sqlite的SQL的更多相关文章

  1. MySQL 表字段操作

    MySQL 表字段操作 一.增加表字段 1)mysql> alter table 二.删除表字段 三.修改表字段

  2. (转载)根据数据字典表定义的表结构,生成创建表的SQL语句

    <来源网址:http://www.delphifans.com/infoview/Article_221.html>根据数据字典表定义的表结构,生成创建表的SQL语句 //1.  类名:T ...

  3. 一段完整的创建表格的SQL代码

    一段完整的创建表格的SQL代码 使用SQL语句创建一张表,不仅可以可以快速熟悉SQL语句,还可以从这看出一个人对该技能点的熟悉程度. 这里先说明几点: PRIMARY KEY:主键,一张表中只允许有一 ...

  4. 做网站-mysql表字段设计

    https://mp.weixin.qq.com/s/HhdbmQqKmiw9IVnnL0Zyag VARCHAR与CHAR如何选择 使用VARCHAR理由 字段不经常更新 字段比较长,且长度不均(比 ...

  5. Java之数据库表字段有关键字报错java.sql.SQLSyntaxErrorException

    前两天在开发中遇到一个坑,本来我在快乐的做着增删改查,然后悲剧发生了,在查询数据库的过程中,报了java.sql.SQLSyntaxErrorException: 经过排查,是因为数据库表字段中存在关 ...

  6. Mysql表字段命令alter add

    alter add命令用来增加表的字段. alter add命令格式:alter table 表名 add字段 类型 其他; 例如,在表MyClass中添加了一个字段passtest,类型为int(4 ...

  7. MySQL 表字段唯一性约束设置方法unique

    1. 建表时加上唯一性约束 CREATE TABLE `t_user` ( `Id` int(11) NOT NULL AUTO_INCREMENT, -- 自增 `username` varchar ...

  8. mysql 表字段不能使用type???

    type 字段 可能跟系统内置字段有冲突吧

  9. C#读取MySql表字段出现System.Byte[]问题

     记录下,用了多字段拼接后在程序中查询出的结果为System.Byte[],而在数据库中查正常 解决办法为:加Convert转换编码   select CONVERT((CASE background ...

随机推荐

  1. easyui datebox 扩展清空按钮及日期判断

    <input id="EndHavDate" class="easyui-datebox" data-options="prompt:'请选择结 ...

  2. Linux centOS下搭建RTMP服务器的具体步骤

    以下的所需的安装包,可直接在linux系统终端下载,也可从其他地方下载之后拷到对应目录下解压使用,遇到连接不到国外网站时可改变压缩包地址 1.安装依赖包: #yum install glibc.i68 ...

  3. Java集合系列:-----------04fail-fast总结(通过ArrayList来说明fail-fast的原理以及解决办法)

    前面,我们已经学习了ArrayList.接下来,我们以ArrayList为例,对Iterator的fail-fast机制进行了解.内容包括::1 fail-fast简介2 fail-fast示例3 f ...

  4. python2.7到python3代码转换脚本2to3的一些介绍

       你的位置: Home ‣ Dive Into Python 3 ‣ 难度等级: ♦♦♦♦♦   使用2to3将代码移植到Python 3 ❝ Life is pleasant. Death is ...

  5. 一篇不错的讲解Java异常的文章(转载)

    http://www.blogjava.net/freeman1984/archive/2007/09/27/148850.html 六种异常处理的陋习 你觉得自己是一个Java专家吗?是否肯定自己已 ...

  6. 【转】perl特殊符号及默认的内部变量

    perl特殊符号及默认的内部变量,有需要的朋友不妨参考下 Perl的特殊符号 @       数组                          $x{}   x名字前面是美元符号($),后面是花 ...

  7. BITMAP图片压缩算法三则--bilinear、nearest、cubic

    原文:http://blog.chinaunix.net/uid-253932-id-3037805.html 工作需要,要弄截图且缩小.截图倒是好说,WIN API可以搞定,但是缩小且尽量不失真,这 ...

  8. 关于 永恒之蓝 和 MS17-010 补丁

    [KB4012598]:http://www.catalog.update.microsoft.com/Search.aspx?q=KB4012598 适用于Windows XP 32位/64位/嵌入 ...

  9. 「九省联考 2018」IIIDX 解题报告

    「九省联考 2018」IIIDX 这什么鬼题,送的55分要拿稳,实测有60? 考虑把数值从大到小摆好,每个位置\(i\)维护一个\(f_i\),表示\(i\)左边比它大的(包括自己)还有几个数可以选 ...

  10. IBGP规划

    在IBGP邻居中,使用反射器减少IBGP邻居关系是一种最常用的网络结构,在上图中AS65001中有6台路由器,其中,R1和R2是一组反射器,配置如下: R1: ! interface Loopback ...