Intellipaat Back

Explore Courses Blog Tutorials Interview Questions
0 votes
2 views
in SQL by (6.1k points)

I would like to create one derived attribute "Age" which estimates the age of the tuple based on its "Datebought" attribute. I discovered that it can be made with views, although I have no idea where to place the view.

CREATE TABLE Kids_Bike(
    BikeId ID,
    BrandName VARCHAR(max),
    ModelName VARCHAR(max),
    DateBought DATE,
    /*??????????????????????*/
    Age (SELECT datediff(day, DateBought , GETdate()) / 365.2425 ) DECIMAL,
    Color VARCHAR(max),
    StationId ID,
    TrainingWheels BIT,
    PRIMARY KEY (BikeId),
    FOREIGN KEY (StationId) REFERENCES RentingStation(StationID)
);

1 Answer

0 votes
by (12.7k points)

You have to place the view outside the table:

create view v_kids_bike as
    select kb.*, extract(day from (current_date - date_bought)) / 365.2425 as age
    from kids_bike;

If you're using the SQL Server, then you can define the computed column in the create table like this:

Age as (SELECT datediff(day, DateBought, GETdate()) / 365.2425 ),

Sign up for the SQL Course to learn SQL in detail and to get certified.

Related questions

0 votes
2 answers
0 votes
1 answer
0 votes
3 answers
asked Dec 31, 2020 in SQL by Appu (6.1k points)
0 votes
1 answer
asked Dec 16, 2020 in SQL by Appu (6.1k points)

1.2k questions

2.7k answers

501 comments

693 users

Browse Categories

...