摘要:系統(tǒng)默認(rèn)集成了很多開發(fā)工具其中就包括所需要的一些軟件工具下面我們將搭建最簡單的開發(fā)環(huán)境每一步都會驗證上一步的操作結(jié)構(gòu)請一步一步跟我一起搭建吧服務(wù)器之是一款服務(wù)器用于運行文件除了外也可以是服務(wù)器默認(rèn)情況下已經(jīng)預(yù)裝了服務(wù)自然不用服務(wù)器了現(xiàn)在什么
Mac 系統(tǒng)默認(rèn)集成了很多開發(fā)工具,其中就包括 php 所需要的一些軟件工具.
下面我們將搭建最簡單的 php 開發(fā)環(huán)境,每一步都會驗證上一步的操作結(jié)構(gòu),請一步一步跟我一起搭建吧!
web 服務(wù)器之 apacheapache 是一款 web 服務(wù)器,用于運行 php 文件,除了 apache 外也可以是 nginx 服務(wù)器.
默認(rèn)情況下 mac 已經(jīng)預(yù)裝了 apach 服務(wù),自然不用 nginx 服務(wù)器了.
現(xiàn)在什么也沒有配置的情況下,直接啟動 apache 服務(wù)器看一下能否正常運行.
$ sudo apachectl start常用命令
查看 apache 版本
語法: apachectl -v
示例:
$ apachectl -v Server version: Apache/2.4.34 (Unix) Server built: Feb 22 2019 19:30:04
啟動 apache 服務(wù)
語法: sudo apachectl start
示例:
$ sudo apachectl start Password:
停止 apache 服務(wù)
語法: sudo apachectl stop
示例:
$ sudo apachectl stop
重啟 apache 服務(wù)
語法: sudo apachectl restart
示例:
$ sudo apachectl restart安裝路徑
apache 默認(rèn)安裝于 /private/etc/apache2 目錄,屬于系統(tǒng)隱藏目錄,可以在終端中直接進(jìn)入也可以在訪達(dá)中直接前往文件夾.
示例:
$ tree /private/etc/apache2 /private/etc/apache2 ├── extra │?? ├── httpd-autoindex.conf │?? ├── httpd-autoindex.conf~previous │?? ├── httpd-dav.conf │?? ├── httpd-dav.conf~previous │?? ├── httpd-default.conf ├── httpd.conf ├── httpd.conf.pre-update ├── httpd.conf~previous ├── magic ├── mime.types ├── original │?? ├── extra │?? │?? ├── httpd-autoindex.conf │?? │?? ├── httpd-dav.conf │?? │?? ├── httpd-default.conf │?? │?? ├── httpd-vhosts.conf │?? │?? └── proxy-html.conf │?? └── httpd.conf ├── other │?? └── php7.conf └── users └── Guest.conf 5 directories, 43 files
如果想要修改項目部署路徑以及服務(wù)器端口等自定義配置,可打開 /private/etc/apache2/httpd.conf 文件進(jìn)行編輯,如果權(quán)限不足,要么提升權(quán)限要么復(fù)制到別處修改好再替換掉原來的配置文件.
配置文件一旦修改,請一定要重啟服務(wù)器,不然并不會生效!
vim 搜索文件內(nèi)容時臨時高亮設(shè)置: :set hlsearch ,取消高亮設(shè)置: :set nohlsearch .
修改項目部署路徑
DocumentRoot : 默認(rèn)部署路徑于 /Library/WebServer/Documents
終端輸入 vim 命令查找并編輯目標(biāo)節(jié)點.
$ vim /private/etc/apache2/httpd.conf
輸入 vim /private/etc/apache2/httpd.conf 進(jìn)入命令行模式,輸入 :/DocumentRoot 從頭搜索文件內(nèi)容,緊接著輸入 n 表示查找下一項匹配字符,N 表示查找上一項匹配內(nèi)容.
如果不熟悉 vim 語法也可以選擇熟悉的編輯器打開 httpd.conf 配置文件進(jìn)行修改配置.
修改項目部署端口
Listen : 默認(rèn)監(jiān)聽端口 80
如果端口沖突的話,可以修改成其他端口,80 端口的好處在于可以直接訪問服務(wù)器地址而不用顯示帶上端口號.
# 等價于 http://localhost:80 http://localhost # 等價于 http://127.0.0.1:80 http://127.0.0.1部署路徑
默認(rèn)情況下,apache 的部署路徑位于 /Library/WebServer/Documents ,除非你更改了 httpd.conf#DocumentRoot 的節(jié)點配置.
$ tree /Library/WebServer/Documents /Library/WebServer/Documents ├── PoweredByMacOSX.gif ├── PoweredByMacOSXLarge.gif ├── index.html.en └── index.html.en~orig 0 directories, 4 files
當(dāng)然你可以通過訪達(dá)直接前往 /Library/WebServer/Documents 目錄或者 open /Library/WebServer/Documents 直接調(diào)用內(nèi)置程序打開目錄.
如果非要一步一步找到部署路徑,打開 訪達(dá) 后選擇左側(cè)最下方的本地光盤(個人用戶名稱),然后依次選擇 Machintosh HD > 資源庫 (Library) > WebServer > Documents世界上最好的語言之 php
php 在行業(yè)內(nèi)贏得"世界上最好的語言"稱號,自嘲為"拍簧片".不管怎樣,既然我們決定 pai(拍)huang(簧)pian(片) ,那總要配置一下 php 的基本環(huán)境吧!
Mac 系統(tǒng)一如既往內(nèi)置了 php 環(huán)境,不用我們費心去安裝 php 了,現(xiàn)在看一下 php 的基本信息吧!
$ php -version PHP 7.1.23 (cli) (built: Feb 22 2019 22:08:13) ( NTS ) Copyright (c) 1997-2018 The PHP Group Zend Engine v3.1.0, Copyright (c) 1998-2018 Zend Technologies
php 是一種服務(wù)端腳本解釋性語言,依賴于 web 服務(wù)器進(jìn)行解析,所以 php 想要正常工作離不開上一步配置的 apache 服務(wù)器.
還記得 apache 配置文件的位置嗎?
apache 配置文件路徑 : /private/etc/apache2/httpd.conf
打開 httpd.conf 配置文件并搜索 LoadModule php 字符串,將前面的 # 去掉即可引入 php 支持,配置文件修改后記得重啟才能生效喲!
是時候展示真正的技術(shù)了,現(xiàn)在萬事俱備只待測試 php 到底有沒有配置成功?!
在項目部署根目錄下新建 info.php 測試文件,啟動服務(wù)器后訪問 [
http://localhost/info.php](
http://localhost/info.php) 如果能正常打印出 php 相關(guān)信息,那就證明 php 和 apache 整合無誤,否則可能是某一步配置有誤!
Mac 系統(tǒng)并沒有默認(rèn)安裝 mysql 服務(wù),因此我們需要手動安裝 mysql .
一般來說,我們談到 mysql 數(shù)據(jù)庫指的是 mysql 的服務(wù)端,作為生產(chǎn)環(huán)境服務(wù)端足夠了并不需要客戶端.
但是,日常開發(fā)中如果沒有客戶端我們很難直觀管理數(shù)據(jù),所以一般來說,我們還會安裝 mysql 客戶端,當(dāng)然一般是各種功能強大的圖形化工具.
mysql 服務(wù)端下載鏈接: macOS 10.14 (x86, 64-bit), DMG Archive
和正常的軟件安裝一樣,將安裝文件移動到應(yīng)用里即可完成,比 Windows 的下一步下一步安裝還要方便快捷!
安裝完成后,可以在系統(tǒng)偏好設(shè)置中找到 MySQL 圖標(biāo),查看管理 mysql 服務(wù)端.
點擊 MySQL 圖標(biāo),可以進(jìn)行簡單的設(shè)置以及重啟服務(wù)等操作.
但是如果想要在終端中無痛連接上 mysql 服務(wù)端,那么還需要一步設(shè)置軟鏈接,類似于 Windows 的快捷方式.
$ sudo ln -fs /usr/local/mysql/bin/mysql /usr/local/bin/mysql
現(xiàn)在我們就可以在終端內(nèi)愉快的連接上 mysql 服務(wù)端了呢!
# 登錄 `mysql` 服務(wù)端 $ mysql -u root -p Enter password: Welcome to the MySQL monitor. Commands end with ; or g. Your MySQL connection id is 29 Server version: 5.7.24 MySQL Community Server (GPL) Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type "help;" or "h" for help. Type "c" to clear the current input statement. # 查看當(dāng)前數(shù)據(jù)庫列表 mysql> show databases; +---------------------+ | Database | +---------------------+ | information_schema | | mysql | | performance_schema | | security-plus | | sys | | test | +---------------------+ 6 rows in set (0.00 sec) # 退出當(dāng)前數(shù)據(jù)庫會話 mysql> exit Bye $
查看 mysql 服務(wù)端版本
語法: mysql --version
示例:
$ mysql --version mysql Ver 14.14 Distrib 5.7.24, for macos10.14 (x86_64) using EditLine wrapper
查看 mysql 服務(wù)端狀態(tài)
語法: sudo /usr/local/mysql/support-files/mysql.server status
示例:
$ sudo /usr/local/mysql/support-files/mysql.server status SUCCESS! MySQL running (73088)
啟動 mysql 服務(wù)端
語法: sudo /usr/local/mysql/support-files/mysql.server start
示例:
$ sudo /usr/local/mysql/support-files/mysql.server start Starting MySQL . SUCCESS!
停止 mysql 服務(wù)端
語法: sudo /usr/local/mysql/support-files/mysql.server stop
示例:
$ sudo /usr/local/mysql/support-files/mysql.server stop Shutting down MySQL .. SUCCESS!
重啟 mysql 服務(wù)端
語法: sudo /usr/local/mysql/support-files/mysql.server restart
示例:
$ sudo /usr/local/mysql/support-files/mysql.server restart Shutting down MySQL . SUCCESS! Starting MySQL . SUCCESS!mysql 客戶端
如果說生產(chǎn)環(huán)境沒有 mysql 的圖形化工具也就罷了,但是如果日常開發(fā)時也不沒有圖形化工具的話,那就真的太不方便了.
這里推薦兩個客戶端工具,一個是人畜無害的 Sequel Pro,另一個則是 php 專屬的 phpMyAdmin.
BS 架構(gòu)的 phpMyAdmin
下載地址 : phpMyAdmin
phpMyAdmin 是一款 web 版數(shù)據(jù)款管理軟件,可以在瀏覽器中在線訪問,像訪問你的網(wǎng)站一樣訪問數(shù)據(jù)庫.
下載完成后解壓并重命名為 phpMyAdmin,然后移動到 apache 的項目部署路徑下,如果沒有更改過默認(rèn)的部署路徑,那么應(yīng)該是 /Library/WebServer/Documents 目錄.
現(xiàn)在部署路徑下不僅有個 info.php 文件還有 phpMyAdmin 文件夾.
# 僅僅顯示兩級文件目錄 $ tree -L 2 . ├── PoweredByMacOSX.gif ├── PoweredByMacOSXLarge.gif ├── index.html.en ├── index.html.en~orig ├── info.php └── phpMyAdmin ├── CODE_OF_CONDUCT.md ├── CONTRIBUTING.md ├── export.php ├── favicon.ico ├── gis_data_editor.php ├── import.php ├── import_status.php ├── index.php ├── view_operations.php └── yarn.lock 11 directories, 108 files
移動完成后先復(fù)制一份 config.sample.inc.php 文件并重命名為 config.inc.php 文件.
執(zhí)行 vim /Library/WebServer/Documents/phpMyAdmin/config.inc.php 搜索并編輯 host 節(jié)點內(nèi)容,將 localhost 更改成 127.0.0.1 .
示例:
# 修改前 $cfg["Servers"][$i]["host"] = "localhost"; # 修改后: 將 `localhost` 更改成 `127.0.0.1` $cfg["Servers"][$i]["host"] = "127.0.0.1";
重啟 apache 服務(wù),訪問 http://localhost/phpMyAdmin/ 開始登陸數(shù)據(jù)庫吧!
輸入 mysql 的用戶名和密碼登錄成功后就能管理本地數(shù)據(jù)庫了.
CS 架構(gòu)的 Sequel Pro
下載地址 : v1.1.2 OS X 10.6 or Higher
Sequel Pro 是簡單易用的數(shù)據(jù)庫管理工具,與上述的 phpMyAdmin 不同之處在于并不依賴 php 環(huán)境,可以獨立安裝部署.
安裝完成后輸入數(shù)據(jù)庫連接信息連接到本地數(shù)據(jù)庫,參考信息如下.
點擊連接(Connect) 連接到本地服務(wù)器,由于剛才并沒有選擇數(shù)據(jù)庫,因此登陸后需要選定數(shù)據(jù)庫,這里根據(jù)實際情況選擇即可.
php 集成 mysql如果沒有數(shù)據(jù)庫提供持久化存儲能力,那么 php 只能臨時運行而沒有記憶功能,所以想要記住網(wǎng)站大量信息自然離不開數(shù)據(jù)庫.
準(zhǔn)備數(shù)據(jù)為了接下來演示 php 集成 mysql 數(shù)據(jù)庫,現(xiàn)在先創(chuàng)建一個測試數(shù)據(jù)庫并插入一些測試數(shù)據(jù).
下面主要是通過終端方式進(jìn)行操作,小伙伴們也可以使用上述安裝的圖形化工具進(jìn)行可視化編輯.
連接到本地服務(wù)器
語法 : mysql -u-p
示例:
# 連接到本地數(shù)據(jù)庫,用戶名 `root`,密碼自定義 $ mysql -u root -p Enter password: Welcome to the MySQL monitor. Commands end with ; or g. Your MySQL connection id is 109 Server version: 5.7.24 MySQL Community Server (GPL) Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type "help;" or "h" for help. Type "c" to clear the current input statement.
列出當(dāng)前數(shù)據(jù)庫列表
語法 : show databases
示例:
mysql> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | mysql | | performance_schema | | security-plus | | sys | +--------------------+ 5 rows in set (0.00 sec)
創(chuàng)建測試數(shù)據(jù)庫
語法 : create database
示例:
# 創(chuàng)建 `test` 數(shù)據(jù)庫并指定編碼格式為 `utf8` mysql> create database IF NOT EXISTS test default charset utf8 COLLATE utf8_general_ci; Query OK, 1 row affected (0.00 sec) # 再次查詢當(dāng)前數(shù)據(jù)庫列表,新增 `test` 數(shù)據(jù)庫 mysql> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | mysql | | performance_schema | | security-plus | | sys | | test | +--------------------+ 6 rows in set (0.00 sec)
列出當(dāng)前數(shù)據(jù)表列表
語法 : show tables
示例:
# 使用 `test` 測試數(shù)據(jù)庫 mysql> use test; Database changed # 列出當(dāng)前全部數(shù)據(jù)表 mysql> show tables; Empty set (0.00 sec)
創(chuàng)建測試數(shù)據(jù)表
語法 : create tabel( ))
# 創(chuàng)建 `user` 用戶表 mysql> CREATE TABLE `test`.`user` ( `id` BIGINT(11) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT "用戶 id", `name` VARCHAR(45) NOT NULL DEFAULT "" COMMENT "姓名", PRIMARY KEY (`id`), UNIQUE INDEX `id_UNIQUE` (`id` ASC)) ENGINE = InnoDB DEFAULT CHARACTER SET = utf8 COMMENT = "用戶表"; Query OK, 0 rows affected (0.01 sec) # 再次列出當(dāng)前數(shù)據(jù)表列表 mysql> show tables; +----------------+ | Tables_in_test | +----------------+ | user | +----------------+ 1 row in set (0.00 sec)
查看數(shù)據(jù)表結(jié)構(gòu)
語法 : desc
示例:
mysql> desc user; +-------+---------------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+---------------------+------+-----+---------+----------------+ | id | bigint(11) unsigned | NO | PRI | NULL | auto_increment | | name | varchar(45) | NO | | | | +-------+---------------------+------+-----+---------+----------------+ 2 rows in set (0.00 sec)
查看數(shù)據(jù)表創(chuàng)建語句
語法 : show create table
示例:
mysql> show create table user G *************************** 1. row *************************** Table: user Create Table: CREATE TABLE `user` ( `id` bigint(11) unsigned NOT NULL AUTO_INCREMENT COMMENT "用戶 id", `name` varchar(45) NOT NULL DEFAULT "" COMMENT "姓名", PRIMARY KEY (`id`), UNIQUE KEY `id_UNIQUE` (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT="用戶表" 1 row in set (0.00 sec)
查詢數(shù)據(jù)
語法 : select [fields] from tableName [where condition] [limit N][ offset M]
示例:
mysql> select id,name from user; Empty set (0.00 sec)
插入數(shù)據(jù)
語法 : insert into([fields]) VALUES ([values])
示例:
mysql> INSERT INTO `test`.`user` (`name`) VALUES ("snowdreams1006"); Query OK, 1 row affected (0.00 sec) mysql> INSERT INTO `test`.`user` (`name`) VALUES ("雪之夢技術(shù)驛站"); Query OK, 1 row affected (0.00 sec) mysql> INSERT INTO `test`.`user` (`name`) VALUES ("測試用戶姓名"); Query OK, 1 row affected (0.00 sec) mysql> select id,name from user; +----+-----------------------+ | id | name | +----+-----------------------+ | 1 | snowdreams1006 | | 2 | 雪之夢技術(shù)驛站 | | 3 | 測試用戶姓名 | +----+-----------------------+ 3 rows in set (0.00 sec)
退出數(shù)據(jù)庫
語法 : exit
示例:
mysql> exit Bye $
導(dǎo)出數(shù)據(jù)
語法 : mysqldump -u-p > exportName.sql
備份數(shù)據(jù)用到的是 mysqldump 工具,默認(rèn)情況下該命令位于 /usr/local/mysql/bin 目錄下,正常情況下需要指定該路徑才能調(diào)用 mysqldump 命令.
$ tree /usr/local/mysql/bin /usr/local/mysql/bin ├── innochecksum ├── lz4_decompress ├── my_print_defaults ├── myisam_ftdump ├── myisamchk ├── mysql ├── mysql_client_test_embedded ├── mysql_config ├── mysqlbinlog ├── mysqlcheck ├── mysqld ├── mysqld-debug ├── mysqld_multi ├── mysqld_safe ├── mysqldump ├── resolveip └── zlib_decompress 0 directories, 38 files
所以,應(yīng)該是如下命令才能調(diào)用 mysqldump 命令.
$ /usr/local/mysql/bin/mysqldump --version mysqldump Ver 10.13 Distrib 5.7.24, for macos10.14 (x86_64)
不過這也太長了吧,肯定不是很不變,一勞永逸的方法是將 /usr/local/mysql/bin 加入到環(huán)境變量中就不用添加額外的路徑信息了.
還記得 mysql 服務(wù)端剛安裝完畢,我們想要通過終端連接到本地數(shù)據(jù)庫服務(wù)器時設(shè)置了 mysql 的軟鏈接,所以才能直接使用 mysql -u root -p 進(jìn)行登錄.
mac 的軟鏈接方式相當(dāng)于 windows 系統(tǒng)的快捷方式,只針對具體命令,現(xiàn)在需要 mysqldump 命令,繼續(xù)使用軟鏈接還要添加類似的快捷方式.
$ sudo ln -fs /usr/local/mysql/bin/mysql /usr/local/bin/mysql $ sudo ln -fs /usr/local/mysql/bin/mysqldump /usr/local/bin/mysqldump
實測可用,但是這并不是優(yōu)雅的操作方式,/usr/local/mysql/bin/ 目錄下那么多命令,下次需要用到其他命令豈不是要設(shè)置很多軟鏈接?
$ mysqldump --version mysqldump Ver 10.13 Distrib 5.7.24, for macos10.14 (x86_64)
所以,現(xiàn)在我們考慮將 /usr/local/mysql/bin 加入到系統(tǒng)環(huán)境變量中,這樣一來就能一勞永逸不用頻繁設(shè)置軟鏈接了!
# mysql export PATH=$PATH:/usr/local/mysql/bin
設(shè)置完畢后下次重啟電腦就會生效,或者運行下述命令立即生效.
$ source ~/.bash_profile
為了測試環(huán)境變量是否生效,我們先刪除原來的軟鏈接.
$ rm -rf /usr/local/bin/mysql $ rm -rf /usr/local/bin/mysqldump
依然能夠正常調(diào)用 mysql 相關(guān)命令.
# `mysql` 版本信息 $ mysql --version mysql Ver 14.14 Distrib 5.7.24, for macos10.14 (x86_64) using EditLine wrapper # `mysqldump` 版本信息 $ mysqldump --version mysqldump Ver 10.13 Distrib 5.7.24, for macos10.14 (x86_64)
示例:
$ mysqldump -u root -p test > database_test.sql; Enter password: $
注意 : mysqldump 和 mysql 相互獨立的命令行程序,并不是在 mysql 會話中執(zhí)行的 sql.
查看當(dāng)前備份文件內(nèi)容:
# 備份文件位于當(dāng)前目錄 $ cat $(pwd)/database_test.sql
備份 sql 文件內(nèi)容,可以直接復(fù)制執(zhí)行.
-- MySQL dump 10.13 Distrib 5.7.24, for macos10.14 (x86_64) -- -- Host: localhost Database: test -- ------------------------------------------------------ -- Server version 5.7.24 /*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */; /*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */; /*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */; /*!40101 SET NAMES utf8 */; /*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */; /*!40103 SET TIME_ZONE="+00:00" */; /*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */; /*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */; /*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE="NO_AUTO_VALUE_ON_ZERO" */; /*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */; -- -- Table structure for table `user` -- DROP TABLE IF EXISTS `user`; /*!40101 SET @saved_cs_client = @@character_set_client */; /*!40101 SET character_set_client = utf8 */; CREATE TABLE `user` ( `id` bigint(11) unsigned NOT NULL AUTO_INCREMENT COMMENT "用戶 id", `name` varchar(45) NOT NULL DEFAULT "" COMMENT "姓名", PRIMARY KEY (`id`), UNIQUE KEY `id_UNIQUE` (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 COMMENT="用戶表"; /*!40101 SET character_set_client = @saved_cs_client */; -- -- Dumping data for table `user` -- LOCK TABLES `user` WRITE; /*!40000 ALTER TABLE `user` DISABLE KEYS */; INSERT INTO `user` VALUES (1,"snowdreams1006"),(2,"雪之夢技術(shù)驛站"),(3,"測試用戶姓名"); /*!40000 ALTER TABLE `user` ENABLE KEYS */; UNLOCK TABLES; /*!40103 SET TIME_ZONE=@OLD_TIME_ZONE */; /*!40101 SET SQL_MODE=@OLD_SQL_MODE */; /*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */; /*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */; /*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */; /*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */; /*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */; /*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */; -- Dump completed on 2019-05-19 12:49:35
導(dǎo)入數(shù)據(jù)
語法 : source
示例:
# 創(chuàng)建 `test_import` 數(shù)據(jù)庫 mysql> create database test_import; # 使用 `test_import` 數(shù)據(jù)庫 mysql> use test_import; # 導(dǎo)入 `database_test.sql` 文件 mysql> source /Users/sunpo/Documents/workspace/snowdreams1006.github.io/database_test.sql
刪除數(shù)據(jù)庫
語法 : drop database
示例:
mysql> drop database test_import; Query OK, 1 row affected (0.01 sec)編程連接
如果沒有更改過項目的部署路徑,那么我們之前有個測試 php 環(huán)境的文件,即 /Library/WebServer/Documents/info.php ,現(xiàn)在我們繼續(xù)編寫該文件,通過編碼的方式連接到 mysql 數(shù)據(jù)庫.
set_charset("utf8"); if(mysqli_connect_error()){ echo "連接失敗: " . mysqli_connect_error(); exit; } # 查詢用戶列表 $result = $db->query("SELECT id,name FROM user"); if ($result->num_rows > 0) { // 輸出數(shù)據(jù) while($row = $result->fetch_assoc()) { echo var_dump($row). "
"; } } # 關(guān)閉數(shù)據(jù)庫連接 $db->close(); phpinfo(); ?>
現(xiàn)在再次啟動 apache 服務(wù)器,訪問 http://localhost/info.php 測試成功!
環(huán)境搭建要點總結(jié)apache 服務(wù)默認(rèn)已安裝,啟動服務(wù)器后,在瀏覽器中訪問 http://localhost/ 會顯示It works!,表明 apache 能正常使用.
查看 apache 服務(wù)器版本 : apachectl -v
啟動 apache 服務(wù)器 : sudo apachectl start
停止 apache 服務(wù)器 : sudo apachectl stop
重啟 apache 服務(wù)器 : sudo apachectl restart
apache 服務(wù)器安裝路徑 : /private/etc/apache2
apache 服務(wù)器部署路徑 : /Library/WebServer/Documents
php 服務(wù)默認(rèn)已安裝,集成到 apache 服務(wù)器只需要在 /private/etc/apache2/httpd.conf 配置文件中啟用 LoadModule php7_module libexec/apache2/libphp7.so 模塊即可,重啟 apache 服務(wù)器即可支持 php 環(huán)境.
查看 php 版本信息 : php -version
php 默認(rèn)配置文件路徑 : /private/etc/php.ini.default
mysql 數(shù)據(jù)庫默認(rèn)沒有安裝,需要手動前往 https://www.mysql.com/downloads/ 官網(wǎng)進(jìn)行下載安裝.
如果需要在終端命令行內(nèi)訪問 mysql 服務(wù)端,最好將 mysql 的安裝路徑添加到系統(tǒng)環(huán)境中,或者添加軟鏈接也可以.
mysql 安裝路徑 : /usr/local/mysql
系統(tǒng)環(huán)境變量路徑 : ~/.bash_profile
mysql 二進(jìn)制文件添加到系統(tǒng)環(huán)境變量 : export PATH=$PATH:/usr/local/mysql/bin
刷新系統(tǒng)環(huán)境變量配置 : source ~/.bash_profile
mysql 命令添加軟鏈接 : sudo ln -fs /usr/local/mysql/bin/mysql /usr/local/bin/mysql
查看 mysql 版本信息 : mysql --version
查看 mysql 服務(wù)器狀態(tài) : mysql.server status
啟動 mysql 服務(wù)器 : mysql.server start
停止 mysql 服務(wù)器 : mysql.server stop
重啟 mysql 服務(wù)器 : mysql.server restart
登錄 mysql 服務(wù)器 : mysql -u root -p
退出 mysql 服務(wù)器 : exit
最后,php 不僅僅可以面向過程也可以面向?qū)ο?雖然是拍簧片,但真的很強大,魅力不小呢!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/31526.html
摘要:系統(tǒng)默認(rèn)集成了很多開發(fā)工具其中就包括所需要的一些軟件工具下面我們將搭建最簡單的開發(fā)環(huán)境每一步都會驗證上一步的操作結(jié)構(gòu)請一步一步跟我一起搭建吧服務(wù)器之是一款服務(wù)器用于運行文件除了外也可以是服務(wù)器默認(rèn)情況下已經(jīng)預(yù)裝了服務(wù)自然不用服務(wù)器了現(xiàn)在什么 Mac 系統(tǒng)默認(rèn)集成了很多開發(fā)工具,其中就包括 php 所需要的一些軟件工具. 下面我們將搭建最簡單的 php 開發(fā)環(huán)境,每一步都會驗證上一步的操...
平日學(xué)習(xí)接觸過的網(wǎng)站積累,以每月的形式發(fā)布。2017年以前看這個網(wǎng)址:http://www.kancloud.cn/jsfron... 03月份前端資源分享 1. Javascript 175453545 Redux compose and middleware 源碼分析 深入 Promise(二)——進(jìn)擊的 Promise Effective JavaScript leeheys blog -...
平日學(xué)習(xí)接觸過的網(wǎng)站積累,以每月的形式發(fā)布。2017年以前看這個網(wǎng)址:http://www.kancloud.cn/jsfron... 03月份前端資源分享 1. Javascript 175453545 Redux compose and middleware 源碼分析 深入 Promise(二)——進(jìn)擊的 Promise Effective JavaScript leeheys blog -...
閱讀 2128·2021-09-06 15:02
閱讀 1748·2021-08-13 15:02
閱讀 2309·2019-08-29 14:14
閱讀 1472·2019-08-26 13:55
閱讀 556·2019-08-26 13:46
閱讀 3407·2019-08-26 11:41
閱讀 522·2019-08-26 10:27
閱讀 3271·2019-08-23 15:28