This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2018-05-14
Channels
- # architecture (5)
- # beginners (36)
- # boot (3)
- # cider (89)
- # clara (35)
- # cljsrn (6)
- # clojure (123)
- # clojure-dev (15)
- # clojure-italy (9)
- # clojure-nl (14)
- # clojure-spec (11)
- # clojure-uk (192)
- # clojurescript (27)
- # cursive (22)
- # data-science (1)
- # datascript (1)
- # datomic (31)
- # defnpodcast (1)
- # duct (1)
- # emacs (9)
- # fulcro (2)
- # graphql (16)
- # jobs-discuss (10)
- # juxt (1)
- # keechma (7)
- # mount (4)
- # off-topic (83)
- # onyx (8)
- # pedestal (5)
- # portkey (1)
- # re-frame (44)
- # reagent (29)
- # reitit (4)
- # remote-jobs (1)
- # ring-swagger (1)
- # rum (24)
- # shadow-cljs (1)
- # spacemacs (30)
- # tools-deps (6)
- # vim (23)
Morning
How are you doing this morning Dominic?
Tired lol
Morning.
maaning
morning
morning
anyone got an opinion on data-structure representations of SQL queries ? what's good, what's bad, examples ? i'm particularly looking for inspiration on a structure to represent joins. not for a SQL db as it happens, but a join is a join
I’m keeping most of my SQL as strings. It’s a simple approach, but it seems to work well.
@peterwestmacott do you build up your query strings dynamically?
occasionally - but mostly not
mostly the queries are for specific use cases, so they’re hand-crafted SQL
I suppose it's less prevalent within Clojure as it works really well for transforming data after collection
I don’t have the data on prevalence - but it works well for me. I’ve written quite a lot of SQL previously and I think it’s a reasonably good DSL to use.
There may well be better approaches than what I’m doing though.
if i was doing actual SQL i would probably go with the strings or the stringy hugsql approach ... but in this case i'm starting from scratch - there's no underlying join syntax i have to map to, and i don't have to deal with different'db's syntax differences... so a data-structure based DSL seems to make sense
we use the same approach as @peterwestmacott for sql - but I guess the underlying principle is minimal wrapping when appropriate - however we do have a thing that wraps magento "entities" because they are a nightmare and for that we use a datomic pull syntax style
this only came out recently, and wouldn't work in our case, but it's this kind of thing
vectors of keywords represent fields, maps represent joins
“Walkable’s goal is to become the ultimate SQL library for Clojure.”
clearly not written by a brit
otherwise would be "walkable is a little sql datastructure thing, probably no one will be interested in it but I'll put it here on github anyway"
morning all
everybody get some sun in at the weekend?
serious weather chat here
got a bit of sun with my family yesterday painting some new bits of fence in our garden
my wife asked the kids (aged 3 and 5) what colour we should paint it - so it’s painted like a rainbow now
so apparently user research has its limits after all 😂
but then I am a ronseal in brown kinda fence guy so ymmv 🙂
walkable looks interesting, thanks @danieleneal
@mccraigmccraig (also not SQL as it happens, but) I’ve been kicking around ideas for a query scheduler / resolver, and joins are sensitive
instead of representing joined queries, I’ve got a more complicated structure where I can tag fields (in Clojure that would use keywords) and then decide on which fields can be joined
so I guess in case of query representation, it would not be represented as a single merged entity, but as two or more entities with indications of the attributes over which they are joined - sounds kinda graphy
another thing that’s come up for me when investigating joins was (and this is probably more important for scheduling/resolving, but throwing it out there since I don’t know what your ultimate usecase is) metadata, specifically around things like row counts, so that you can decide whether it’s even worth to join, or whether you should perform separate queries.
isn’t that the kind of decision that a good DB query planner should be making for you?
@peterwestmacott even good query planners have their limits - postgres query planner deals with a single join at a time, whereas i want to do n joins in a single pass
also, my db doesn’t support joins at all without spark and spark is great but slow, so i’m doing my own joins
(obvs u can’t do n general joins in one pass, but if the joins are all in the same key you can)
@peterwestmacott if all the queries go to the same datasource, it’s not a problem. But when you need to coordinate several datasources, which contain duplicate data and are not all of the same type, it gets a bit complicated 🙂
ah, yes - then I guess you’d need to take a step back
Treat databases as a local optimisation. http://devcycle.co.uk/software-by-design-part3/#how-to-design-for-change
Whoooooooooo Jade says BACK IN THE ROOM @agile_geek lovely to see you dude!
@jasonbell W00t! So glad to see my sarcasm lives on in my absence Jade!
Morning everyone
you been confined to a corporate bunker @agile_geek ?
@mccraigmccraig some thing like that
haha, so you work for GCHQ now, which obvs you can't answer truthfully 😬
Naw, Government won't have me anymore....too disruptive apparently!
I'm in Leeds ATM (at least for next few months)
You know you're doing well when Govt depts desperate for ppl won't renew your contract!
@alex.lynham Went walking up Rivington Pike with the mutt and some friends, was great 😄
Took the SLR out for the first time in ages too, and then failed to use it in time when I saw a stoat
that (http://devcycle.co.uk/software-by-design-part3) is a good post
ah found it! http://devcycle.co.uk/software-by-design/ this right?
I was also going to ask @agile_geek if you've done the event storming design technique before as a part of that kind of method
people are big on event storming here I think...
I was also going to ask @agile_geek if you've done the event storming design technique before as a part of that kind of method
> failed to use it in time when I saw a stoat I think we an all sympathise with that predicament
welcome back @agile_geek !
Thanks Thomas
@agile_geek the second blog post in that series is chefs_kiss.gif
the stuff on data/domain modelling particularly rings true
@otfrom I haven’t had the chance to use event storming but I think it would work quite well.
I must finish off part 4 of that series but I’m still thinking about what I want it to focus on.
Also there’s some spin off blog posts I have in mind almost as footnotes or appendices to the main post thread
I’m trying to turn it into a talk I can give at a conference my friend Fiona is helping organise in Newcastle in November.
I find it interesting that you folks seem interested in my thoughts on architecture but my previous client didn’t renew my contract because of them!
@mccraigmccraig no they didn't like my thoughts not being group think
sounds like a doomed company @agile_geek, or a public service
some people don’t like it when their employees are smarter… and they remove competition
I think it's more that my torrence for corporate politics has decreased over the years. I just don't play the game anymore
*tolerance
it is quite exhausting to swim upstream in a large org
in my current role I have learned that possibly more important than being right and having the right idea is to introduce those changes at a pace that is compatible with the organisational structure. For example if you are working for an organiation that doesn't have version control, tests, CI/CD etc, you cannot go off an introduce all those things all at once at a high rate of change. Change has to be drop fed so as to get buy in from management, but most importantly from the team members themselves. Start by introducing git, then let that simmer for a week, stir in some linting, let the team adjust, then enforce pull requests etc.
You can't go full fascist on day one. For some organisations that may work, but in most places you slowly have to convert your coworkers over a period of say 3-6 months
^ getting fluent in a new workflow is a significant mental effort and makes a lot of experienced people feel stupid
so if you change too many things at once, it’s like giving an iPhone person an Android phone, or vice versa
Makes people panicky internally, thus generates a lot of resistance related to fear of failure, looking bad in front of others etc.
yeah if you've been repeating yourself for 6-8 months about fixing problems to lots of positive noise but little outcome it can become a bit wearying
sorry, bit of a debbie downer this week, I always get morbid around my birthday
birthdays are such a weird thing to celebrate
Living long is expected now, but i guess a long time ago, life expectancy was much shorter so its celebrated?
Celebrations are about community. Birthdays are people showing you that they’re happy to have you with them.
> Celebrations are about community. Birthdays are people showing you that they’re happy to have you with them. I know, I always feel like an absolute git because I always a) don't want to make a fuss & b) look at what I've achieved in the last year and get down
I should probably just lighten up a bit 🙂
nah this is clojure-uk
if grumbling is welcome anywhere
mine is xmas 🙂
if it helps, I remember reading research showing people’s happiness and life satisfaction is highest at the start and end of life, but drops dramatically in adulthood
❤️ the interactive tagging there @U08TUA46M XD
Since I'm the wrong side of 50, my birthday no longer feels like cause for celebration. My friends and I therefore have a few drinks in honour of World Toilet Day, with which it coincides. :face_with_rolling_eyes:
Wasn't even that drastic. Everyone in project agreed with my tech solutions (I was tech arch). Issue was I didn't have 10 years of org specific knowledge of ppl and processes to navigate. I kept falling fowl of checkpoints because I hadn't talked/cadjoled/begged/ bribed the right ppl cos I didn't know the right ppl. Product owner dismissed me cos she needed someone who could do that. The role description and the actual job requirements were not aligned. No way anyone coming in new could do it in timescales.
was this a govt department or large org?
sounds oddly familiar tho
even if people agree with a call on a technical thing, you either don't have the mandate or the org knowledge to get it anywhere
Mandates are rarely given. Just take it. 😄 It's easier to apologise than ask for permission.
haha easier said than done - where you're dealing with e.g. servers in meatspace on a WAN you can't take what you want, you need permission. There's some things you can do with github and travis and a couple of AWS boxes but they're usually not the hard or the most painful things
although, that's just my experience 🙂
sure, there are obviously exceptions to the sentiment. But if you can use aws, or travis, then just go ahead and commission it.
yeah 💯 %
@cfeckardt lesson to learn if you’re a contractor….can’t apologise when they don’t renew your contract!
Typically as a contractor you're retained for one of two reasons, drive process change or churn out code.
I was supposed to draw diagrams so that they could be shredded by 20+ self important people who couldn't Google CAP theorem let alone understand it!
Not that I'm bitter
You would think that after 11 years of consulting I would have learned…but as I said, my ‘BS’ tolerance has got lower in my old age.
@agile_geek - Amen, Brother...
@maleghast cheers man
It would appear that Slack can't embed .webp so you've just gonna have to download it... 😉
Quick poll... Would anyone in this channel be interested in an online Clojure study group?
To clarify, I'm thinking from all levels of experience (e.g. beginners wanting to learn Clojure through to experienced Clojure devs willing to share their wealth of knowledge/experience)
For anyone that is interested, what sort of times would suit you best? Personally, 8:30pm onwards on a weekday would probably be my preferred option.
I think for me, as due to family reasons i barely have any time, i would be interested in seeing recordings on it too, and seeing what the outcomes were
I am in a similar position. I'd envision this as being a monthly thing (maybe fortnightly at a stretch)
I would definitely be interested but may have to come and go depending on when it happens...
No hard commitments 🙂
I would be, but also in my previous experience (granted with human language study groups) “all levels” doesn’t work
I suppose if various topics were covered over the period of months, some would be expects in certain areas while others might be experts in different areas.
as in, you can’t talk about which library to best use to solve the problem of … let’s say promises, if you’re talking to someone who still struggles to set up their project
(in language groups: you can’t practice language by having a conversation if one of the members is someone who can’t put together a sentence without a lot of “uhhhh” in between)
(I realise this may sound like a “I can’t be bothered to help beginners” impatient pushing; but my experience is actually as someone who was a beginner and didn’t really have a good way to work with a more advanced group in various contexts.)
All valid points
@yogidevbear how would such a thing look?
the #virtual-clj-meetup uses http://crowdcast.io
Yes, was thinking along the lines of Google hangouts to start with
I like crowdcast but it's a minimum of $49/mo
Bit expensive for my personal pocket :)
Main issue with hangouts is it limits participants to 10 I think
Probably not, but if we did then that's a good problem to have
http://meet.google.com - the replacement for hangouts
Oh cool, I hadn't heard of that before 👍
Save time and money by having the team Meet, wherever they are in the world.
- High-definition video meetings with up to 30* participants
- Easy-access meetings – just share a link and anyone can join with one click
- Every meeting has a dial-in number for team members who prefer to call in*
- Integrates directly with Calendar, making it easy to see important meeting details and join instantly
You can always Meet with teams via an invitation, but to enjoy the full capabilities you must use a G Suite-enabled account authorised to use Meet. If you are unsure about your account status, contact your G Suite domain administrator. Find more information at
*Available in G Suite Enterprise Edition
I've got access to a g-suite account so this could work well
But not sure if we'd get more than that to start with