Is it a good idea to use COLUMN AS (left([Another_Column],(4)) instead of LEFT in the select? The Next CEO of Stack OverflowWhich 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
How to pronounce the slash sign
Is it my responsibility to learn a new technology in my own time my employer wants to implement?
Return of the Riley Riddles in Reverse
Crossing the line between justified force and brutality
Can a caster that cast Polymorph on themselves stop concentrating at any point even if their Int is low?
Can someone shed some light on this inequality?
Was a professor correct to chastise me for writing "Prof. X" rather than "Professor X"?
How long to clear the 'suck zone' of a turbofan after start is initiated?
Unreliable Magic - Is it worth it?
Understanding "table margins"
How should I support this large drywall patch?
% symbol leads to superlong (forever?) compilations
What does this shorthand mean?
Return the Closest Prime Number
Is a stroke of luck acceptable after a series of unfavorable events?
What is the point of a new vote on May's deal when the indicative votes suggest she will not win?
Why doesn't a table tennis ball float on the surface? How do we calculate buoyancy here?
declare as function pointer and initialize in the same line
How to Reset Passwords on Multiple Websites Easily?
What can we do to stop prior company from asking us questions?
Anatomically Correct Strange Women In Ponds Distributing Swords
How easy is it to start Magic from scratch?
Can the Reverse Gravity spell affect the Meteor Swarm spell?
India just shot down a satellite from the ground. At what altitude range is the resulting debris field?
Is it a good idea to use COLUMN AS (left([Another_Column],(4)) instead of LEFT in the select?
The Next CEO of Stack OverflowWhich 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
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
There is a thin chance of getting some more usable statistics. Other than that, probably nothing. But it doesn't use space either :)
– dean
1 hour ago
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 9 mins ago
Josh Darnell
7,23522141
7,23522141
asked 7 hours ago
Racer SQLRacer SQL
3,10142562
3,10142562
There is a thin chance of getting some more usable statistics. Other than that, probably nothing. But it doesn't use space either :)
– dean
1 hour ago
add a comment |
There is a thin chance of getting some more usable statistics. Other than that, probably nothing. But it doesn't use space either :)
– dean
1 hour ago
There is a thin chance of getting some more usable statistics. Other than that, probably nothing. But it doesn't use space either :)
– dean
1 hour ago
There is a thin chance of getting some more usable statistics. Other than that, probably nothing. But it doesn't use space either :)
– dean
1 hour ago
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');
var $window = $(window),
onScroll = function(e)
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom))
StackExchange.using('gps', function() StackExchange.gps.track('embedded_signup_form.view', location: 'question_page' ); );
$window.unbind('scroll', onScroll);
;
$window.on('scroll', onScroll);
);
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 7 hours ago
Erik DarlingErik Darling
22.2k1269111
22.2k1269111
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 10 mins ago
Josh DarnellJosh Darnell
7,23522141
7,23522141
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');
var $window = $(window),
onScroll = function(e)
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom))
StackExchange.using('gps', function() StackExchange.gps.track('embedded_signup_form.view', location: 'question_page' ); );
$window.unbind('scroll', onScroll);
;
$window.on('scroll', onScroll);
);
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');
var $window = $(window),
onScroll = function(e)
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom))
StackExchange.using('gps', function() StackExchange.gps.track('embedded_signup_form.view', location: 'question_page' ); );
$window.unbind('scroll', onScroll);
;
$window.on('scroll', onScroll);
);
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');
var $window = $(window),
onScroll = function(e)
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom))
StackExchange.using('gps', function() StackExchange.gps.track('embedded_signup_form.view', location: 'question_page' ); );
$window.unbind('scroll', onScroll);
;
$window.on('scroll', onScroll);
);
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');
var $window = $(window),
onScroll = function(e)
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom))
StackExchange.using('gps', function() StackExchange.gps.track('embedded_signup_form.view', location: 'question_page' ); );
$window.unbind('scroll', onScroll);
;
$window.on('scroll', onScroll);
);
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
There is a thin chance of getting some more usable statistics. Other than that, probably nothing. But it doesn't use space either :)
– dean
1 hour ago