Is it a good idea to use COLUMN AS (left([Another_Column],(4)) instead of LEFT in the select?Which problems arise, declaring the size of all varchar parameters as max in stored proc?How to add/update a column with an incremented value and reset said value based on another column in SQLCan I create a computed column that requires input to select?Can I tell SQL Server not to place data in the buffer cache?Storing NULL versus storing '' in a varchar columnSQL Server - Sudden log autogrowth after database backupProper table design for sparse primary keyWhy did my database size almost double over night?Reclaim space from dropped column in SQLServer2008R2Group by sum based on under group in SQL Server
Prime joint compound before latex paint?
Why airport relocation isn't done gradually?
Is there a name of the flying bionic bird?
Denied boarding due to overcrowding, Sparpreis ticket. What are my rights?
Should the British be getting ready for a no-deal Brexit?
Email Account under attack (really) - anything I can do?
Where to refill my bottle in India?
aging parents with no investments
Why do we use polarized capacitors?
What to wear for invited talk in Canada
Copycat chess is back
Why is the design of haulage companies so “special”?
Is there a familial term for apples and pears?
How to deal with fear of taking dependencies
What are the advantages and disadvantages of running one shots compared to campaigns?
Domain expired, GoDaddy holds it and is asking more money
Map list to bin numbers
"My colleague's body is amazing"
Shall I use personal or official e-mail account when registering to external websites for work purpose?
extract characters between two commas?
Can I legally use front facing blue light in the UK?
Does it makes sense to buy a new cycle to learn riding?
Why doesn't a const reference extend the life of a temporary object passed via a function?
A poker game description that does not feel gimmicky
Is it a good idea to use COLUMN AS (left([Another_Column],(4)) instead of LEFT in the select?
Which problems arise, declaring the size of all varchar parameters as max in stored proc?How to add/update a column with an incremented value and reset said value based on another column in SQLCan I create a computed column that requires input to select?Can I tell SQL Server not to place data in the buffer cache?Storing NULL versus storing '' in a varchar columnSQL Server - Sudden log autogrowth after database backupProper table design for sparse primary keyWhy did my database size almost double over night?Reclaim space from dropped column in SQLServer2008R2Group by sum based on under group in SQL Server
.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty margin-bottom:0;
I came across a table like this:
CREATE TABLE TABLE1
(
CD1 int
,CD2 varchar(16)
,CD3 varchar(21)
,CD4 decimal(14,0)
,CD5 varchar(4)
,CD6 decimal(18,2)
,CD7 AS (left([CD3],(4)))
)
This table has more than 4 BILLION rows (totally unnecessary, but this is another topic).
As you can see in the last column, they use AS (left([CD3],(4)))
. I think this is pretty useless, since we almost NEVER have a SELECT on this table, and here is just using space.
Isn't it better to select that field during the select when needed?
sql-server sql-server-2008-r2 t-sql
add a comment |
I came across a table like this:
CREATE TABLE TABLE1
(
CD1 int
,CD2 varchar(16)
,CD3 varchar(21)
,CD4 decimal(14,0)
,CD5 varchar(4)
,CD6 decimal(18,2)
,CD7 AS (left([CD3],(4)))
)
This table has more than 4 BILLION rows (totally unnecessary, but this is another topic).
As you can see in the last column, they use AS (left([CD3],(4)))
. I think this is pretty useless, since we almost NEVER have a SELECT on this table, and here is just using space.
Isn't it better to select that field during the select when needed?
sql-server sql-server-2008-r2 t-sql
1
There is a thin chance of getting some more usable statistics. Other than that, probably nothing. But it doesn't use space either :)
– dean
Mar 28 at 18:12
add a comment |
I came across a table like this:
CREATE TABLE TABLE1
(
CD1 int
,CD2 varchar(16)
,CD3 varchar(21)
,CD4 decimal(14,0)
,CD5 varchar(4)
,CD6 decimal(18,2)
,CD7 AS (left([CD3],(4)))
)
This table has more than 4 BILLION rows (totally unnecessary, but this is another topic).
As you can see in the last column, they use AS (left([CD3],(4)))
. I think this is pretty useless, since we almost NEVER have a SELECT on this table, and here is just using space.
Isn't it better to select that field during the select when needed?
sql-server sql-server-2008-r2 t-sql
I came across a table like this:
CREATE TABLE TABLE1
(
CD1 int
,CD2 varchar(16)
,CD3 varchar(21)
,CD4 decimal(14,0)
,CD5 varchar(4)
,CD6 decimal(18,2)
,CD7 AS (left([CD3],(4)))
)
This table has more than 4 BILLION rows (totally unnecessary, but this is another topic).
As you can see in the last column, they use AS (left([CD3],(4)))
. I think this is pretty useless, since we almost NEVER have a SELECT on this table, and here is just using space.
Isn't it better to select that field during the select when needed?
sql-server sql-server-2008-r2 t-sql
sql-server sql-server-2008-r2 t-sql
edited Mar 28 at 19:41
Josh Darnell
7,89022243
7,89022243
asked Mar 28 at 12:48
Racer SQLRacer SQL
3,10642565
3,10642565
1
There is a thin chance of getting some more usable statistics. Other than that, probably nothing. But it doesn't use space either :)
– dean
Mar 28 at 18:12
add a comment |
1
There is a thin chance of getting some more usable statistics. Other than that, probably nothing. But it doesn't use space either :)
– dean
Mar 28 at 18:12
1
1
There is a thin chance of getting some more usable statistics. Other than that, probably nothing. But it doesn't use space either :)
– dean
Mar 28 at 18:12
There is a thin chance of getting some more usable statistics. Other than that, probably nothing. But it doesn't use space either :)
– dean
Mar 28 at 18:12
add a comment |
2 Answers
2
active
oldest
votes
If the computed column isn't persisted or indexed, it's only a virtual column (expression), and it's not taking up any "space".
add a comment |
The only reason I can think of for having that column is to index it, because there is some common set of read queries that filter on the first few characters in CD3
.
If the computed column is, indeed, indexed, then the it's valuable because:
- it would required less storage than the full 21 char column
- it would incur less page reads for seeks and scans than an index on the full 21 char column
You mentioned the table is rarely read, but I would check for indexes that use this computed column to be sure.
If it's not indexed, then see Erik's answer about the storage aspect of non-persisted computed columns.
add a comment |
Your Answer
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "182"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdba.stackexchange.com%2fquestions%2f233382%2fis-it-a-good-idea-to-use-column-as-leftanother-column-4-instead-of-left-i%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
2 Answers
2
active
oldest
votes
2 Answers
2
active
oldest
votes
active
oldest
votes
active
oldest
votes
If the computed column isn't persisted or indexed, it's only a virtual column (expression), and it's not taking up any "space".
add a comment |
If the computed column isn't persisted or indexed, it's only a virtual column (expression), and it's not taking up any "space".
add a comment |
If the computed column isn't persisted or indexed, it's only a virtual column (expression), and it's not taking up any "space".
If the computed column isn't persisted or indexed, it's only a virtual column (expression), and it's not taking up any "space".
answered Mar 28 at 12:49
Erik DarlingErik Darling
22.7k1269113
22.7k1269113
add a comment |
add a comment |
The only reason I can think of for having that column is to index it, because there is some common set of read queries that filter on the first few characters in CD3
.
If the computed column is, indeed, indexed, then the it's valuable because:
- it would required less storage than the full 21 char column
- it would incur less page reads for seeks and scans than an index on the full 21 char column
You mentioned the table is rarely read, but I would check for indexes that use this computed column to be sure.
If it's not indexed, then see Erik's answer about the storage aspect of non-persisted computed columns.
add a comment |
The only reason I can think of for having that column is to index it, because there is some common set of read queries that filter on the first few characters in CD3
.
If the computed column is, indeed, indexed, then the it's valuable because:
- it would required less storage than the full 21 char column
- it would incur less page reads for seeks and scans than an index on the full 21 char column
You mentioned the table is rarely read, but I would check for indexes that use this computed column to be sure.
If it's not indexed, then see Erik's answer about the storage aspect of non-persisted computed columns.
add a comment |
The only reason I can think of for having that column is to index it, because there is some common set of read queries that filter on the first few characters in CD3
.
If the computed column is, indeed, indexed, then the it's valuable because:
- it would required less storage than the full 21 char column
- it would incur less page reads for seeks and scans than an index on the full 21 char column
You mentioned the table is rarely read, but I would check for indexes that use this computed column to be sure.
If it's not indexed, then see Erik's answer about the storage aspect of non-persisted computed columns.
The only reason I can think of for having that column is to index it, because there is some common set of read queries that filter on the first few characters in CD3
.
If the computed column is, indeed, indexed, then the it's valuable because:
- it would required less storage than the full 21 char column
- it would incur less page reads for seeks and scans than an index on the full 21 char column
You mentioned the table is rarely read, but I would check for indexes that use this computed column to be sure.
If it's not indexed, then see Erik's answer about the storage aspect of non-persisted computed columns.
answered Mar 28 at 19:40
Josh DarnellJosh Darnell
7,89022243
7,89022243
add a comment |
add a comment |
Thanks for contributing an answer to Database Administrators Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fdba.stackexchange.com%2fquestions%2f233382%2fis-it-a-good-idea-to-use-column-as-leftanother-column-4-instead-of-left-i%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
-sql-server, sql-server-2008-r2, t-sql
1
There is a thin chance of getting some more usable statistics. Other than that, probably nothing. But it doesn't use space either :)
– dean
Mar 28 at 18:12