php脚本来创建一个表,PHP - SQL脚本创建器

我需要的:

一个高效的SQL脚本生成器来替换下面的。

的背景。

一个非常简单的程序,但我需要一个更有效的方式来生成它,我有这个代码的原因是我需要其他开发人员能够在我的平台和数据库表上创建“模块”,但我阻止他们拥有完全访问权限到核心数据库,他们必须使用我的$ api-> database-> access层来访问他们的表/数据。它阻止了对我的程序核心部分的任何请求。

以下是我期望如何使用这些函数来构建SQL创建表脚本。

SqlField类/函数只是返回传递值的平面数组,没有什么特别的。

//The structure of the params are..

//$fields[] = SqlField::create($f_name, $f_type, $null, $auto_inc, $is_pk, $is_unique);

$fields[] = SqlField::create('id', 'int(7)', 0, 1, 1, 1);

$sql = $sqlTable->createTable('MyTableName', $fields );以下是我写得很快的功能,但它很快就变得混乱,而且还没有完成。

public function createTable($tableName, $fields = array()) {

$sql="CREATE TABLE xmod_".$tableName." ( \r\n";

$isinit = true;

foreach($fields as $field) {

$sql .= ($isinit)? "" : ", \r\n" ;

$isinit = false;

$sql .= "".$field[0]." ".$field[1]." ";

if($field[2] == true) {

$sql .= "NOT NULL ";

}

if($field[3] == true) {

$sql .= "auto_increment ";

}

}

$isinit = true;

//Work on the primary keys

foreach($fields as $field) {

if($field[4] == 1) {

$sql .= ($isinit)? "" : ", \r\n" ;

$isinit = false;

$sql .= "PRIMARY KEY (".$field[0].")";

}

}

$isinit = true;

//Work on the unique fields

foreach($fields as $field) {

if($field[5] == 1) {

$sql .= ($isinit)? "" : ", \r\n" ;

$isinit = false;

$sql .= "UNIQUE id (".$field[0].")";

}

}

$sql .= "\r\n )";

return $sql;

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/368111.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

openLayers 4 canvas图例绘制,canvas循环添加图片,解决图片闪烁问题

一、问题来源: 接触Openlayers 一段时间了,最近做了一个农业产业系统,项目中涉及到产业图例,最后考虑用canvas来绘制图例图像。当中带图片的图例移动时,图片会实现闪烁留白情况。闪烁是因为绘制图片本身的复杂性&#…

Akka应用模式:分布式应用程序设计实践指南pdf

下载地址:网盘下载 对于想要学习Akka的Java 和 Scala 开发者们,有很多技术资源可供参考,但是如要想知道如何去应用这些技术就需要不同的思维方式了。为了帮助你正确地使用Akka,《Akka应用模式:分布式应用程序设计实践指…

使用番石榴的5个理由

Guava是一个开放源代码库,其中包含许多Java类,由Google编写。 它是杂项实用程序函数和类的潜在有用来源,我敢肯定,许多开发人员以前已经写过自己,或者只是想要并且从来没有时间编写它们。 这是使用它的5个充分理由&…

哈密尔顿算法matlab,复杂制造过程最优哈密尔顿圈算法的MATLAB仿真与分析.doc

摘要:当今的工业制造过程越来越复杂,产品生产批量化,单个产品组成零部件数量庞大,加工需要多道工序,且工序间连续性强,整个制造过程属于离散制造,这样必然会使生产制造过程复杂化。在这种情况下…

Python 编程核心知识体系(REF)

Python 编程核心知识体系: https://woaielf.github.io/2017/06/13/python3-all/ https://woaielf.github.io/page2/ 转载于:https://www.cnblogs.com/hopesun/p/8340514.html

为input输入框添加圆角并去除阴影

<input type"text" name"bianhao" value"" placeholder"请输入商品编号" maxlength"10" size"10" style"width:105px; margin:0px 0px 0px 12px;height:22px;border-radius:4px;border:1px solid #DBDBD…

flask基础之jinja2模板-语法定义

懂得MVC的人都知道&#xff0c;模型、视图、控制&#xff0c;下面要要介绍的jinja就是视图层的一个渲染模板&#xff0c;类似于jsp&#xff0c;下面来学习 一、jinja2基本语法 jinja2模板可以保存在任何基于文本的文件中&#xff0c;比如XML、HTML、CSV等&#xff0c;所以模板文…

Java DB嵌入式模式

Java DB是基于Java编程语言和SQL的关系数据库管理系统。 这是Apache软件基金会的开源Derby项目的Oracle版本。 Java SE 7 SDK中包含Java DB。 Java DB有两个部署选项&#xff1a; Embedded和Network Server 。 这篇文章是关于嵌入式部署或模式的。 1.嵌入式 在嵌入式模式下&…

php 多线程处理redis,redis的多线程

目录先说明下redis也是多线程的.但是redis的主线程处理业务.而其他三个线程跟主要功能是关系不到的redis的三个线程主要是做什么初始化入口void initServer(void) {...bioInit();...}初始化后redis其他后台线程.void bioInit(void) {pthread_attr_t attr;pthread_t thread;size…

linux内核删不掉,linux 删除内核文件,未能启动,修复方法 CDROM与网络法

当缺少 /boot 内核文件vmlinuz-2….initramfs-2…此时只能借助 光盘 CDROM 来引导生成进入 RESCUE 模式1 chroot /mnt/sysimagemount /dev/cdrom /mnt/cdromcd /mnt/cdromcd isolinux cp vmlinuz /boot/按照…

阿卡vs风暴

我最近在Twitter的Storm上工作了一段时间&#xff0c;这让我想知道&#xff0c;它与另一个高性能的并发数据处理框架Akka相比如何 。 什么是Akka和Storm&#xff1f; 让我们从两个系统的简短描述开始。 Storm是一个分布式实时计算系统。 在Storm集群上&#xff0c;您执行拓扑 …

清除浮动方法解析

清除浮动方法解析 清除浮动带来的额外影响 如果对于浮动不熟悉的同学&#xff0c;可以看看介绍float的文章。传送门&#xff1a;CSS float 我们知道&#xff0c;在一个父元素内如果遇到某个浮动元素&#xff0c;此时父元素的高度会发生塌陷。针对父元素高度塌陷的问题&#xff…

进程间的通信----管道

前提&#xff1a;本文是基于Linux系统下的学习 用户态的进程是如何组织的呢&#xff1f;所有的用户态进构成了一棵树。进程树。 进程树的树根是init.也就是1号进程。是用户态进程的祖宗进程。如何查看进程树&#xff1f;pstree 进程之间的关系 父子进程和兄弟进程查看进程的信息…

web项目启动时,自动执行代码的几种方式

在项目开发过程中&#xff0c;往往需要一些功能随着项目启动而优先启动&#xff0c;下面我总结几种方式&#xff08;非spring boot&#xff09; spring boot的参考 spring boot 学习之路9 (项目启动后就执行特定方法) 方式一&#xff1a; ServletContextListener监听器&#…

设计模式:状态

本文将介绍状态设计模式 。 它是行为设计模式之一 。 您无需了解许多理论即可了解模式的主要概念。 该文章将分为几个部分&#xff0c;在其中我将提供有关需要应用该模式的情况&#xff0c;它所具有的利弊以及用法示例的信息。 有时&#xff0c;当对象的内部状态更改时&#…

Linux内核锁实现原理,linux 大内核锁原理

大内核锁(BKL)的设计是在kernel hacker们对多处理器的同步还没有十足把握时&#xff0c;引入的大粒度锁。他的设计思想是&#xff0c;一旦某个内核路径获取了这把锁&#xff0c;那么其他所有的内核路径都不能再获取到这把锁。自旋锁加锁的对象一般是一个全局变量&#xff0c;大…

Sass学习日志

一、什么是SASS SASS是一中CSS的开发工具&#xff0c;提供了许多便利的写法&#xff0c;大大节约了设计者们的时间&#xff0c;使得CSS的开发&#xff0c;变得简单和可维护。本文总结了SASS的主要方法。我们的目标是&#xff0c;有了这篇文章&#xff0c;日常的一般使用就不需…

ptyhon中文本挖掘精简版

import xlrd import jieba import sys import importlib import os #python内置的包&#xff0c;用于进行文件目录操作&#xff0c;我们将会用到os.listdir函数 import pickle #导入cPickle包并且取一个别名pickle #持久化类 import random import numpy as np …

[UWP]了解模板化控件(9):UI指南

[UWP]了解模板化控件(9)&#xff1a;UI指南 原文:[UWP]了解模板化控件(9)&#xff1a;UI指南1. 使用TemplateSettings统一外观 TemplateSettings提供一组只读属性&#xff0c;用于在新建ControlTemplate时使用这些约定的属性。 譬如&#xff0c;修改HeaderedContentControl的Co…

Java的反射API

如果您曾经问​​过自己以下问题&#xff1a; –“如何在字符串中仅包含其名称的方法调用&#xff1f;” –“如何动态列出类中的所有属性&#xff1f;” –“如何编写一种将任何给定对象的状态重置为默认值的方法&#xff1f;” 然后您可能已经听说过Java的Reflection API…