php导入sql文件
sql php
php导入sql文件
基本思路
1.打开sql文件,放入一个变量(字符串类型)其中
2.使用正则替换掉其中的凝视(“--”与“/**/”)
3.使用explode切割成为一个数组并去除每行的空格
4.链接数据库之后使用my_query()运行sql
代码
<?php// +------------------------------------------------------------------------------------------// | Author: longDD <longdd_love@163.com>// +------------------------------------------------------------------------------------------// | There is no true,no evil,no light,there is only power.// +------------------------------------------------------------------------------------------// | Description: import sql Dates: 2014-08-07// +------------------------------------------------------------------------------------------class ImportSql{/** @var $content 数据库连接 */protected $connect = null;/** @var $db 数据库对象 */protected $db = null;/** @var $sqlFile sql文件 */public $sqlFile = "";/** @array @sqlArr sql语句数组 */public $sqlArr = array();/*** 构造函数** @param string $host 主机地址* @param string $user username* @param string $pw password* @param $db_name 数据库名称* @return void*/public function __construct($host, $user, $pw, $db_name){/** 连接数据库 */$this->connect = mysql_connect($host, $user, $pw) or die("Could not connect: " . mysql_error());/** 选中数据库 */$this->db = mysql_select_db($db_name, $this->connect) or die("Yon can not select the table:" . mysql_error());}/*** 导入sql文件** @param string $url 文件路径* @return true 导入成返回true*/public function Import($url){if(!file_exists($url)){exit("文件不存在! ");}$this->sqlFile = file_get_contents($url);if (!$this->sqlFile){exit("打开文件错误! ");}else{$this->GetSqlArr();if ($this->Runsql()){return true;}}}/*** 获取sql语句数组** @return void*/public function GetSqlArr(){/** 去除凝视 */$str = $this->sqlFile;$str = preg_replace('/--.*/i', '', $str);$str = preg_replace('/\/\*.*\*\/(\;)?/i', '', $str);/** 去除空格 创建数组 */$str = explode(";\n", $str);foreach ($str as $v){$v = trim($v);if (empty($v)){continue;}else{$this->sqlArr[] = $v;}}}/*** 运行sql文件** @return true 运行成功返回true*/public function RunSql(){/** 开启事务 */if (mysql_query('BEGIN')){foreach ($this->sqlArr as $k => $v){if (!mysql_query($v)){/** 回滚 */mysql_query('ROLLBACK');exit("sql语句错误:第" . $k . "行" . mysql_error());}}/** 提交事务 */mysql_query('COMMIT');return true;}else{exit('无法开启事务! ');}}}// +------------------------------------------------------------------------------------------// | End of ImportSql class// +------------------------------------------------------------------------------------------/*** This is a example.*/header("Content-type:text/html;charset=utf-8");$sql = new ReadSql("localhost", "root", "", "log_db");$rst = $sql->Import("./log_db.sql");if ($rst){echo "Success。";}// +------------------------------------------------------------------------------------------// | End of file ImportSql.php// +------------------------------------------------------------------------------------------// | Location: ./ImportSql.php// +------------------------------------------------------------------------------------------
php导入sql文件的更多相关文章
- Linux环境导入*.sql文件出现数据库为空
登录mysql命令: 导入.sql文件: 或者: mysql -h127.0.0.1 -uroot -p userDb < /home/user.sql 按回车键后输数据库的密码 导入成功后, ...
- WampServer数据库导入sql文件
WampServer中MySQL如何导入sql文件: http://jingyan.baidu.com/article/3c343ff7f9c7940d377963c0.html
- 向mysql workbench中导入.sql文件
mysql workbench用的不多,前段时间装了一下,然后用了一下,感觉操作比dbdesigner4要更人性化一点.其中二个方面做了改进,让我觉得很爽. 第一,就是端口可以修改了,以前就是定死33 ...
- 命令行导入SQL文件
摘要:把数据库导出为XX.sql格式的数据库文件,导入到另外一个数据库中的时候,总是无法全部导入.及时用mysql的命令界面导入依然是无法全部导入.老师告诉我:在命令行中运行的效率和成功率是最快和最高 ...
- mysql 启动 导入sql文件
mysql mysqld.exe mysqld.exe 是mysql的服务器进程,只有先启动这个进程才能连接服务器 dos下进入mysql文件目录下的bin目录,输入mysql -u root -p ...
- MYSQL 编码方式 ------导入 .sql 文件 报编码错误
在做计量泵上位机时,利用MYSQL存储数据,建表hisruninfo(计量泵历史运行数据表). 表格式为utf8,查过数据库 格式 同样为utf8 导入该hisruninfo.sql文件时,并没有报错 ...
- mysql导入.sql文件
1. source /home/susie ...../**.sql 2. \. /home/susie/.../**.sql 批量导入.sql文件 首先新建一个main.sql,然后在main.sq ...
- MySQL导入sql 文件的5大步骤
http://database.51cto.com/art/201005/200739.htm 以下的文章主要介绍的是MySQL导入sql 文件,即MySQL数据库导入导出sql 文件的实际操作步骤, ...
- mysql数据库导入sql文件时提示“Error Code: 1153 - Got a packet bigger than 'max_allowed_packet' bytes”解决办法
向mysql数据库中导入sql文件时,如果文件过大(几百M),会提示"Error Code: 1153 - Got a packet bigger than 'max_allowed_pac ...
- navicat导入.sql文件
用Navicat for Mysql导入.sql文件 虽然这算不上什么难事,但是对于新手来说(比如说我),Navicat for MySQL里的导出连接.运行SQL文件.导入向导.还原备份.这些功 ...
随机推荐
- 3CSS基本语法
------------------------- --------------------------------------- -------------------------------- & ...
- 6.11---字节输入流数据根据字节输出流存到文件中---io流概念及分类---文件存储的原理和记事本打开的原理---字节流读取文件的原理---文件复制的原理
- 一、CSS的基础样式
CSS的基础样式 border 边框 复合写法 border:border-width border-style border-color: border-width:边框宽度 top right ...
- centos7下手动制作trove镜像
获取镜像 [root@bldattet1 ~]# wget http://mirrors.aliyun.com/centos/7.5.1804/isos/x86_64/CentOS-7-x86_64 ...
- servlet-响应信息的content-Type作用
package servlet; import java.io.File; import java.io.FileInputStream; import java.io.IOException; im ...
- python web 开发学习路线
转载,备着 自己目前学习python web 开发, 经过两个月的摸索,目前对web开发有了浅显的认识,把自己的学习过程贴出来.1.python入门推荐老齐<从零开始学python>,&l ...
- (转)Quartz任务调度(1)概念例析快速入门
http://blog.csdn.net/qwe6112071/article/details/50991563 Quartz框架需求引入 在现实开发中,我们常常会遇到需要系统在特定时刻完成特定任务的 ...
- js post一个对象 在C#中怎么接收? 未解决
这个在C#中怎么接收?
- Python 之__slots__的作用
# 注意:__slots__ 用来限制当前类的实例属性的,如:name.age才可被使用,添加其他的属性则报错 # 不会限制继承类的属性 class Person(): __slots__ = (&q ...
- Java报表统计导出Word-xdocin方式
官网:http://www.xdocin.com Controller层: //创建对象 XDocService xdocService = new XDocService(); //封装参数 Map ...