Add command function returning command tag value of a query

This commit is contained in:
Tomasz Rybarczyk 2018-10-08 21:06:41 +02:00
parent 3363bffce8
commit 2da6a3a767
3 changed files with 57 additions and 6 deletions

View File

@ -51,3 +51,26 @@ exports.ffiUnsafeQuery = function(client) {
}; };
}; };
}; };
exports.ffiUnsafeCommand = function(client) {
return function(sql) {
return function(values) {
return function(onError, onSuccess) {
var q = client.query({
text: sql,
values: values,
rowMode: 'array',
}).catch(function(err) {
onError(err);
}).then(function(result) {
onSuccess(result.rowCount);
});
return function (cancelError, cancelerError, cancelerSuccess) {
q.cancel();
cancelerSuccess();
};
};
};
};
};

View File

@ -8,6 +8,7 @@ module Database.PostgreSQL
, newPool , newPool
, withConnection , withConnection
, withTransaction , withTransaction
, command
, execute , execute
, query , query
, scalar , scalar
@ -25,7 +26,7 @@ import Control.Monad.Error.Class (catchError, throwError)
import Data.Array (head) import Data.Array (head)
import Data.Either (Either(..)) import Data.Either (Either(..))
import Foreign (Foreign) import Foreign (Foreign)
import Data.Maybe (Maybe(..)) import Data.Maybe (Maybe)
import Data.Newtype (class Newtype) import Data.Newtype (class Newtype)
import Data.Traversable (traverse) import Data.Traversable (traverse)
import Database.PostgreSQL.Row (class FromSQLRow, class ToSQLRow, Row0(..), Row1(..), fromSQLRow, toSQLRow) import Database.PostgreSQL.Row (class FromSQLRow, class ToSQLRow, Row0(..), Row1(..), fromSQLRow, toSQLRow)
@ -160,6 +161,26 @@ foreign import ffiUnsafeQuery
-> Array Foreign -> Array Foreign
-> EffectFnAff (Array (Array Foreign)) -> EffectFnAff (Array (Array Foreign))
fromRight :: a b. Either a b -> Maybe b -- | Execute a PostgreSQL query and return its command tag value.
fromRight (Left _) = Nothing command
fromRight (Right a) = Just a :: i
. ToSQLRow i
=> Connection
-> Query i Int
-> i
-> Aff Int
command conn (Query sql) values =
unsafeCommand conn sql (toSQLRow values)
unsafeCommand
:: Connection
-> String
-> Array Foreign
-> Aff Int
unsafeCommand c s = fromEffectFnAff <<< ffiUnsafeCommand c s
foreign import ffiUnsafeCommand
:: Connection
-> String
-> Array Foreign
-> EffectFnAff Int

View File

@ -18,11 +18,10 @@ import Data.JSDate as JSDate
import Data.Maybe (Maybe(..), fromJust) import Data.Maybe (Maybe(..), fromJust)
import Data.Newtype (unwrap) import Data.Newtype (unwrap)
import Data.Tuple (Tuple(..)) import Data.Tuple (Tuple(..))
import Database.PostgreSQL (Connection, PoolConfiguration, Query(Query), Row0(Row0), Row1(Row1), Row2(Row2), Row3(Row3), Row9(Row9), execute, newPool, query, scalar, withConnection, withTransaction) import Database.PostgreSQL (Connection, PoolConfiguration, Query(Query), Row0(Row0), Row1(Row1), Row2(Row2), Row3(Row3), Row9(Row9), command, execute, newPool, query, scalar, withConnection, withTransaction)
import Effect (Effect) import Effect (Effect)
import Effect.Aff (Aff, error, launchAff) import Effect.Aff (Aff, error, launchAff)
import Effect.Class (liftEffect) import Effect.Class (liftEffect)
import Effect.Console (logShow)
import Foreign.Object (Object, fromFoldable) import Foreign.Object (Object, fromFoldable)
import Math ((%)) import Math ((%))
import Partial.Unsafe (unsafePartial) import Partial.Unsafe (unsafePartial)
@ -145,6 +144,14 @@ main = void $ launchAff do
""") Row0 """) Row0
liftEffect <<< assert $ deleted == [Row2 "pork" true, Row2 "rookworst" true] liftEffect <<< assert $ deleted == [Row2 "pork" true, Row2 "rookworst" true]
test conn "delete returning command tag value" $ do
insertFood
deleted <- command conn (Query """
DELETE FROM foods
WHERE delicious
""") Row0
liftEffect <<< assert $ deleted == 2
test conn "handling instant value" $ do test conn "handling instant value" $ do
before <- liftEffect $ (unwrap <<< unInstant) <$> now before <- liftEffect $ (unwrap <<< unInstant) <$> now
insertFood insertFood