Skip to content
By using Twitter’s services you agree to our Cookies Use. We and our partners operate globally and use cookies, including for analytics, personalisation, and ads.
  • Home Home Home, current page.
  • About

Saved searches

  • Remove
  • In this conversation
    Verified accountProtected Tweets @
Suggested users
  • Verified accountProtected Tweets @
  • Verified accountProtected Tweets @
  • Language: English
    • Bahasa Indonesia
    • Bahasa Melayu
    • Català
    • Čeština
    • Dansk
    • Deutsch
    • English UK
    • Español
    • Filipino
    • Français
    • Hrvatski
    • Italiano
    • Magyar
    • Nederlands
    • Norsk
    • Polski
    • Português
    • Română
    • Slovenčina
    • Suomi
    • Svenska
    • Tiếng Việt
    • Türkçe
    • Ελληνικά
    • Български език
    • Русский
    • Српски
    • Українська мова
    • עִבְרִית
    • العربية
    • فارسی
    • मराठी
    • हिन्दी
    • বাংলা
    • ગુજરાતી
    • தமிழ்
    • ಕನ್ನಡ
    • ภาษาไทย
    • 한국어
    • 日本語
    • 简体中文
    • 繁體中文
  • Have an account? Log in
    Have an account?
    · Forgot password?

    New to Twitter?
    Sign up
sgrif's profile
Miss Dada 🏳️‍⚧️
Miss Dada 🏳️‍⚧️
Miss Dada  🏳️‍⚧️
@sgrif

Tweets

Miss Dada  🏳️‍⚧️

@sgrif

Co lead of the http://crates.io  team. Creator of @dieselframework. Former host of @_bikeshed and @_yakshave. Former Rails comitter. Enby. they/them

Albuquerque, NM
patreon.com/seantheprogram…
Joined November 2008

Tweets

  • © 2020 Twitter
  • About
  • Help Center
  • Terms
  • Privacy policy
  • Imprint
  • Cookies
  • Ads info
Dismiss
Previous
Next

Go to a person's profile

Saved searches

  • Remove
  • In this conversation
    Verified accountProtected Tweets @
Suggested users
  • Verified accountProtected Tweets @
  • Verified accountProtected Tweets @

Promote this Tweet

