Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Insert() returns null on Simple.Data.SqlServer when PK isn't an autoincrementing int #370

Open
jrnail23 opened this issue Jul 16, 2015 · 8 comments

Comments

@jrnail23
Copy link

Here's the reproduction (w/ SQL Server 2012 Express, using Simple.Data.SqlServer):

-- my table definition:
CREATE TABLE [dbo].[Example](
    [ID] [uniqueidentifier] NOT NULL,
    [Name] [varchar](50) NOT NULL,
        CONSTRAINT [PK_Example] PRIMARY KEY CLUSTERED ([ID] ASC))
var example = db.Example.Insert(Name: "some value");

In this case, example always ends up null, unless I change the ID column (the primary key)
to [ID] [int] IDENTITY(1,1)

@ThatRendle
Copy link
Owner

Hi. Yes, at present Simple.Data.SqlServer only returns inserted records when there is an IDENTITY column. v2 should address this.

As a technical note, using uniqueidentifier as a Primary Key is not recommended. Clustered indexes on GUIDs expand at a ridiculous rate. I suggest using an IDENTITY column as the Primary Key and a secondary column with a non-clustered index to hold the GUID. If you also specify newid() as the default for the GUID column, Simple.Data will return the generated value for that column as well.

@skironDotNet
Copy link

If I could click "like" on what markrendle said "As a technical note", I would.
My hint is also that BigInt for Primary Key totally enough. I also had a chance to work with systems where PK was not set auto identity and the ID was generated by DAL using fancy algorithm.
And yes I had a chance to work with GUID type PK and it was super hard to make any SQL investigations, JOINS, and findings, ORDER BY ID is hard with GUID.

If you really want to use GUID, you could disabale identity and work like this

var id = System.Guid.NewGuid()
var example = db.Example.Insert(ID: id, Name: "some value");

@WayneHiller
Copy link

I agree with the "technical note", however there are cases when uniqueidentifier's are invaluable. For example I have built a number of databases that participate in a custom built replication system. Trying to merge records (with child records and relations) without guid primary keys is a nightmare.

The other place that they really helped is that these databases partition data by Customer. So each Customer gets their own copy of data but it is all stored within the same tables. Trying to build composite keys and links to other tables separated by Customer in a setup like this would be horrible.

Mark, how are you doing on Simple.Data 2.0? I know your busy as hell building your cloud services etc. I hope you still find some time to play on that xbox :-)

@ThatRendle
Copy link
Owner

I completely agree that uniqueidentifiers are invaluable for a range of use cases. Many of the databases I design use GUIDs as secondary ID columns, but I always use a BIGINT IDENTITY as the PK.

Simple.Data 2.0-beta1 is on course for a release next month, and I feel a blog post is in order...

@jrnail23
Copy link
Author

Point taken about GUIDs as PKs. Where we do use them, we do either newsequentialid() as default value or a CombGuid generated in the application to mitigate the index fragmentation / performance issues.

@WayneHiller
Copy link

Mark, so then you would use that Secondary key for foreign keys? Interesting, I never thought about it that way.

jrnail23, yes I use newsequentialid() as well. What do you mean by CombGuid?

@jrnail23
Copy link
Author

@WayneHiller, a CombGuid is an algorithm that creates a sequential GUID in application code.
It's used in NHibernate as one of its built-in identity generator strategies, which AFAIK originates here: The Cost of GUIDs as Primary Keys, by Jimmy Nilson.

Also, more info here: GUIDs as fast primary keys under multiple databases

@WayneHiller
Copy link

Thanks @jrnail23, I have cases where I do indeed assign the GUID's from code, especially when doing large data imports, Using CombGuid's in that case would make a lot of sense. Thank you very much for the info :-)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants