首页 > 数据库 >无涯教程-SQLite - 连接PHP

无涯教程-SQLite - 连接PHP

时间:2024-01-18 20:31:34浏览次数:43  
标签:SALARY SQLite NAME successfully db 无涯 echo ADDRESS PHP

在本章中,您将学习如何在PHP程序中使用SQLite。

安装

从PHP 5.3.0起默认启用SQLite3扩展。可以在编译时使用-without-sqlite3 禁用它。

Windows用户必须启用php_sqlite3.dll才能使用此扩展名。从PHP 5.3.0开始,此DLL包含在Windows的PHP发行版中。

有关详细的安装说明,请查看无涯教程的PHP教程及其官方网站。

PHP接口API

以下是重要的PHP示例教程,这些示例程可以满足您从PHP程序使用SQLite数据库的要求。如果正在寻找更复杂的应用程序,则可以查阅PHP官方文档。

Sr.No. API & 描述
1

public void SQLite3::open ( filename, flags, encryption_key )

打开SQLite 3数据库。如果构建包含加密,则它将尝试使用键(key)。

如果文件名以':memory:'给出,则SQLite3::open()将在RAM中创建一个内存数据库,该数据库仅在会话期间持续存在。

如果文件名是实际的设备文件名,则SQLite3::open()尝试使用其值打开数据库文件。如果不存在该名称的文件,则将创建一个新的该名称的数据库文件。

用于确定如何打开SQLite数据库的可选标志。默认情况下,打开使用SQLITE3_OPEN_READWRITE | SQLITE3_OPEN_CREATE。

2

public bool SQLite3::exec ( string $query )

此示例程提供了一种快速,简便的方法来执行sql参数提供的SQL命令,该命令可以包含多个SQL命令。该示例程用于对给定的数据库执行无输出查询。

3

public SQLite3Result SQLite3::query ( string $query )

此示例程执行SQL查询,如果查询返回输出,则返回 SQLite3Result 对象。

4

public int SQLite3::lastErrorCode(void)

此示例程返回最近失败的SQLite请求的数字输出代码。

5

public string SQLite3::lastErrorMsg ( void )

此示例程返回描述最近失败的SQLite请求的英文文本。

6

public int SQLite3::changes(void)

此示例程返回由最新SQL语句更新,插入或删除的数据库行数。

7

public bool SQLite3::close ( void )

该示例程关闭先前通过调用SQLite3::open()打开的数据库连接。

8

public string SQLite3::escapeString ( string $value )

此示例程返回已正确转义的字符串,以安全地包含在SQL语句中。

连接到数据库

以下PHP代码显示了如何连接到现有数据库。如果数据库不存在,则将创建数据库,最后将返回数据库对象。

<?php
   class MyDB extends SQLite3 {
      function __construct() {
         $this->open('test.db');
      }
   }
   $db = new MyDB();
   if(!$db) {
      echo $db->lastErrorMsg();
   } else {
      echo "Opened database successfully\n";
   }
?>

现在,让无涯教程运行上面的程序在当前目录中创建数据库 test.db 。您可以根据需要更改路径。如果数据库创建成功,则将显示以下消息-

Open database successfully

创建表

以下PHP程序将用于在先前创建的数据库中创建表。

<?php
   class MyDB extends SQLite3 {
      function __construct() {
         $this->open('test.db');
      }
   }
   $db = new MyDB();
   if(!$db) {
      echo $db->lastErrorMsg();
   } else {
      echo "Opened database successfully\n";
   }

   $sql =<<<EOF
      CREATE TABLE COMPANY
      (ID INT PRIMARY KEY     NOT NULL,
      NAME           TEXT    NOT NULL,
      AGE            INT     NOT NULL,
      ADDRESS        CHAR(50),
      SALARY         REAL);
EOF;

   $ret = $db->exec($sql);
   if(!$ret){
      echo $db->lastErrorMsg();
   } else {
      echo "Table created successfully\n";
   }
   $db->close();
?>

执行上述程序后,它将在您的 test.db 中创建COMPANY表,并显示以下消息-

Opened database successfully
Table created successfully

插入操作

以下PHP程序显示了如何在上面的示例中创建的COMPANY表中创建记录。

<?php
   class MyDB extends SQLite3 {
      function __construct() {
         $this->open('test.db');
      }
   }
   
   $db = new MyDB();
   if(!$db){
      echo $db->lastErrorMsg();
   } else {
      echo "Opened database successfully\n";
   }

   $sql =<<<EOF
      INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
      VALUES (1, 'Paul', 32, 'California', 20000.00 );

      INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
      VALUES (2, 'Allen', 25, 'Texas', 15000.00 );

      INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
      VALUES (3, 'Teddy', 23, 'Norway', 20000.00 );

      INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
      VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 );
