PHP通过(PDO)Mysql表字段一键生成创建sqlite的SQL
首发于: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的更多相关文章
- MySQL 表字段操作
MySQL 表字段操作 一.增加表字段 1)mysql> alter table 二.删除表字段 三.修改表字段
- (转载)根据数据字典表定义的表结构,生成创建表的SQL语句
<来源网址:http://www.delphifans.com/infoview/Article_221.html>根据数据字典表定义的表结构,生成创建表的SQL语句 //1. 类名:T ...
- 一段完整的创建表格的SQL代码
一段完整的创建表格的SQL代码 使用SQL语句创建一张表,不仅可以可以快速熟悉SQL语句,还可以从这看出一个人对该技能点的熟悉程度. 这里先说明几点: PRIMARY KEY:主键,一张表中只允许有一 ...
- 做网站-mysql表字段设计
https://mp.weixin.qq.com/s/HhdbmQqKmiw9IVnnL0Zyag VARCHAR与CHAR如何选择 使用VARCHAR理由 字段不经常更新 字段比较长,且长度不均(比 ...
- Java之数据库表字段有关键字报错java.sql.SQLSyntaxErrorException
前两天在开发中遇到一个坑,本来我在快乐的做着增删改查,然后悲剧发生了,在查询数据库的过程中,报了java.sql.SQLSyntaxErrorException: 经过排查,是因为数据库表字段中存在关 ...
- Mysql表字段命令alter add
alter add命令用来增加表的字段. alter add命令格式:alter table 表名 add字段 类型 其他; 例如,在表MyClass中添加了一个字段passtest,类型为int(4 ...
- MySQL 表字段唯一性约束设置方法unique
1. 建表时加上唯一性约束 CREATE TABLE `t_user` ( `Id` int(11) NOT NULL AUTO_INCREMENT, -- 自增 `username` varchar ...
- mysql 表字段不能使用type???
type 字段 可能跟系统内置字段有冲突吧
- C#读取MySql表字段出现System.Byte[]问题
记录下,用了多字段拼接后在程序中查询出的结果为System.Byte[],而在数据库中查正常 解决办法为:加Convert转换编码 select CONVERT((CASE background ...
随机推荐
- SAP生产订单状态
SAP系统的常见订单状态如下: · CRTD (创建):标识生产订单刚刚创建,此时禁止做后续发料和报工确认等操作: · PREL (部分下达):当生产订单部分下达时,如仅下 ...
- iframe框架自适应高度 uncanght SecurityError: Blocked a frame with origin "null" from accessing a frame ....
来源于crm项目的contact/edit.html 一.背景是这样的 最近在做crm系统的前端页面,有一个页面呢,点击“查看全部信息”时会弹出,这个弹窗里面又有分页导航,分页不是使用ajax 异步刷 ...
- iOS 状态栏、导航栏、工具栏、选项卡大小
1.状态栏状态栏一般高度为20像素,在打手机或者显示消息时会放大到40像素高,注意,两倍高度的状态栏在好像只能在纵向的模式下使用.如下图用户可以隐藏状态栏,也可以将状态栏设置为灰色,黑色或者半透明的黑 ...
- UITableView cell中label自动换行和自定义label自动换行
换行的前提必须是有足够的高度 才能换 否则不显示超出部分 所以,在设置label换行的时候 要考虑cell的高度,cell的高度也要变化,废话不多说,来段代码: cell.label.text=[di ...
- win10系统调用架构分析
http://blog.csdn.net/liuyez123/article/details/50992038
- <BEA-141281> <unable to get file lock, will retry ...> --reference
I ran into this error the first time I restarted Weblogic on one of my installs, the only reference ...
- 从cmd中进入MySQL的命令界面
两种方式进入mysql命令界面 第一.直接开始界面→搜索mysql客户端登陆界面 第二.从cmd中进入MySQL的命令界面 2010-05-17 10:02:05| 分类: mysql|字号 订阅 ...
- 使用CocoaPods遇到的几个坑,记录一下
最近使用pod的时候升级到1.0.0版本后遇到一些坑,整理一下 首先是CocoaPods报错:The dependency `` is not used in any concrete target ...
- Python 学习开发笔记之IO操作
文件或者目录的路径操作 获取当前工作目录 import os import sys cwd = os.getcwd() 路径的拼接 os.path.join(path,"dir") ...
- JUnit4简要说明
单元测试(unit testing),是指对软件中的最小可测试单元进行检查和验证. 开发者编写一小段代码,用于检验被测代码的一个很小的.很明确的功能是否正确. 通常而言,一个单元测试是用于判断某个特定 ...