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

Done #9

Open
wants to merge 1 commit into
base: main
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
30 changes: 30 additions & 0 deletions queries.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,94 +8,124 @@

<!-- Your Query Goes Here -->

INSERT INTO jslibraries(name, owner, description, stars, url, releases, licence, used_by, contributors, main_technology, type,release_date)
VALUES
('solid', 'solid', 'A declarative, efficient, and flexible JavaScript library for building user interfaces.', 175000,'solid.org', 138, 'MIT License', 7400000, 1501, 'javascript', 'SPA library', '2014-08-23'),
('chartjs', 'chartjs', 'A declarative, efficient, and flexible JavaScript library for building user interfaces.', 176000,'chart.org', 138, 'MIT License', 7400000, 1501, 'javascript', 'SPA library', '2014-08-23');
<br>

**2. Get all the fields of the library that was released earliest (first).**

<!-- Your Query Goes Here -->

SELECT \* FROM jslibraries
ORDER BY release_date ASC;
<br>

**3. Get all the fields of the library that was released most recently (last).**

<!-- Your Query Goes Here -->

SELECT \* FROM jslibraries
ORDER BY release_date DESC
LIMIT 1;
<br>

**4. All the libraries released before 2015.**

<!-- Your Query Goes Here -->

SELECT \* from jslibraries
WHERE release_date < '2015-01-01';
<br>

**5. Get the `name` and the `release_date` of the libraries without a licence.**

<!-- Your Query Goes Here -->

SELECT name, release_date from jslibraries
WHERE licence IS NULL;
<br>

**6. Get the `name` and the `stars` from all CSS Framework libraries.**

<!-- Your Query Goes Here -->

SELECT name, stars from jslibraries
WHERE description LIKE '%CSS%';
<br>

**7. Get the `name` of the libraries where the main technology is Typescript.**

<!-- Your Query Goes Here -->

SELECT name from jslibraries
WHERE main_technology = 'typescript';
<br>

**8. Get the `name` and the `type` of all the libraries with more than 1000 contributors.**

<!-- Your Query Goes Here -->

SELECT name, type from jslibraries
WHERE contributors > 1000;
<br>

**9. Get the total number of `stars` of all the libraries.**

<!-- Your Query Goes Here -->

SELECT SUM (stars) AS total_stars FROM jslibraries;
<br>

**10. Get the average number of `contributors` for all the libraries.**

<!-- Your Query Goes Here -->

SELECT AVG(contributors) FROM jslibraries;
<br>

**11. Update the `licence` field of the libriaries without a licence to store `'unknown'` instead of `NULL`.**

<!-- Your Query Goes Here -->

UPDATE jslibraries SET licence='unknown' WHERE licence IS NULL;
<br>

**12. Update the `used_by` field of the libraries that don't have this information to store `'unknown'` instead of `NULL`.**

<!-- Your Query Goes Here -->

UPDATE jslibraries
SET used_by = 0
WHERE used_by IS NULL;
<br>

**13. Update all the records to capitalize the string provided in the `main_technology` field.**

<!-- Your Query Goes Here -->

UPDATE jslibraries
SET main_technology = CONCAT(UPPER(LEFT(main_technology, 1)), LOWER(SUBSTRING(main_technology, 2)));
<br>

**14. Delete all the records where `licence` is `'unknown'`.**

<!-- Your Query Goes Here -->

DELETE FROM jslibraries WHERE licence = 'unknown';
<br>

**15. Delete all the records with 10000 or less `stars`.**

<!-- Your Query Goes Here -->

DELETE FROM jslibraries WHERE stars <= 10000;
<br>

**16. Delete all the records with less than 100 `releases`.**

<!-- Your Query Goes Here -->

DELETE FROM jslibraries WHERE releases < 100;
<br>