EOF;

   $ret = $db->exec($sql);
   if(!$ret) {
      echo $db->lastErrorMsg();
   } else {
      echo "Records created successfully\n";
   }
   $db->close();
?>

执行上述程序后,它将在COMPANY表中创建给定记录,并显示以下两行。

Opened database successfully
Records created successfully

选择操作

以下PHP程序演示了如何从在上面的示例中创建的COMPANY表中获取和显示记录-

<?php
   class MyDB extends SQLite3 {
      function __construct() {
         $this->open('test.db');
      }
   }
   
   $db = new MyDB();
   if(!$db) {
      echo $db->lastErrorMsg();
   } else {
      echo "Opened database successfully\n";
   }

   $sql =<<<EOF
      SELECT * from COMPANY;
EOF;

   $ret = $db->query($sql);
   while($row = $ret->fetchArray(SQLITE3_ASSOC) ) {
      echo "ID=". $row['ID'] . "\n";
      echo "NAME=". $row['NAME'] ."\n";
      echo "ADDRESS=". $row['ADDRESS'] ."\n";
      echo "SALARY=".$row['SALARY'] ."\n\n";
   }
   echo "Operation done successfully\n";
   $db->close();
?>

执行上述程序时,将产生以下输出。

Opened database successfully
ID=1
NAME=Paul
ADDRESS=California
SALARY=20000

ID=2
NAME=Allen
ADDRESS=Texas
SALARY=15000

ID=3
NAME=Teddy
ADDRESS=Norway
SALARY=20000

ID=4
NAME=Mark
ADDRESS=Rich-Mond
SALARY=65000

Operation done successfully

更新操作

以下PHP代码显示了如何使用UPDATE语句更新任何记录,然后从COMPANY表中获取并显示更新的记录。

<?php
   class MyDB extends SQLite3 {
      function __construct() {
         $this->open('test.db');
      }
   }
   
   $db = new MyDB();
   if(!$db) {
      echo $db->lastErrorMsg();
   } else {
      echo "Opened database successfully\n";
   }
   $sql =<<<EOF
      UPDATE COMPANY set SALARY = 25000.00 where ID=1;
EOF;
   $ret = $db->exec($sql);
   if(!$ret) {
      echo $db->lastErrorMsg();
   } else {
      echo $db->changes(), " Record updated successfully\n";
   }

   $sql =<<<EOF
      SELECT * from COMPANY;
EOF;
   
   $ret = $db->query($sql);
   while($row = $ret->fetchArray(SQLITE3_ASSOC) ) {
      echo "ID=". $row['ID'] . "\n";
      echo "NAME=". $row['NAME'] ."\n";
      echo "ADDRESS=". $row['ADDRESS'] ."\n";
      echo "SALARY=".$row['SALARY'] ."\n\n";
   }
   echo "Operation done successfully\n";
   $db->close();
?>

执行上述程序时,将产生以下输出。

Opened database successfully
1 Record updated successfully
ID=1
NAME=Paul
ADDRESS=California
SALARY=25000

ID=2
NAME=Allen
ADDRESS=Texas
SALARY=15000

ID=3
NAME=Teddy
ADDRESS=Norway
SALARY=20000

ID=4
NAME=Mark
ADDRESS=Rich-Mond
SALARY=65000

Operation done successfully

删除操作

以下PHP代码显示了如何使用DELETE语句删除任何记录,然后从COMPANY表中获取并显示其余记录。

<?php
   class MyDB extends SQLite3 {
      function __construct() {
         $this->open('test.db');
      }
   }
   
   $db = new MyDB();
   if(!$db) {
      echo $db->lastErrorMsg();
   } else {
      echo "Opened database successfully\n";
   }
   $sql =<<<EOF
      DELETE from COMPANY where ID = 2;
EOF;
   
   $ret = $db->exec($sql);
   if(!$ret){
     echo $db->lastErrorMsg();
   } else {
      echo $db->changes(), " Record deleted successfully\n";
   }

   $sql =<<<EOF
      SELECT * from COMPANY;
EOF;
   $ret = $db->query($sql);
   while($row = $ret->fetchArray(SQLITE3_ASSOC) ) {
      echo "ID=". $row['ID'] . "\n";
      echo "NAME=". $row['NAME'] ."\n";
      echo "ADDRESS=". $row['ADDRESS'] ."\n";
      echo "SALARY=".$row['SALARY'] ."\n\n";
   }
   echo "Operation done successfully\n";
   $db->close();