Block

  • Tweet with a location

    You can add location information to your Tweets, such as your city or precise location, from the web and via third-party applications. You always have the option to delete your Tweet location history. Learn more

    Your lists

    Create a new list


    Under 100 characters, optional

    Privacy

    Copy link to Tweet

    Embed this Tweet

    Embed this Video

    Add this Tweet to your website by copying the code below. Learn more

    Add this video to your website by copying the code below. Learn more

    Hmm, there was a problem reaching the server.

    By embedding Twitter content in your website or app, you are agreeing to the Twitter Developer Agreement and Developer Policy.

    Preview

    Why you're seeing this ad

    Log in to Twitter

    · Forgot password?
    Don't have an account? Sign up »

    Sign up for Twitter

    Not on Twitter? Sign up, tune into the things you care about, and get updates as they happen.

    Sign up
    Have an account? Log in »

    Two-way (sending and receiving) short codes:

    Country Code For customers of
    United States 40404 (any)
    Canada 21212 (any)
    United Kingdom 86444 Vodafone, Orange, 3, O2
    Brazil 40404 Nextel, TIM
    Haiti 40404 Digicel, Voila
    Ireland 51210 Vodafone, O2
    India 53000 Bharti Airtel, Videocon, Reliance
    Indonesia 89887 AXIS, 3, Telkomsel, Indosat, XL Axiata
    Italy 4880804 Wind
    3424486444 Vodafone
    » See SMS short codes for other countries

    Confirmation

     

    Welcome home!

    This timeline is where you’ll spend most of your time, getting instant updates about what matters to you.

    Tweets not working for you?

    Hover over the profile pic and click the Following button to unfollow any account.

    Say a lot with a little

    When you see a Tweet you love, tap the heart — it lets the person who wrote it know you shared the love.

    Spread the word

    The fastest way to share someone else’s Tweet with your followers is with a Retweet. Tap the icon to send it instantly.

    Join the conversation

    Add your thoughts about any Tweet with a Reply. Find a topic you’re passionate about, and jump right in.

    Learn the latest

    Get instant insight into what people are talking about now.

    Get more of what you love

    Follow more accounts to get instant updates about topics you care about.

    Find what's happening

    See the latest conversations about any topic instantly.

    Never miss a Moment

    Catch up instantly on the best stories happening as they unfold.

    1. Gary Bernhardt‏ @garybernhardt 28 Mar 2019
      • Report Tweet
      • Report NetzDG Violation

      I figured it out. Update triggers don't fire for modifications to a row created in the current transaction. If you begin, insert a row, and modify that row, "before update" triggers won't fire. But if you insert a row, begin, and modify that row, the triggers will fire.

      3 replies 0 retweets 9 likes
      Show this thread
    2. Gary Bernhardt‏ @garybernhardt 28 Mar 2019
      • Report Tweet
      • Report NetzDG Violation

      I am vexed.

      1 reply 0 retweets 3 likes
      Show this thread
    3. Gary Bernhardt‏ @garybernhardt 28 Mar 2019
      • Report Tweet
      • Report NetzDG Violation

      I'm using this trigger to update the `updated_at` fields of tables whenever they change. A correct `updated_at` might theoretically be important, even inside a transaction where the row was created and then modified. So this seems like a big problem.

      4 replies 0 retweets 2 likes
      Show this thread
    4. Gary Bernhardt‏ @garybernhardt 28 Mar 2019
      • Report Tweet
      • Report NetzDG Violation

      Admittedly, the probability of this mattering in production code is relatively small. My actual immediate problem is that all tests are run inside a transaction, and I want to write a test for this updated_at behavior, and I can't!

      1 reply 0 retweets 4 likes
      Show this thread
    5. Gary Bernhardt‏ @garybernhardt 28 Mar 2019
      • Report Tweet
      • Report NetzDG Violation

      Gary Bernhardt Retweeted Miss Dada  🏳️‍⚧️

      Apparently this was all wrong. My problem was that neither now() nor CURRENT_TIMESTAMP changes during a transaction. But there is clock_timestamp(), which does change. Thank you @sgrif, as usual!https://twitter.com/sgrif/status/1111368222861746176 …

      Gary Bernhardt added,

      Miss Dada  🏳️‍⚧️ @sgrif
      Replying to @garybernhardt
      `CURRENT_TIMESTAMP` never changes inside a transaction, so `updated_at` will be the same regardless of whether the trigger runs or not
      6 replies 2 retweets 43 likes
      Show this thread
    6. Miss Dada  🏳️‍⚧️‏ @sgrif 28 Mar 2019
      • Report Tweet
      • Report NetzDG Violation
      Replying to @garybernhardt

      FWIW I think using `CURRENT_TIMESTAMP` is what users would expect. Assuming you're testing the trigger in general, and not that it's created for specific tables, you can test by creating a new table in the test outside a transaction. https://github.com/diesel-rs/diesel/blob/50798e5dd52ae9d3c7c9a4bf7a5f1e5b9167aba3/diesel_tests/tests/connection.rs#L12-L75 …

      1 reply 0 retweets 0 likes
    7. Miss Dada  🏳️‍⚧️‏ @sgrif 28 Mar 2019
      • Report Tweet
      • Report NetzDG Violation
      Replying to @sgrif @garybernhardt

      (Our trigger and helper function https://github.com/diesel-rs/diesel/blob/50798e5dd52ae9d3c7c9a4bf7a5f1e5b9167aba3/diesel_cli/src/setup_sql/postgres/initial_setup/up.sql#L8-L36 …)

      1 reply 0 retweets 0 likes
    8. Gary Bernhardt‏ @garybernhardt 28 Mar 2019
      • Report Tweet
      • Report NetzDG Violation
      Replying to @sgrif

      I agree that using CURRENT_TIMESTAMP is the most sensible. I guess I can write this test to use raw SQL, create the temporary table like you suggest, but `drop table if exists` first to clean up any that get left over from previous test runs.

      2 replies 0 retweets 1 like
    9. Gary Bernhardt‏ @garybernhardt 28 Mar 2019
      • Report Tweet
      • Report NetzDG Violation
      Replying to @garybernhardt @sgrif

      Does Diesel provide any way to guarantee that this trigger is in place? Or would it let you create a purported `updated_at` column and forget to call that trigger-creation function?

      1 reply 0 retweets 0 likes
    10. Miss Dada  🏳️‍⚧️‏ @sgrif 28 Mar 2019
      • Report Tweet
      • Report NetzDG Violation
      Replying to @garybernhardt

      The latter. Our migrations are just plain SQL files, so it's on you to remember to call `diesel_manage_updated_at` after creating the table. I like the idea of providing a function that tests if any tables exist with a column called `updated_at` but don't have the trigger

      1 reply 0 retweets 0 likes
      Miss Dada  🏳️‍⚧️‏ @sgrif 28 Mar 2019
      • Report Tweet
      • Report NetzDG Violation
      Replying to @sgrif @garybernhardt

      An interesting side effect of using SQL files for migrations is that our CLI tool/migration infrastructure isn't actually coupled to Rust or Diesel at all

      2:10 PM - 28 Mar 2019
      • 1 Like
      • Gerard Klijs
      0 replies 0 retweets 1 like

      Loading seems to be taking a while.

      Twitter may be over capacity or experiencing a momentary hiccup. Try again or visit Twitter Status for more information.

        Promoted Tweet

        false

        • © 2020 Twitter
        • About
        • Help Center
        • Terms
        • Privacy policy
        • Imprint
        • Cookies
        • Ads info