Haskell SQLite3 query all
Would like to determine the size of a table (length) to avoid a user entering an incremental ID that already exists (Note: left all Haskell books to get my feet wet). Got a table with id, task, date_in, date_out
and need to count the number id's. Using this function:
checkUniqueID = do
conn <- open "taglist.db"
len <- query conn "SELECT * FROM task;" (Only xxx) :: IO [id]
let showLength = length $ len
print showLength
close conn
return ()
However: omitting the 'Only
' will result in ghci mentioning too few arguments, but I really cannot figure out what to put at xxx. Too bad all Haskell doc is so fragmented, since it is such a cool language.
Thanks guys!
sqlite haskell
add a comment |
Would like to determine the size of a table (length) to avoid a user entering an incremental ID that already exists (Note: left all Haskell books to get my feet wet). Got a table with id, task, date_in, date_out
and need to count the number id's. Using this function:
checkUniqueID = do
conn <- open "taglist.db"
len <- query conn "SELECT * FROM task;" (Only xxx) :: IO [id]
let showLength = length $ len
print showLength
close conn
return ()
However: omitting the 'Only
' will result in ghci mentioning too few arguments, but I really cannot figure out what to put at xxx. Too bad all Haskell doc is so fragmented, since it is such a cool language.
Thanks guys!
sqlite haskell
add a comment |
Would like to determine the size of a table (length) to avoid a user entering an incremental ID that already exists (Note: left all Haskell books to get my feet wet). Got a table with id, task, date_in, date_out
and need to count the number id's. Using this function:
checkUniqueID = do
conn <- open "taglist.db"
len <- query conn "SELECT * FROM task;" (Only xxx) :: IO [id]
let showLength = length $ len
print showLength
close conn
return ()
However: omitting the 'Only
' will result in ghci mentioning too few arguments, but I really cannot figure out what to put at xxx. Too bad all Haskell doc is so fragmented, since it is such a cool language.
Thanks guys!
sqlite haskell
Would like to determine the size of a table (length) to avoid a user entering an incremental ID that already exists (Note: left all Haskell books to get my feet wet). Got a table with id, task, date_in, date_out
and need to count the number id's. Using this function:
checkUniqueID = do
conn <- open "taglist.db"
len <- query conn "SELECT * FROM task;" (Only xxx) :: IO [id]
let showLength = length $ len
print showLength
close conn
return ()
However: omitting the 'Only
' will result in ghci mentioning too few arguments, but I really cannot figure out what to put at xxx. Too bad all Haskell doc is so fragmented, since it is such a cool language.
Thanks guys!
sqlite haskell
sqlite haskell
asked Nov 22 at 17:50
Madderote
20119
20119
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
I am not terribly familiar with these libraries. I check the docs
of Database.PostgreSQL.Simple
and found out that, if you don't have arguments to your query, you can use query_
and omit the argument tuple. The examples at the very beginning of the docs are quite helpful.
That being said, your approach looks wrong. You are pulling the whole table from the DB only to count the entries. This is a waste: you should instead use something like select count(*) from ..
so that you query for the length only.
This might work: (again, I've never used that library)
[Only len] <- query_ conn "select count(*) from task" :: IO [Only Int]
Hi @Chi with a little change it works. Thanks so much to get me on track again. Library is new for me too and on pulling in the entire table like I did, SQLite throws an error anyway. Maybe if others run into this 'problem' and read your reply, here's the modified code that works:conn <- open "taglist.db"n len <- query_ conn "SELECT (id) FROM task" :: IO [Only Int] let showLength = Data.List.length $ len print showLength close conn return ()
– Madderote
Nov 23 at 7:37
@Madderote If you have a completely working code, you can post it answering your own question. StackOverflow's policy encourage self-answers, when they can be useful to others.
– chi
Nov 23 at 12:27
Thanks for the tip. Will do with future issues, which I will encounter for sure ;-)
– Madderote
Nov 23 at 15:06
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53436097%2fhaskell-sqlite3-query-all%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
I am not terribly familiar with these libraries. I check the docs
of Database.PostgreSQL.Simple
and found out that, if you don't have arguments to your query, you can use query_
and omit the argument tuple. The examples at the very beginning of the docs are quite helpful.
That being said, your approach looks wrong. You are pulling the whole table from the DB only to count the entries. This is a waste: you should instead use something like select count(*) from ..
so that you query for the length only.
This might work: (again, I've never used that library)
[Only len] <- query_ conn "select count(*) from task" :: IO [Only Int]
Hi @Chi with a little change it works. Thanks so much to get me on track again. Library is new for me too and on pulling in the entire table like I did, SQLite throws an error anyway. Maybe if others run into this 'problem' and read your reply, here's the modified code that works:conn <- open "taglist.db"n len <- query_ conn "SELECT (id) FROM task" :: IO [Only Int] let showLength = Data.List.length $ len print showLength close conn return ()
– Madderote
Nov 23 at 7:37
@Madderote If you have a completely working code, you can post it answering your own question. StackOverflow's policy encourage self-answers, when they can be useful to others.
– chi
Nov 23 at 12:27
Thanks for the tip. Will do with future issues, which I will encounter for sure ;-)
– Madderote
Nov 23 at 15:06
add a comment |
I am not terribly familiar with these libraries. I check the docs
of Database.PostgreSQL.Simple
and found out that, if you don't have arguments to your query, you can use query_
and omit the argument tuple. The examples at the very beginning of the docs are quite helpful.
That being said, your approach looks wrong. You are pulling the whole table from the DB only to count the entries. This is a waste: you should instead use something like select count(*) from ..
so that you query for the length only.
This might work: (again, I've never used that library)
[Only len] <- query_ conn "select count(*) from task" :: IO [Only Int]
Hi @Chi with a little change it works. Thanks so much to get me on track again. Library is new for me too and on pulling in the entire table like I did, SQLite throws an error anyway. Maybe if others run into this 'problem' and read your reply, here's the modified code that works:conn <- open "taglist.db"n len <- query_ conn "SELECT (id) FROM task" :: IO [Only Int] let showLength = Data.List.length $ len print showLength close conn return ()
– Madderote
Nov 23 at 7:37
@Madderote If you have a completely working code, you can post it answering your own question. StackOverflow's policy encourage self-answers, when they can be useful to others.
– chi
Nov 23 at 12:27
Thanks for the tip. Will do with future issues, which I will encounter for sure ;-)
– Madderote
Nov 23 at 15:06
add a comment |
I am not terribly familiar with these libraries. I check the docs
of Database.PostgreSQL.Simple
and found out that, if you don't have arguments to your query, you can use query_
and omit the argument tuple. The examples at the very beginning of the docs are quite helpful.
That being said, your approach looks wrong. You are pulling the whole table from the DB only to count the entries. This is a waste: you should instead use something like select count(*) from ..
so that you query for the length only.
This might work: (again, I've never used that library)
[Only len] <- query_ conn "select count(*) from task" :: IO [Only Int]
I am not terribly familiar with these libraries. I check the docs
of Database.PostgreSQL.Simple
and found out that, if you don't have arguments to your query, you can use query_
and omit the argument tuple. The examples at the very beginning of the docs are quite helpful.
That being said, your approach looks wrong. You are pulling the whole table from the DB only to count the entries. This is a waste: you should instead use something like select count(*) from ..
so that you query for the length only.
This might work: (again, I've never used that library)
[Only len] <- query_ conn "select count(*) from task" :: IO [Only Int]
answered Nov 22 at 18:21
chi
72.8k280135
72.8k280135
Hi @Chi with a little change it works. Thanks so much to get me on track again. Library is new for me too and on pulling in the entire table like I did, SQLite throws an error anyway. Maybe if others run into this 'problem' and read your reply, here's the modified code that works:conn <- open "taglist.db"n len <- query_ conn "SELECT (id) FROM task" :: IO [Only Int] let showLength = Data.List.length $ len print showLength close conn return ()
– Madderote
Nov 23 at 7:37
@Madderote If you have a completely working code, you can post it answering your own question. StackOverflow's policy encourage self-answers, when they can be useful to others.
– chi
Nov 23 at 12:27
Thanks for the tip. Will do with future issues, which I will encounter for sure ;-)
– Madderote
Nov 23 at 15:06
add a comment |
Hi @Chi with a little change it works. Thanks so much to get me on track again. Library is new for me too and on pulling in the entire table like I did, SQLite throws an error anyway. Maybe if others run into this 'problem' and read your reply, here's the modified code that works:conn <- open "taglist.db"n len <- query_ conn "SELECT (id) FROM task" :: IO [Only Int] let showLength = Data.List.length $ len print showLength close conn return ()
– Madderote
Nov 23 at 7:37
@Madderote If you have a completely working code, you can post it answering your own question. StackOverflow's policy encourage self-answers, when they can be useful to others.
– chi
Nov 23 at 12:27
Thanks for the tip. Will do with future issues, which I will encounter for sure ;-)
– Madderote
Nov 23 at 15:06
Hi @Chi with a little change it works. Thanks so much to get me on track again. Library is new for me too and on pulling in the entire table like I did, SQLite throws an error anyway. Maybe if others run into this 'problem' and read your reply, here's the modified code that works:
conn <- open "taglist.db"n len <- query_ conn "SELECT (id) FROM task" :: IO [Only Int] let showLength = Data.List.length $ len print showLength close conn return ()
– Madderote
Nov 23 at 7:37
Hi @Chi with a little change it works. Thanks so much to get me on track again. Library is new for me too and on pulling in the entire table like I did, SQLite throws an error anyway. Maybe if others run into this 'problem' and read your reply, here's the modified code that works:
conn <- open "taglist.db"n len <- query_ conn "SELECT (id) FROM task" :: IO [Only Int] let showLength = Data.List.length $ len print showLength close conn return ()
– Madderote
Nov 23 at 7:37
@Madderote If you have a completely working code, you can post it answering your own question. StackOverflow's policy encourage self-answers, when they can be useful to others.
– chi
Nov 23 at 12:27
@Madderote If you have a completely working code, you can post it answering your own question. StackOverflow's policy encourage self-answers, when they can be useful to others.
– chi
Nov 23 at 12:27
Thanks for the tip. Will do with future issues, which I will encounter for sure ;-)
– Madderote
Nov 23 at 15:06
Thanks for the tip. Will do with future issues, which I will encounter for sure ;-)
– Madderote
Nov 23 at 15:06
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53436097%2fhaskell-sqlite3-query-all%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown