Code Monkey home page Code Monkey logo

Comments (5)

timmolter avatar timmolter commented on August 29, 2024

So if I understand this correctly, you would want to pass in Integer or Long (or even String?) to the insert method and not be forced to receive a Long?

from yank.

eepstein avatar eepstein commented on August 29, 2024

Sort of. But no need for the type explicitly, it is inferred:

public static <R> R insert(String poolName, String sql, Object[] params) {
    try {
        return new QueryRunner(getDataSource(poolName)).insert(sql, new ScalarHandler<>(), params);
    } catch (SQLException e) {
        throw new WrappedSqlException("Error inserting: " + sql, e);
    }
}

Of course, that’s using 1.7 type erasure, but the essence of the code works in 1.5 (and hence 1.6) too, just need a cast (and perhaps a @SuppressWarnings(“unchecked”)

On Feb 16, 2015, at 10:01 AM, Tim Molter [email protected] wrote:

So if I understand this correctly, you would want to pass in Integer or Long (or even String?) to the insert method and not be forced to receive a Long?


Reply to this email directly or view it on GitHub #23 (comment).

from yank.

timmolter avatar timmolter commented on August 29, 2024

Thanks. I tried this, but using ScalarHandler, I cannot guarantee which type is returned (int, long) and the cast can go wrong, ending up with a java.lang.ClassCastException. My InsertedIDResultSetHandler forces it to always be a long.

from yank.

eepstein avatar eepstein commented on August 29, 2024

Presumably of I created the class that's being inserted I'd also know what type to expect for the ID. And if I ain't sure I can also introspect the type.

Flexibility = power.

Rigidity => brittleness and unnecessary limitation.

On Aug 4, 2016, at 2:13 AM, Tim Molter [email protected] wrote:

Thanks. I tried this, but using ScalarHandler, I cannot guarantee which type is returned (int, long) and the cast can go wrong, ending up with a java.lang.ClassCastException. My InsertedIDResultSetHandler forces it to always be a long.


You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub, or mute the thread.

from yank.

timmolter avatar timmolter commented on August 29, 2024

OK, so your idea was to have the client make the call what type it should be. That makes sense, but I'll need to look at it again to see how to do it. I'll reopen it.

from yank.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.