<div class="gmail_quote">On Tue, Jan 25, 2011 at 9:48 AM, Adam Ruppe <span dir="ltr"><<a href="mailto:destructionator@gmail.com">destructionator@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
<div class="im">Piotr Szturmaj wrote:<br>
> I already have working postgresql row querying. There are typed and<br>
> untyped rows. Untyped row is DBRow!(Variant[]), typed rows are<br>
> encapsulated using struct or tuple, for example:<br>
<br>
</div>Very nice! I did something similar in two cases: one is the<br>
byStruct in mysql.d (currently commented out - it was rather buggy<br>
anyway) and the other is the next(T..) function in sqlite.<br>
<br>
<br>
byStruct translated a textual mysql row into the given struct, by<br>
translating the names:<br>
<br>
foreach(member; __traits(allMembers, S)) {<br>
S.member = to!(typeof(S.member))(db_row[member]);<br>
}<br>
return S;<br>
<br>
(pseudocode just to show the idea).<br>
<br>
<br>
My implementation was always a little buggy though, so I didn't<br>
use it much. I still like the idea though!<br>
<br>
<br>
The other thing is to fill in a bunch of local variables. This<br>
was my first attempt at database in D, written before we had<br>
immutable and half of Phobos. You can see some of it in sqlite.d:<br>
<br>
auto db_statement = db.prepare("SELECT id, name FROM users");<br>
<br>
string name;<br>
int id;<br>
<br>
db_statement.execute();<br>
<br>
while(db_statement.next(id, name)) {<br>
// the variables id and name are now filled in with the row<br>
}<br>
<br>
<br>
It would fill them in positionally, and coerce the type from the<br>
db to match the variables passed in. I don't remember why I abandoned<br>
that. I think it was just a long gap between writing it and the next<br>
time I needed a database, which was mysql, so the sqlite module didn't<br>
get reused.<br>
<br>
It's a little tedious to use anyway though. I prefer having all<br>
the variables in the scope of the loop, rather than outside like<br>
it is here.<br>
<br>
<br>
<br>
<br>
But anyway, returning a Tuple!() is something I've never tried,<br>
I like the idea.<br>
<div class="im"><br>
<br>
> I've also written simple ORM mapping - creating and managing tables<br>
> based on struct layout. I see your solution is in opposite -<br>
> creating structs/classes based on SQL CREATE scripts.<br>
<br>
</div>Yeah, the main reason there is all my attempts to go struct > sql<br>
ended up being pretty sucky.<br>
<br>
I'd start with a basic struct. Getting it to a simple create table<br>
command is pretty straightforward (hey, remember that post a month<br>
or two ago where someone did that in Go and was like "yay Go rocks!"<br>
That thread is actually what inspired the subject to this thread.)<br>
<br>
But, a real database has a lot of constraints on top of that -<br>
field lengths, foreign keys, checks, and so on.<br>
<br>
I tried two approaches: one was magic. Add stuff based on the names<br>
and types, so assume "int id" is a primary key, for example.<br>
<br>
Didn't work in practice. What about a table with a primary key<br>
that spans two columns?<br></blockquote><div><br></div><div>I know I keep beating this horse, but in other languages, this is the textbook example for why annotations are useful. Adding metadata to code, even if it can only be examined at compile time, can be immensely useful.</div>
</div>