摘要:數(shù)據(jù)庫(kù)抽象層是底層組件,由它驅(qū)動(dòng)框架中的模型層。它完全由語(yǔ)言編寫,是一個(gè)獨(dú)立的數(shù)據(jù)庫(kù)高級(jí)抽象層。使用任何數(shù)據(jù)庫(kù)適配器,數(shù)據(jù)都會(huì)被自動(dòng)轉(zhuǎn)義。配合使用,可以在數(shù)據(jù)庫(kù)抽象層上提供日志記錄功能。語(yǔ)法因數(shù)據(jù)庫(kù)而異。并非所有數(shù)據(jù)庫(kù)系統(tǒng)都允許修改列或
數(shù)據(jù)庫(kù)抽象層(Database Abstraction Layer)
PhalconDb是PhalconMvcModel底層組件,由它驅(qū)動(dòng)框架中的模型層。它完全由C語(yǔ)言編寫,是一個(gè)獨(dú)立的數(shù)據(jù)庫(kù)高級(jí)抽象層。
與傳統(tǒng)模型相比,該組件允許更底層的數(shù)據(jù)庫(kù)操作。
數(shù)據(jù)庫(kù)適配器(Database Adapters)該組件使用適配器來封裝特定的數(shù)據(jù)庫(kù)操作。Phalcon使用PDO連接數(shù)據(jù)庫(kù),支持下列數(shù)據(jù)庫(kù)引擎:
類 | 說明 |
---|---|
PhalconDbAdapterPdoMysql | 世界上最流行的關(guān)系型數(shù)據(jù)庫(kù)系統(tǒng)(RDBMS),作為服務(wù)器運(yùn)行,支持多用戶、多數(shù)據(jù)庫(kù)訪問 |
PhalconDbAdapterPdoPostgresql | Postgresql是一個(gè)強(qiáng)大的開源關(guān)系數(shù)據(jù)庫(kù)系統(tǒng),超過15年的發(fā)展和通過驗(yàn)證的架構(gòu),為其贏得了正確、可靠、數(shù)據(jù)完整的良好聲譽(yù) |
PhalconDbAdapterPdoSqlite | SQLite是一個(gè)實(shí)現(xiàn)自包含、無服務(wù)、零配置的事務(wù)型數(shù)據(jù)庫(kù) |
使用適配器選項(xiàng)加載PDO:
"localhost", "dbname" => "blog", "port" => 3306, "username" => "sigma", "password" => "secret", "adapter" => "mysql", ]; $db = Factory::load($options);自定義適配器(Implementing your own adapters)
創(chuàng)建自定義數(shù)據(jù)庫(kù)適配器或擴(kuò)展現(xiàn)有適配器,必須實(shí)現(xiàn)PhalconDbAdapterInterface接口。
數(shù)據(jù)庫(kù)語(yǔ)言(Database Dialects)phalcon語(yǔ)言封裝了每個(gè)數(shù)據(jù)庫(kù)的具體操作,為適配器提供通用方法和SQL生成器。
類 | 說明 |
---|---|
PhalconDbDialectMysql | MySQL特定語(yǔ)言 |
PhalconDbDialectPostgresql | Postgresql特定語(yǔ)言 |
PhalconDbDialectSqlite | SQLite特定語(yǔ)言 |
創(chuàng)建自定義數(shù)據(jù)庫(kù)語(yǔ)言或擴(kuò)展現(xiàn)有語(yǔ)言,必須實(shí)現(xiàn)PhalconDbDialectInterface接口。
連接數(shù)據(jù)庫(kù)(Connection to Databases)建立數(shù)據(jù)庫(kù)連接,必須實(shí)例化適配器類,它只接收一個(gè)包含連接參數(shù)的數(shù)組。下面例子展示了如何傳遞必選參數(shù)和可選參數(shù)來建立數(shù)據(jù)庫(kù)連接:
"127.0.0.1", "username" => "mike", "password" => "sigma", "dbname" => "test_db", ]; // 可選參數(shù) $config["persistent"] = false; // 建立連接 $connection = new PhalconDbAdapterPdoMysql($config);
"localhost", "username" => "postgres", "password" => "secret1", "dbname" => "template", ]; // 可選參數(shù) $config["schema"] = "public"; // 建立連接 $connection = new PhalconDbAdapterPdoPostgresql($config);設(shè)置額外的PDO選項(xiàng)(Setting up additional PDO options)
在建立連接時(shí),傳遞options參數(shù)設(shè)置PDO:
"localhost", "username" => "root", "password" => "sigma", "dbname" => "test_db", "options" => [ PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES UTF8", PDO::ATTR_CASE => PDO::CASE_LOWER, ], ] );使用工廠類連接數(shù)據(jù)庫(kù)(Connecting using Factory)
使用一個(gè)簡(jiǎn)單的ini文件來配置 / 連接數(shù)據(jù)庫(kù)。
[database] host = TEST_DB_MYSQL_HOST username = TEST_DB_MYSQL_USER password = TEST_DB_MYSQL_PASSWD dbname = TEST_DB_MYSQL_NAME port = TEST_DB_MYSQL_PORT charset = TEST_DB_MYSQL_CHARSET adapter = mysql
set("config", $config); $di->set( "db", function () { return Factory::load($this->config->database); } );
上述代碼返回?cái)?shù)據(jù)庫(kù)連接實(shí)例,這樣做的好處是可以在不修改應(yīng)用代碼的情況下改變數(shù)據(jù)庫(kù)連接甚至是數(shù)據(jù)庫(kù)適配器。
查詢記錄(Finding Rows)PhalconDb提供了多種查詢方法。這種情況下,SQL必須遵循數(shù)據(jù)庫(kù)引擎的特定語(yǔ)法:
query($sql); // 打印robot的name字段 while ($robot = $result->fetch()) { echo $robot["name"]; } // 獲取結(jié)果集數(shù)組 $robots = $connection->fetchAll($sql); foreach ($robots as $robot) { echo $robot["name"]; } // 獲取結(jié)果集中的第一條記錄 $robot = $connection->fetchOne($sql);
默認(rèn)情況下,調(diào)用這些方法會(huì)返回一個(gè)數(shù)組(關(guān)聯(lián)+索引)??梢哉{(diào)用PhalconDbResult::setFetchMode()方法改變這種行為,該方法接收一個(gè)常量值,定義返回結(jié)果集的類型:
常量 | 說明 |
---|---|
PhalconDb::FETCH_NUM | 返回索引數(shù)組 |
PhalconDb::FETCH_ASSOC | 返回關(guān)聯(lián)數(shù)組 |
PhalconDb::FETCH_BOTH | 返回?cái)?shù)組(索引+關(guān)聯(lián)) |
PhalconDb::FETCH_OBJ | 返回對(duì)象 |
query($sql); $result->setFetchMode(PhalconDb::FETCH_NUM); while ($robot = $result->fetch()) { echo $robot[0]; }
PhalconDb::query()方法返回一個(gè)PhalconDbResultPdo實(shí)例。該對(duì)象封裝了與返回結(jié)果集相關(guān)的所有功能,如遍歷、查找特定行、統(tǒng)計(jì)總行數(shù)等。
query($sql); // 遍歷結(jié)果集 while ($robot = $result->fetch()) { echo $robot["name"]; } // 查找第三行 $result->seek(2); $robot = $result->fetch(); // 計(jì)算總行數(shù) echo $result->numRows();參數(shù)綁定(Binding Parameters)
PhalconDb支持參數(shù)綁定。使用參數(shù)綁定會(huì)影響性能,但可以防止SQL注入。
支持字符串和數(shù)字占位符,參數(shù)綁定可以簡(jiǎn)單的實(shí)現(xiàn)如下:
query( $sql, [ "Wall-E", ] ); // 字符串占位符 $sql = "INSERT INTO `robots`(name, year) VALUES(:name, :year)"; $success = $connection->query( $sql, [ "name" => "Astro Boy", "year" => 1952, ] );
使用數(shù)字占位符時(shí),需要將它們定義為數(shù)字值(如1或2),"1"或"2"會(huì)被視為字符串而非數(shù)字,導(dǎo)致占位符不能被成功替換。使用任何數(shù)據(jù)庫(kù)適配器,數(shù)據(jù)都會(huì)被Pdo::Quote()自動(dòng)轉(zhuǎn)義。該方法會(huì)考慮到連接字符集,因此建議在連接選項(xiàng)或服務(wù)器配置中定義正確的字符集,錯(cuò)誤的字符集會(huì)在存儲(chǔ)或檢索數(shù)據(jù)時(shí)產(chǎn)生不良影響。
此外,可以將參數(shù)直接傳遞給execute() / query()方法,這種情況下的綁定參數(shù)會(huì)直接傳遞給PDO:
query( $sql, [ 1 => "Wall-E", ] );特定類型占位符(Typed Placeholders)
占位符允許執(zhí)行參數(shù)綁定以避免SQL注入:
:id:"; $robots = $this->modelsManager->executeQuery( $phql, [ "id" => 100, ] );
某些數(shù)據(jù)庫(kù)系統(tǒng)在使用占位符時(shí)需要執(zhí)行額外操作,如指定綁定參數(shù)的類型:
modelsManager->executeQuery( $phql, [ "number" => 10, ], Column::BIND_PARAM_INT );
可以在參數(shù)中使用類型化的占位符,而不用在executeQuery()方法中指定:
modelsManager->executeQuery( $phql, [ "number" => 10, ] ); $phql = "SELECT * FROM StoreRobots WHERE name <> {name:str}"; $robots = $this->modelsManager->executeQuery( $phql, [ "name" => $name, ] );
如果不需要指定綁定參數(shù)類型,可以省略:
{name}"; $robots = $this->modelsManager->executeQuery( $phql, [ "name" => $name, ] );
類型化的占位符很強(qiáng)大,我們可以綁定靜態(tài)數(shù)組,而無需將每個(gè)參數(shù)作為占位符多帶帶傳遞:
modelsManager->executeQuery( $phql, [ "ids" => [1, 2, 3, 4], ] );
支持下列類型:
綁定類型 | 綁定類型常量 | 示例 |
---|---|---|
str | Column::BIND_PARAM_STR | {name:str} |
int | Column::BIND_PARAM_INT | {number:int} |
double | Column::BIND_PARAM_DECIMAL | {price:double} |
bool | Column::BIND_PARAM_BOOL | {enabled:bool} |
blob | Column::BIND_PARAM_BLOB | {image:blob} |
null | Column::BIND_PARAM_NULL | {exists:null} |
array | Column::BIND_PARAM_STR數(shù)組 | {codes:array} |
array-str | Column::BIND_PARAM_STR數(shù)組 | {names:array} |
array-int | Column::BIND_PARAM_INT數(shù)組 | {flags:array} |
默認(rèn)情況下,綁定參數(shù)不會(huì)在PHP中轉(zhuǎn)換為指定類型,
如,在LIMIT / OFFSET中給占位符傳遞一個(gè)字符串值就會(huì)導(dǎo)致錯(cuò)誤:
executeQuery( "SELECT * FROM SomeRobots LIMIT {number:int}", [ "number" => $number, ] );
這會(huì)導(dǎo)致異常:
Fatal error: Uncaught exception "PDOException" with message "SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ""100"" at line 1" in /Users/scott/demo.php:78
錯(cuò)誤原因是"100"是一個(gè)字符串??梢韵葘⒅缔D(zhuǎn)換為整型:
executeQuery( "SELECT * FROM SomeRobots LIMIT {number:int}", [ "number" => (int) $number, ] );
要解決這個(gè)問題,需要開發(fā)者格外注意綁定參數(shù)類型及其如何傳遞。為了簡(jiǎn)化操作并避免異常,可以指定Phalcon自動(dòng)轉(zhuǎn)換:
true]);
以下操作根據(jù)指定的綁定類型執(zhí)行:
綁定類型 | 操作 |
---|---|
Column::BIND_PARAM_STR | 將值轉(zhuǎn)換為PHP字符串 |
Column::BIND_PARAM_INT | 將值轉(zhuǎn)換為PHP整型 |
Column::BIND_PARAM_BOOL | 將值轉(zhuǎn)換為PHP布爾值 |
Column::BIND_PARAM_DECIMAL | 將值轉(zhuǎn)換為PHP浮點(diǎn)數(shù) |
從數(shù)據(jù)庫(kù)返回的值在PDO中始終表示為字符串,無論該列值是數(shù)字還是布爾值。這種情況是因?yàn)槟承┝蓄愋陀捎谄浯笮∠拗贫鵁o法用PHP原來類型表示。例如,MySQL中的BIGINT可以存儲(chǔ)無法用PHP 32位整型表示的大整數(shù)。所以,PDO和ORM默認(rèn)將所有值作為字符串。可以設(shè)置ORM自動(dòng)將這些值轉(zhuǎn)換為PHP實(shí)際類型:
true]);
通過這種方式,可以使用嚴(yán)格運(yùn)算符或?qū)ψ兞款愋瓦M(jìn)行假設(shè):
id) { echo $robot->name; }插入 / 更新 / 刪除記錄(Inserting / Updating / Deleting Rows)
可以使用原生SQL或類方法來插入、更新、刪除記錄:
execute($sql); // 使用占位符 $sql = "INSERT INTO `robots`(`name`, `year`) VALUES(?, ?)"; $success = $connection->execute( $sql, [ "Astro Boy", 1952, ] ); // 動(dòng)態(tài)生成SQL語(yǔ)句 $success = $connection->insert( "robots", [ "Astro Boy", 1952, ], [ "name", "year", ] ); // 動(dòng)態(tài)生成SQL語(yǔ)句(另一種語(yǔ)法) $success = $connection->insertAsDict( "robots", [ "name" => "Astro Boy", "year" => 1952, ] ); // 使用原生SQL更新數(shù)據(jù) $sql = "UPDATE `robots` SET `name` = "Astro Boy" WHERE `id` = 101"; $success = $connection->execute($sql); // 使用占位符 $sql = "UPDATE `robots` SET `name` = ? WHERE `id` = ?"; $success = $connection->execute( $sql, [ "Astro Boy", 101, ] ); // 動(dòng)態(tài)生成SQL語(yǔ)句 $success = $connection->update( "robots", [ "name", ], [ "New Astro Boy", ], "id = 101" // 注意,這種情況下值不會(huì)被自動(dòng)轉(zhuǎn)義 ); // 條件中數(shù)據(jù)的轉(zhuǎn)義 $success = $connection->update( "robots", [ "name", ], [ "New Astro Boy", ], [ "conditions" => "id = ?", "bind" => [101], "bindTypes" => [PDO::PARAM_INT], // 可選參數(shù) ] ); $success = $connection->updateAsDict( "robots", [ "name" => "New Astro Boy", ], [ "conditions" => "id = ?", "bind" => [101], "bindTypes" => [PDO::PARAM_INT], // 可選參數(shù) ] ); // 使用原生SQL刪除記錄 $sql = "DELETE `robots` WHERE `id` = 101"; $success = $connection->execute($sql); // 使用占位符 $sql = "DELETE `robots` WHERE `id` = ?"; $success = $connection->execute($sql, [101]); // 動(dòng)態(tài)生成SQL語(yǔ)句 $success = $connection->delete( "robots", "id = ?", [ 101, ] );事務(wù)和嵌套事務(wù)(Transactions and Nested Transactions)
PDO支持事務(wù)處理,在事務(wù)內(nèi)部執(zhí)行數(shù)據(jù)庫(kù)操作通常可以提高數(shù)據(jù)庫(kù)的性能:
begin(); // 執(zhí)行SQL語(yǔ)句 $connection->execute("DELETE `robots` WHERE `id` = 101"); $connection->execute("DELETE `robots` WHERE `id` = 102"); $connection->execute("DELETE `robots` WHERE `id` = 103"); // 如果一切順利,提交事務(wù) $connection->commit(); } catch (Exception $e) { // 發(fā)生異常,回滾事務(wù) $connection->rollback(); }
除了標(biāo)準(zhǔn)事務(wù),PhalconDb內(nèi)置了嵌套事務(wù)(如果數(shù)據(jù)庫(kù)支持)。當(dāng)再次調(diào)用begin()方法時(shí),會(huì)創(chuàng)建一個(gè)嵌套事務(wù):
begin(); // 執(zhí)行SQL語(yǔ)句 $connection->execute("DELETE `robots` WHERE `id` = 101"); try { // 開始嵌套事務(wù) $connection->begin(); // 嵌套事務(wù)中執(zhí)行SQL語(yǔ)句 $connection->execute("DELETE `robots` WHERE `id` = 102"); $connection->execute("DELETE `robots` WHERE `id` = 103"); // 創(chuàng)建保存點(diǎn) $connection->commit(); } catch (Exception $e) { // 發(fā)生異常,回滾嵌套事務(wù) $connection->rollback(); } // 繼續(xù)執(zhí)行更多SQL語(yǔ)句 $connection->execute("DELETE `robots` WHERE `id` = 104"); // 如果一切順利,提交事務(wù) $connection->commit(); } catch (Exception $e) { // 發(fā)生異常,回滾事務(wù) $connection->rollback(); }數(shù)據(jù)庫(kù)事件(Database Events)
PhalconDb能夠?qū)⑹录l(fā)送給EventManager(如果存在),某些事件返回false時(shí),可能會(huì)終止操作。支持以下事件:
事件名稱 | 觸發(fā)時(shí)機(jī) | 是否會(huì)終止操作 |
---|---|---|
afterConnect | 成功連接到數(shù)據(jù)庫(kù)后 | 否 |
beforeQuery | 執(zhí)行SQL語(yǔ)句前 | 是 |
afterQuery | 執(zhí)行SQL語(yǔ)句后 | 否 |
beforeDisconnect | 關(guān)閉臨時(shí)數(shù)據(jù)庫(kù)連接前 | 否 |
beginTransaction | 事務(wù)開啟前 | 否 |
rollbackTransaction | 事務(wù)回滾前 | 否 |
commitTransaction | 事務(wù)提交前 | 否 |
將EventsManager綁定到數(shù)據(jù)庫(kù)連接很簡(jiǎn)單,PhalconDb將觸發(fā)db類型事件:
attch("db", $dbListener); $connection = new Connection( [ "host" => "localhost", "username" => "root", "password" => "secret", "dbname" => "invo", ] ); // 將eventsManager分配給數(shù)據(jù)庫(kù)適配器實(shí)例 $connection->setEventsManager($eventsManager);
數(shù)據(jù)庫(kù)事件中,終止SQL操作非常有用。例如,想在SQL執(zhí)行前實(shí)現(xiàn)注入檢查:
attch( "db:beforeQuery", function (Event $event, $connection) { $sql = $connection->getSQLStatement(); // 檢查SQL中是否有惡意關(guān)鍵字 if (preg_match("/DROP|ALTER/i", $sql)) { // 不允許DROP / ALTERT操作 return false; } return true; } )分析SQL語(yǔ)句(Profiling SQL Statements)
PhalconDb內(nèi)置了性能分析組件PhalconDbProfiler,用于分析數(shù)據(jù)庫(kù)性能,以便診斷問題,發(fā)現(xiàn)瓶頸。使用PhalconDbProfiler進(jìn)行數(shù)據(jù)庫(kù)分析相當(dāng)容易:
attch( "db", function (Event $event, $connection) use ($profiler) { if ($event->getType() === "beforeQuery") { $sql = $connection->getSQLStatement(); // 開始分析 $profiler->startProfile($sql); } if ($event->getType() === "afterQuery") { // 停止分析 $profiler->stopProfile(); } } ); // 將事件管理器分配給數(shù)據(jù)庫(kù)連接 $connection->setEventsManager($eventsManager); $sql = "SELECT buyer_name, quantity, product_name FROM buyers LEFT JOIN products ON buyers.pid = products.id"; // 執(zhí)行SQL語(yǔ)句 $connection->query($sql); // 獲取最后一個(gè)分析結(jié)果 $profile = $profiler->getLastProfile(); echo "SQL Statement: ", $profile->getSQLStatement(), " "; echo "Start Time: ", $profile->getInitialTime(), " "; echo "Final Time: ", $profile->getFinalTime(), " "; echo "Total Elapsed Time: ", $profile->getTotalElapsedSeconds(), " ";
還可以基于PhalconDbProfiler創(chuàng)建自己的分析器,以實(shí)時(shí)統(tǒng)計(jì)發(fā)送到數(shù)據(jù)庫(kù)的SQL語(yǔ)句:
getSQLStatement(); } // SQL語(yǔ)句發(fā)送到數(shù)據(jù)庫(kù)服務(wù)器之后執(zhí)行 public function afterEndProfile(Item $profile) { echo $profile->getTotalElapsedSeconds(); } } // 創(chuàng)建事件管理器 $eventsManager = new EventsManager(); // 創(chuàng)建事件監(jiān)聽器 $dbProfiler = new DbProfiler(); // 設(shè)置監(jiān)聽器監(jiān)聽所有數(shù)據(jù)庫(kù)事件 $eventsManager->attch("db", $dbProfiler);記錄SQL語(yǔ)句(Logging SQL Statements)
使用諸如PhalconDb這樣的高級(jí)抽象組件來訪問數(shù)據(jù)庫(kù)時(shí),很難獲知哪些語(yǔ)句被發(fā)送到了數(shù)據(jù)庫(kù)。PhalconLogger配合PhalconDb使用,可以在數(shù)據(jù)庫(kù)抽象層上提供日志記錄功能。
attch( "db:beforeQuery", function (Event $event, $connection) use ($logger) { $sql = $connection->getSQLStatement(); $logger->log($sql, Logger::INFO); } ); // 將eventsManager分配給數(shù)據(jù)庫(kù)適配器實(shí)例 $connection->setEventsManager($eventsManager); // 執(zhí)行SQL語(yǔ)句 $connection->insert( "products", [ "Hot pepper", 3.50, ], [ "name", "price", ] );
如上所述,文件app/logs/db.log將包含下列內(nèi)容:
[Sun, 29 Apr 12 22:35:26 -0500][DEBUG][Resource Id #77] INSERT INTO products (name, price) VALUES ("Hot pepper", 3.50)自定義記錄器(Implementing your own Logger)
可以自定義記錄器以記錄數(shù)據(jù)庫(kù)操作,通過創(chuàng)建一個(gè)實(shí)現(xiàn)了log()方法的類,該方法接受一個(gè)字符串作為第一個(gè)參數(shù)??梢詫⒂涗浧鲗?duì)象傳遞給PhalconDb::setLogger(),這樣在執(zhí)行任何SQL語(yǔ)句時(shí)將調(diào)用log()方法進(jìn)行記錄。
獲取表 / 視圖詳情(Describing Tables / Views)PhalconDb提供了獲取表、視圖詳情的方法:
listTables("test_db"); // 表"robots"是否存在于當(dāng)前庫(kù)中 $exists = $connection->tableExists("robots"); // 獲取"robots"表字段名稱、類型、特性 $fields = $connection->describeColumns("robots"); foreach ($fields as $field) { echo "Column Type: ", $field["Type"]; } // 獲取"robots"表索引 $indexes = $connection->describeIndexes("robots"); foreach ($indexes as $index) { print_r( $index->getColumns() ); } // 獲取"robots"表外鍵 $references = $connection->describeReferences("robots"); foreach ($references as $reference) { // 打印引用列 print_r( $reference->getReferenceColumns() ); }
表詳情和MySQL的describe命令返回的信息相似,包含如下信息:
Field | Type | Key | Null |
---|---|---|---|
字段名稱 | 字段類型 | 是否主鍵或索引列 | 是否允許為空 |
對(duì)于被支持的數(shù)據(jù)庫(kù)系統(tǒng),同樣實(shí)現(xiàn)了獲取視圖詳情的方法:
listViews("test_db"); // 視圖"robots"是否存在于當(dāng)前庫(kù)中 $exists = $connection->viewExists("robots");創(chuàng)建、修改、刪除表(Creating / Alerting / Dropping Tables)
不同的數(shù)據(jù)庫(kù)系統(tǒng)(MySQL,Postgresql等)通過CREATE、ALTER、DROP命令提供了用于創(chuàng)建、修改、刪除數(shù)據(jù)表的功能。SQL語(yǔ)法因數(shù)據(jù)庫(kù)而異。PhalconDb為編輯表提供了統(tǒng)一接口,無需區(qū)分不同數(shù)據(jù)庫(kù)系統(tǒng)的SQL語(yǔ)法。
創(chuàng)建表(Creating Tables)下面例子展示如何創(chuàng)建表:
createTable( "robots", null, [ "columns" => [ new Column( "id", [ "type" => Column::TYPE_INTEGER, "size" => 10, "notNull" => true, "autoIncrement" => true, "primary" => true, ] ), new Column( "name", [ "type" => Column::TYPE_VARCHAR, "size" => 70, "notNull" => true, ] ), new Column( "year", [ "type" => Column::TYPE_INTEGER, "size" => 11, "notNull" => true, ] ), ], ] );
PhalconDb::createTable()接收一個(gè)描述數(shù)據(jù)表的關(guān)聯(lián)數(shù)組,用PhalconDbColumn類創(chuàng)建字段,下表列出了定義字段的選項(xiàng):
選項(xiàng) | 說明 | 是否可選 |
---|---|---|
type | 字段類型,必須是PhalconDbColumn常量 | 否 |
primary | 是否主鍵 | 是 |
size | VARCHAR或INTEGER類型的字段定義字段長(zhǎng)度 | 是 |
scale | DEMICAL或NUMBER類型字段定義數(shù)據(jù)精度 | 是 |
unsigned | INTEGER類型字段定義是否有符號(hào),該選項(xiàng)不適用于其他類型字段 | 是 |
notNull | 字段是否非空 | 是 |
default | 默認(rèn)值 | 是 |
autoIncrement | 是否自增 | 是 |
bind | BIND_TYPE_*常量定義字段在保存前如何綁定數(shù)據(jù) | 是 |
first | 把字段設(shè)置為表的第一個(gè)字段 | 是 |
after | 設(shè)置字段放在指定字段之后 | 是 |
PhalconDb支持下列字段類型:
PhalconDbColumn::TYPE_INTEGER
PhalconDbColumn::TYPE_DATE
PhalconDbColumn::TYPE_VARCHAR
PhalconDbColumn::TYPE_DECIMAL
PhalconDbColumn::TYPE_DATETIME
PhalconDbColumn::TYPE_CHAR
PhalconDbColumn::TYPE_TEXT
傳入PhalconDb::createTable()方法的關(guān)聯(lián)數(shù)組可能包含下列索引:
索引 | 說明 | 是否可選 |
---|---|---|
columns | 由PhalconDbColumn定義的字段組成的數(shù)組 | 否 |
indexes | 由PhalconDbIndex定義的表索引組成的數(shù)組 | 是 |
references | 由PhalconDbReference定義的表引用(外鍵)組成的數(shù)組 | 是 |
options | 包含表創(chuàng)建選項(xiàng)的數(shù)組,這些選項(xiàng)通常與數(shù)據(jù)庫(kù)遷移相關(guān) | 是 |
隨著應(yīng)用程序越來越龐雜,可能需要調(diào)整數(shù)據(jù)庫(kù),作為重構(gòu)或添加新功能的一部分。并非所有數(shù)據(jù)庫(kù)系統(tǒng)都允許修改列或者新增列,PhalconDb也受到這些限制:
addColumn( "robots", null, new Column( "robot_type", [ "type" => Column::TYPE_VARCHAR, "size" => 32, "notNull" => true, "after" => "name", ] ) ); // 編輯列 $connection->modifyColumn( "robots", null, new Column( "name", [ "type" => Column::TYPE_VARCHAR, "size" => 40, "notNull" => true, ] ) ); // 刪除"name"列 $connection->dropColumn( "robots", null, "name" );刪除表(Dropping Tables)
刪除表示例:
dropTable("robots"); // 從"machines"庫(kù)中刪除"robots"表 $connection->dropTable("robots", "machines");
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/28531.html
摘要:使用模型模型表示應(yīng)用程序信息數(shù)據(jù)以及這些數(shù)據(jù)的處理規(guī)則,主要用于管理與對(duì)應(yīng)數(shù)據(jù)表的交互規(guī)則。應(yīng)用中,是所有模型的基類。創(chuàng)建模型模型需繼承類,以大駝峰格式命名。方法在請(qǐng)求期間只調(diào)用一次,目的是為該模型的所有實(shí)例執(zhí)行初始化操作。 使用模型(Working with Models) 模型表示應(yīng)用程序信息(數(shù)據(jù))以及這些數(shù)據(jù)的處理規(guī)則,主要用于管理與對(duì)應(yīng)數(shù)據(jù)表的交互規(guī)則。大多數(shù)情況下,數(shù)據(jù)庫(kù)中...
摘要:原文發(fā)表于入門教程之模型提供了四種方式操作數(shù)據(jù)庫(kù)模型數(shù)據(jù)庫(kù)抽象層以及原生。創(chuàng)建模型模型類的命名必須符合駝峰命名法,而且須繼承自類文件路徑繼承自類。 原文發(fā)表于:Phalcon入門教程之模型 Phalcon 提供了四種方式操作Mysql數(shù)據(jù)庫(kù):模型、PHQL、數(shù)據(jù)庫(kù)抽象層以及原生SQL。不論何種方式,首先都需要在DI中注冊(cè) db 服務(wù)才能正常使用: DI注冊(cè)db服務(wù) // 文件路徑:...
摘要:查詢語(yǔ)言查詢語(yǔ)言,簡(jiǎn)稱或,是一種面向?qū)ο蟮母呒?jí)語(yǔ)言,允許用標(biāo)準(zhǔn)化的編寫。該對(duì)象的每個(gè)成員都是一個(gè)包含所查詢字段的標(biāo)準(zhǔn)對(duì)象。 Phalcon查詢語(yǔ)言(Phalcon Query Language) Phalcon查詢語(yǔ)言,簡(jiǎn)稱PhalconQL或PHQL,是一種面向?qū)ο蟮母呒?jí)SQL語(yǔ)言,允許用標(biāo)準(zhǔn)化的SQL編寫。PHQL實(shí)現(xiàn)了把操作語(yǔ)句解析為RDBMS目標(biāo)語(yǔ)言的解析器(C語(yǔ)言編寫)。 為...
摘要:一般至少要在執(zhí)行路由前要判斷用戶是否具有權(quán)限一般在中,所以應(yīng)該在它之前獲得填充。以下代碼可參考這里的方法就是重點(diǎn)。參考這里把對(duì)象保存在中。 showImg(https://segmentfault.com/img/bVkdih); 使用如下圖解釋這個(gè)組件: showImg(https://segmentfault.com/img/bVkdii); 實(shí)際最終真正要使用的是access_l...
摘要:幫助你開始使用的簡(jiǎn)易指南。第一種方式參考第二種方式參考使用參考簡(jiǎn)單粗暴的理解是把下的對(duì)應(yīng)成數(shù)據(jù)庫(kù)的表,類屬性對(duì)應(yīng)表字段。 幫助你開始使用 phalcon 的簡(jiǎn)易指南。 簡(jiǎn)介 Phalcon 2將于2015年4月17日發(fā)布,這個(gè)版本大約85%的代碼是基于 Zephir 語(yǔ)言重寫的。Zephir是開源的,使用類似PHP語(yǔ)法的語(yǔ)言,生成C語(yǔ)言代碼,并編譯成PHP擴(kuò)展。這提高了PHP擴(kuò)展的開發(fā)...
閱讀 2719·2021-11-11 16:54
閱讀 2338·2021-10-09 09:44
閱讀 2565·2019-08-30 15:54
閱讀 1945·2019-08-30 11:24
閱讀 1187·2019-08-29 17:03
閱讀 2115·2019-08-29 16:22
閱讀 2095·2019-08-29 13:11
閱讀 1056·2019-08-29 12:14