如何通过PHP安装数据库并使数据初始化

 更新时间:2024年03月25日 10:02:56   作者:下页、再停留  
这篇文章主要介绍了如何通过PHP安装数据库并使数据初始化,其实原理就是通过构建原生SQL来创建并初始化数据库,连接数据库、创建数据库、使用数据库、创建数据表、新增数据、关闭连接,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧

一、前言

有些CMS在部署的时候不用使用数据库工具,而是通过数据库安装页面就能完成数据库创建和数据填充,所以自己就想动手做一个这样的功能,这样在给别人安装系统的时候就不用再那么麻烦了,直接一键安装解决了。

二、效果图

输入数据库相关信息后,点击安装并有不同的提示。

三、核心代码

原理:其实就是通过构建原生SQL来创建并初始化数据库,连接数据库、创建数据库、使用数据库、创建数据表、新增数据、关闭连接。

创建前首先要准备以下内容:

① 准备数据库的基本信息:数据库地址、数据库名称、用户名、密码

② 要创建的表及表结构

③ 要初始化的数据

public function createDb($data)
{
	$host = $data['mysqlHostname'];
	$user = $data['mysqlUsername'];
	$pwd = $data['mysqlPassword'];
	$db = $data['mysqlDatabase'];
	// 1.连接数据库
	$conn = mysqli_connect($host, $user, $pwd);
	if (!$conn) {
		// echo "1/7 数据库连接失败<br/><br/>";
		return '1/7 数据库连接失败';
	}else{
		// echo "1/7 数据库连接完成<br/><br/>";
	}
	// 2.创建数据库
	// 先删除再创建
	$sql = "DROP DATABASE {$db}";
	if (mysqli_query($conn, $sql)) {
	 // echo "2/7 数据库删除完成<br/>";
	}else{
		// echo "2/7". mysqli_error($conn)."<br/><br/>";
		// return "2/7 ".mysqli_error($conn);
	}
	// 创建
	$sql = "create database {$db}";
	if (mysqli_query($conn, $sql)) {
	 // echo "2/7 数据库创建完成<br/>";
	}else{
		// echo "2/7". mysqli_error($conn)."<br/><br/>";
		return "2/7 ".mysqli_error($conn);
	}
	// 3.使用数据表
	// echo "3/7 选择数据库开始...<br/>";
	$sql = "use {$db}";
	mysqli_query($conn,$sql);
	// echo "3/7 选择数据库完成<br/><br/>";
	// 4.检查数据库是否存在
	// echo "4/7 检测数据库开始...<br/>";
	$sql = "DROP TABLE IF EXISTS `dic_s_use`";
	mysqli_query($conn,$sql);
	// echo "4/7 检测数据库完成<br/><br/>";
	// 5.创建数据表  批量创建
	// echo "5/7 创建数据表开始...<br/>";
	// dic_s_use 表
	$sql = "CREATE TABLE `dic_s_use`  (
		  `id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 'ID',
		  `s_use` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '特殊用法',
		  `hospital_code` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '机构/医院代码',
		  `status` enum('0','1') CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT '1' COMMENT '状态:1=正常,0=禁用',
		  PRIMARY KEY (`id`) USING BTREE
		) ENGINE = MyISAM AUTO_INCREMENT = 1 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '特殊用法' ROW_FORMAT = Dynamic";
	if (mysqli_query($conn,$sql)) {
		// echo "5/7 数据表[dic_s_use]创建成功<br/>";
	}else{
		// echo "5/7 数据表[dic_s_use]创建失败".mysqli_error($conn)."<br/>";
		return "5/7 数据表[dic_s_use]创建失败".mysqli_error($conn);
	}
	// 6.添加数据
	// echo "6/7 添加数据开始...<br/>";
	// dic_s_use 表
	$insert_use = "(null, '另煎', 'ceshi', '1'),
					(null, '先煎', 'ceshi', '1'),
					(null, '后下', 'ceshi', '1'),
					(null, '包煎', 'ceshi', '1'),
					(null, '烊化', 'ceshi', '1'),
					(null, '冲服', 'ceshi', '1'),
					(null, '煎服', 'ceshi', '1')";
	$sql = "INSERT INTO `dic_s_use` VALUES {$insert_use}";
	if (mysqli_query($conn,$sql)) {
		// echo "6/7 数据表[dic_s_use]数据导入成功<br/>";
	}else{
		// echo "6/7 数据表[dic_s_use]数据导入失败".mysqli_error($conn)."<br/>";
		return "6/7 数据表[dic_s_use]数据导入失败".mysqli_error($conn);
	}
	// 7.关闭连接
	// echo "7/7 数据库关闭连接开始...<br/>";
	mysqli_close($conn);
	// echo "7/7 数据库关闭连接完成<br/><br/><br/>";
	return '200';
	// echo "安装数据库完成<br/>";
}

到此这篇关于通过PHP安装数据库并使数据初始化的文章就介绍到这了,更多相关PHP数据初始化内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • PHP中的密码加密的解决方案总结

    PHP中的密码加密的解决方案总结

    很多用户多个网站使用一个密码,当一个密码丢失其他也遭殃,本篇文章介绍了PHP中的密码加密的解决方案总结,有需要的朋友可以了解一下。
    2016-10-10
  • Laravel中unique和exists验证规则的优化详解

    Laravel中unique和exists验证规则的优化详解

    这篇文章主要给大家介绍了关于Laravel中unique和exists验证规则的优化的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2018-01-01
  • 基于 Swoole 的微信扫码登录功能实现代码

    基于 Swoole 的微信扫码登录功能实现代码

    随着微信的普及,扫码登录方式越来越被现在的应用所使用。它因为不用去记住密码,只要有微信号即可方便快捷登录.这里基于微信公众平台的带参数临时二维码,并且结合 Swoole 的 WebSocket 服务实现扫码登录
    2018-01-01
  • Swoole webSocket消息服务系统压力测试解析

    Swoole webSocket消息服务系统压力测试解析

    这篇文章主要为大家介绍了Swoole webSocket消息服务系统压力测试解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • php对数字进行万、亿单位的转化

    php对数字进行万、亿单位的转化

    在本篇文章里小编给大家整理了一篇关于php对数字进行万、亿单位的转化,有需要的朋友们可以跟着学习下。
    2021-08-08
  • PHP Header失效的原因分析及解决方法

    PHP Header失效的原因分析及解决方法

    下面小编就为大家带来一篇PHP Header失效的原因分析及解决方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-11-11
  • php file_get_contents函数轻松采集html数据

    php file_get_contents函数轻松采集html数据

    PHP手册里是这么解释的:file_get_contents — 将整个文件读入一个字符串,于是可以很容易的获取其他站的信息,再用正则加以变换,再做一些判断和设定,就OK了,不多说了,放代码,我基本都做了解释的。
    2010-04-04
  • 微信随机生成红包金额算法php版

    微信随机生成红包金额算法php版

    这篇文章主要为大家详细介绍了php版的微信随机生成红包金额算法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-07-07
  • 一次项目中Thinkphp绕过禁用函数的实战记录

    一次项目中Thinkphp绕过禁用函数的实战记录

    这篇文章主要给大家介绍了一次项目中Thinkphp绕过禁用函数的实战记录,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2021-11-11
  • laravel框架学习笔记之组件化开发实现方法

    laravel框架学习笔记之组件化开发实现方法

    这篇文章主要介绍了laravel框架学习笔记之组件化开发实现方法,结合实例形式分析了laravel框架组件化开发相关的实现步骤与操作注意事项,需要的朋友可以参考下
    2020-02-02

最新评论