Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 999853
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 16, 20262026-05-16T07:25:04+00:00 2026-05-16T07:25:04+00:00

For example, you have an IRepository interface. You also have a SqlRepository class, which

  • 0

For example, you have an IRepository interface. You also have a SqlRepository class, which implements the interface, backed by a SQL database. Let’s say the constructor for that class takes a connection string. If your repository makes stored procedure calls and if those calls are internal to the repository, isn’t that a hidden dependency? Your repository is dependant not only on the database connection specified by the connection string, it’s also dependant on the database having the proper stored procedures installed. If your backing database doesn’t have those stored procedures, your program will crash. How would you know what stored procedures have to be installed in order for your program to run if you didn’t have access to the SqlRepository‘s code? Is this the type of hidden dependency that makes DI advocates cringe?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-16T07:25:05+00:00Added an answer on May 16, 2026 at 7:25 am

    Yes. The problem is that there’s no way to impose contracts on SQL databases (contracts in the object-oriented sense).

    That is, we don’t have any way to say that a database conforms to an IPersonRepository interface, so we can’t be certain that it implements a procedure “dbo.GetPerson” which returns two resultsets with columns a, b, c, and d. (Or that we have permission to execute that procedure.) Therefore we can’t require an IPersonRepository in our connection string.

    Mature object-relational mappers like (N)Hibernate solve this problem by creating domain-specific languages to describe those expectations (their elaborate configuration specifications), but those techniques are only a partial solution, because they can’t be enforced on the database side.

    This is another facet of the object-relational impedance mismatch, albeit one about which I haven’t seen anything written.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Let's say I have a service interface that looks like this: public interface IFooService
Example I have a repository class (DAL): public class MyRepository : IMyRepository { public
In the simplified example below I have a DataContext and Repository which I think
Example: I have an class that inherits from UIImageView. An object creates an instance
Example: I have a selector like this, which I give to another method as
Example-I have a person class Public Class Person Private _fname As String Public Property
I have an interface, called IRepository. One of the methods in this interface is:
I have an interface IRepository and an implementation EFRepository. I use structuremap injection in
I have the following interface called IAccountService. I also have exactly the same interfaces
If I for example have <p> some long text </p> on my HTML page,

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.