smeghead / phel-pdo
phel-lang pdo wrapper library.
Installs: 7
Dependents: 0
Suggesters: 0
Security: 0
Stars: 5
Watchers: 3
Forks: 1
Open Issues: 1
Language:Dockerfile
Requires
- php: >=8.2
- phel-lang/phel-lang: ^0.15
README
phel-lang pdo wrapper library.
Description
Inherently, it is very easy to call the functionality of PHP classes from phel code. Therefore, it is not difficult to access the database using PDO directly.
However, if you have to think about PHP classes while writing phel code, there is a concern that a context switch will occur between the phel world and the PHP world, and you will not be able to concentrate on writing the phel code.
Therefore, I created a wrapper library (phel-pdo) that can handle PDO just by calling Phel functions.
Install
Install from composer. https://packagist.org/packages/phel-lang/phel-pdo
composer require phel-lang/phel-pdo
Usage
This is an example of connecting to a file database, creating a table, inserting records, and searching on repl.
phel:1> (require phel\pdo) phel\pdo phel:2> (require phel\pdo\statement) phel\pdo\statement phel:3> (def connection-string "sqlite:database.db") 1 phel:4> (def conn (pdo/connect connection-string)) 1 phel:5> (pdo/exec conn "create table t1 (id integer primary key autoincrement, name varchr(10))") 0 phel:6> (pdo/exec conn "insert into t1 (name) values ('phel'), ('php')") 2 phel:7> (def stmt (pdo/query conn "select * from t1 where id = 1")) 1 phel:8> (statement/fetch stmt) {:id 1 :name phel} phel:8> (def stmt (pdo/prepare conn "select * from t1 where id = :id")) 1 phel:9> (def stmt (statement/execute stmt {:id 1})) 1 phel:10> (statement/fetch stmt) {:id 1 :name phel}
Reference
pdo
Represents a connection between PHP and a database server.
begin
Initiates a transaction
(begin conn)
commit
Commits a transaction
(commit conn)
connect
Connect database and return connection object. Throws a PDOException if the attempt to connect to the requested database fails
(connect dns & [username password options])
error-code
Fetch the SQLSTATE associated with the last operation on the database handle
(error-code conn)
error-info
Fetch extended error information associated with the last operation on the database handle
(error-info conn)
exec
Execute an SQL statement and return the number of affected rows
(exec conn stmt & [fetch-mode])
get-attribute
Retrieve a database connection attribute
(get-attribute conn attribute)
get-available-drivers
Return an array of available PDO drivers
(get-available-drivers conn)
in-transaction
Checks if inside a transaction
(in-transaction conn)
last-insert-id
Returns the ID of the last inserted row or sequence value
(last-insert-id conn)
prepare
Prepares a statement for execution and returns a statement object
(prepare conn stmt & [fetch-mode])
query
Prepares and executes an SQL statement without placeholders
(query conn stmt & [fetch-mode])
quote
Quotes a string for use in a query
(query conn string & [type])
rollback
Rolls back a transaction
(rollback conn)
set-attribute
Set an attribute
(set-attribute conn attribute value)
statement
Represents a prepared statement and, after the statement is executed, an associated result set.
bind-value
Binds a value to a parameter
(bind-value statement column value & [type])
debug-dump-params
Returns an SQL prepared command
(debug-dump-params statement)
execute
Executes a prepared statement
Note
The return value of the original library, PDOStatement::execute()
, is a bool
value representing the result of the execute
method, while the return value of statement/execute
returns the statement itself.
(execute statement)
fetch
Fetches the next row from a result set
(fetch statement)
fetch-all
Fetches the remaining rows from a result set
(fetch-all statement)
fetch-column
Returns a single column from the next row of a result set
(fetch-column statement & [column])
Development
Open shell
docker compose build docker compose run --rm php_cli bash
Test
vendor/bin/phel test