?>

执行上述程序时,将产生以下输出。

Opened database successfully
1 Record deleted successfully
ID=1
NAME=Paul
ADDRESS=California
SALARY=25000

ID=3
NAME=Teddy
ADDRESS=Norway
SALARY=20000

ID=4
NAME=Mark
ADDRESS=Rich-Mond
SALARY=65000

Operation done successfully

参考链接

https://www.learnfk.com/sqlite/sqlite-php.html

标签:SALARY,SQLite,NAME,successfully,db,无涯,echo,ADDRESS,PHP
From: https://blog.51cto.com/u_14033984/9319771

相关文章

  • 无涯教程-SQLite - Autoincrement(自增)
    SQLiteAUTOINCREMENT是用于自动递增表中字段值的关键字,只能与INTEGER字段一起使用。AUTOINCREMENT-语法AUTOINCREMENT关键字的基本用法如下-CREATETABLEtable_name(column1INTEGERAUTOINCREMENT,column2datatype,column3datatype,.....colum......
  • FastCGI访问PHP-FPM实现任意代码执行
    之前学习web的Nginx解析漏洞就看到了FastCGI协议,今天学习一下。顺便看看有什么漏洞可以复现Nginx解析漏洞Nginx接受用户的http请求后生成的cgi环境变量有一SCRIPIT_NAME和PATH_INFO比如想要请求/var/www/html/example.gif/.php那么/var/www/html/example.gif就是SCRIPT_NAME/.......
  • 无涯教程-SQLite - NULL语句
    SQLiteNULL是用于表示缺失值的术语,表中的NULL值是显示为空白的字段中的值。NULL-语法以下是在创建表时使用NULL的基本语法。SQLite>CREATETABLECOMPANY(IDINTPRIMARYKEYNOTNULL,NAMETEXTNOTNULL,AGEINTNOTN......
  • PHP把数组按指定的个数分隔
    假设数组为array(‘1’,‘2’,‘3’,‘4’,‘5’,‘6’);想把它分割成四个,那么结果为array( ‘0’=>[‘1’,‘2’], ‘1’=>[‘3’,‘4’], ‘2’=>[‘5’], ‘3’=>[‘6’],);/****把数组按指定的个数分隔*@paramarray$array要分割的数组*@par......
  • 无涯教程-SQLite - 表达式
    SQL表达式类似于公式,它们以查询语言编写,您还可以用于向数据库查询一组特定的数据。Expressions-语法考虑一下SELECT语句的基本语法,如下所示:SELECTcolumn1,column2,columnNFROMtable_nameWHERE[CONDITION|EXPRESSION];以下是不同类型的SQLite表达式。Expressio......
  • 无涯教程-SQLite - 数据类型
    SQLite数据类型是一个属性,用于指定任何对象的数据类型,每个列,变量和表达式在SQLite中都有相关的数据类型。SQLite存储类存储在SQLite数据库中的每个值都具有以下存储类别之一-Sr.No.StorageClass&描述1NULL该值为NULL值。2INTEGER该值为带符号整数,根据值的大小......
  • PHP LFI/RFI Vulnerability attack bypassing remote URL inclusion restriction
    FileInclusionvulnerabilityInthePHPConfiguration,"allow_url_include" wrapperby-defaultsetto"Off"whichinstructPHPnototloadremoteHTTPorFTPurls.HencepreventRemoteFileInclusionattack.ButPHPdoesnotblockSMBURL......
  • thinkphp 操作mysql数据库
    获取当前路由信息useapp\BaseController;//引入控制器publicfunctionindex(){//返回当前实际路径return$this->app->getAppPath();//返回当前方法名//return$this->request->action();}载入的控制器不存在......
  • 无涯教程-SQLite - 安装步骤
    SQLite以其出色的零配置功能而闻名,这意味着不需要复杂的设置或管理,本章将引导您完成在Windows,Linux和MacOSX上设置SQLite的过程。在Windows上安装步骤1-转到SQLite下载页面,并从Windows部分下载预编译的二进制文件。步骤2-下载sqlite-shell-win32-*.zip和sqlite-dll-win......
  • 无涯教程-SQL Numeric Functions函数
    SQL数字函数主要用于数字操作和/或数学计算。下表详细介绍了数字函数-Sr.No.Function&描述1ABS()返回数值表达式的绝对值。2ACOS()返回数值表达式的反余弦值。如果该值不在-1到1之间,则返回NULL。3ASIN()返回数字表达式的反正弦值。如果值不在-1到1的范围内,则返......