postgresql 练习题(一)

  1. 根据数据字典,查询当前用户下有哪些表 
    select tablename from pg_tables where schemaname='public'
  2. 查询所有员工编号,员工姓名、邮件、雇佣日期、部门、部门详细地址信息。
    select employees.employee_id,
    employees.first_name||employees.last_name as full_name,employees.email,employees.hire_date,departments.department_name,locations.street_address
    
    from employees,departments,locations
    where employees.department_id=departments.department_id  
    and departments.location_id=locations.location_id;
  3. 查询1997年入职员工员工编号,员工姓名,雇佣日期,工龄(保留2位小数)、按照First_Name升序排列
    SELECT
    employee_id,
    first_name,
    last_name,
    hire_date,
    ROUND( ( ( CURRENT_DATE - hire_date ) / 365 ), 2 )
    
    FROM employees
    WHERE EXTRACT ( YEAR FROM hire_date ) = 1997
    ORDER BY first_name;
  4. 显示姓、薪水,佣金(commission) ,然后按薪水降序排列
    select first_name,salary,commission_pct as commissions
    from employees
    where commission_pct IS NOT NULL
    order by salary desc;
  5. 显示姓名、薪水,佣金(commission),佣金为空的,统一加上0.05;其余的加上0.03,按照薪资降序、变更后佣金升序排列
    select first_name,last_name,salary,coalesce(commission_pct+0.03,0.05) as commissions
    from employees
    order by salary desc,commissions asc;
  6. 显示名字以J、K、L、M开头的雇员
    SELECT * FROM employees
    WHERE last_name LIKE 'J%'
    or last_name LIKE 'K%'
    or last_name LIKE 'L%'
    or last_name LIKE 'M%';
  7. 显示员工姓名,薪水,调整后薪水(按部门调整:IT提升30%,Salse 提升50%、其余部门提升20%);按照调整后薪水升序排列
    SELECT e.first_name||e.last_name as full_name,e.salary,
    
    CASE d.department_name
    WHEN 'IT' THEN e.salary * 1.2
    WHEN 'Sales' THEN e.salary * 1.5 
    ELSE e.salary * 1.2
    END AS new_salary
    
    FROM employees e, department d
    WHERE e.department_id = d.department_id
    ORDER BY new_salary ASC;
  8. 显示在每月中旬雇佣的员工,显示姓名,雇佣日期
    select first_name || last_name as full_name,hire_date
    from employees
    where extract ( day from hire_date ) between 11 and 20;
     

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PostgreSQL进行查询练习时,可以使用SELECT语句来检索数据。例如,要检索名为COMPANY的表的所有数据,可以使用以下查询语句: SELECT * FROM COMPANY; 这将返回COMPANY表的所有行和列的数据。 如果要根据特定条件进行筛选,可以使用WHERE子句。例如,要检索年龄大于30岁的员工,可以使用以下查询语句: SELECT * FROM COMPANY WHERE AGE > 30; 还可以使用ORDER BY子句对结果进行排序。例如,要按工资从高到低的顺序检索员工数据,可以使用以下查询语句: SELECT * FROM COMPANY ORDER BY SALARY DESC; 此外,还可以使用LIMIT子句限制返回的行数。例如,要检索前5个员工的数据,可以使用以下查询语句: SELECT * FROM COMPANY LIMIT 5; 这些是一些基本的查询练习示例,你可以根据需要进行进一步的练习和探索。 #### 引用[.reference_title] - *1* *2* [通俗易懂的学会SQL,30道练习题PostgreSQL基础版)](https://blog.csdn.net/weixin_41645135/article/details/124396005)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [【postgreSQL 练习】](https://blog.csdn.net/weixin_43496777/article/details/125883953)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值