Mysql表,列,库增删改查问题小结

所属分类: 数据库 / Mysql 阅读数: 177
收藏 0 赞 0 分享

下面是我总结的一些基础的sql知识,主要是为了以后更好的查阅和帮助其他初学的人,同时记录自己的成长,还写了一点稍有

难度的sql面试题级别的题目,好了废话不多说,见真题。。。

#创建数据库
CREATE DATABASE mytest CHARACTER SET gbk
#删除数据库
DROP DATABASE mytest
表的操作
#创建表(create table 表名(columns))
CREATE TABLE students(
id INT PRIMARY KEY,
NAME CHAR(10) NOT NULL,
sex CHAR(4) NOT NULL
);
#删除表(drop table 表名)
DROP TABLE students
#在表格中插入数据(insert into 表名(属性) values(对应的值))
INSERT INTO students(id,NAME,sex) VALUES(1,"张三","男")
#更新表格数据(update 表名 set 键=值,键=值 where 条件)中间要用“,”隔开,其他的无效  set只需写一个
UPDATE students SET id=2 , NAME="a" WHERE id=1
#删除表中数据(delete from 表名 where 条件)
DELETE FROM students WHERE id=0
#查看表中数据(select 查询的东西 from 表名 where 条件)
SELECT * FROM students WHERE id=1
SELECT * FROM students ORDER BY age DESC(order by升序,order by 列名 desc降序)
列
#添加列(alter table 表名 add 列名 字段类型)
ALTER TABLE students ADD tel CHAR(20)
ALTER TABLE students ADD address CHAR(50) AFTER sex
#删除列(alter table 表名 drop 列名)
ALTER TABLE students DROP address
#修改列属性(alter table 表名 change 需要修改的列名 修改后的列名 新列名字段类型)
ALTER TABLE stu CHANGE telphone tel CHAR(20) DEFAULT "-"
ALTER TABLE students CHANGE tel
ALTER TABLE students RENAME stu
简单函数
SELECT SUM(age) AS "总年龄" FROM students
SELECT AVG(age) AS "平均年龄" FROM students
SELECT MAX(age) AS "最大年龄" FROM students
SELECT COUNT(id) AS "人数" FROM students(统计人数选择主键不然可为空的列会影响结果)
分组
表内容:
2005-05-09 胜
2005-05-09 胜
2005-05-09 负
2005-05-09 负
2005-05-10 胜
2005-05-10 负
2005-05-10 负        如果要生成下列结果, 该如何写sql语句?
      胜 负
2005-05-09 2 2
2005-05-10 1 2
SELECT DATA AS " ",SUM(result='胜') AS "胜" ,SUM(result='负') AS "负" FROM test1 GROUP BY DATA Case when(case 属性=“” then “” end)
      写出由table1.table2得到table3的sql语句 
SELECT t1.部门dep,SUM(CASE WHEN 月份mon='一月份' THEN 业绩yj ELSE NULL END) AS '一月份',
SUM(CASE WHEN 月份mon='二月份' THEN 业绩yj ELSE NULL END) AS '二月份',
SUM(CASE WHEN 月份mon='三月份' THEN 业绩yj ELSE NULL END) AS '三月份' FROM table1 t1 LEFT JOIN table2 t2 ON t1.部门dep=t2.部门dep GROUP BY 部门dep
左连接与右连接(left join 表名 on 连接语句)
Left join与right join区别就是:左连接是以主表为主,显示所有内容,若连接的表没有与它对应的值则不显示或显示为null,右连接同理。
内连接
用一条SQL语句查询出每门课都大于80分的学生姓名(表名为score)
  Select distinct(去重) name from score where name not in(
    Select name from score where fenshu<=80;
  );

Union all、union(下分别为t1.t1)
SELECT * FROM t1 UNION ALL SELECT * FROM t2 (不去除重复)===》t3
SELECT * FROM t1 UNION SELECT * FROM t2  (去除重复)=====>t4
(上分别为t3.t4)

以上所述是小编给大家介绍的Mysql表,列,库增删改查问题小结,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

更多精彩内容其他人还在看

MySQL优化之表结构优化的5大建议(数据类型选择讲的很好)

很多人都将 数据库设计范式 作为数据库表结构设计“圣经”,认为只要按照这个范式需求设计,就能让设计出来的表结构足够优化,既能保证性能优异同时还能满足扩展性要求
收藏 0 赞 0 分享

MySQL的表分区详解

这篇文章主要介绍了MySQL的表分区,例如什么是表分区、为什么要对表进行分区、表分区的4种类型详解等,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL基本命令、常用命令总结

这篇文章主要介绍了MySQL基本命令、常用命令总结,需要的朋友可以参考下
收藏 0 赞 0 分享

mysql 强大的trim() 函数

这篇文章主要介绍了mysql 强大的trim() 函数使用方法,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL函数大全及用法示例分享

这篇文章主要介绍了MySQL的一些函数及用法示例,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL不支持INTERSECT和MINUS及其替代方法

这篇文章主要介绍了MySQL不支持INTERSECT和MINUS情况下的替代方法,需要的朋友可以参考下
收藏 0 赞 0 分享

mysql修改数据库编码(数据库字符集)和表的字符编码的方法

Mysql数据库是一个开源的数据库,应用非常广泛。以下是修改mysql数据库的字符编码的操作过程和将表的字符编码转换成utf-8的方法,需要的朋友可以参考下
收藏 0 赞 0 分享

mysql远程登录出错的解决方法

mysql远程登录出错的情况,先比很多朋友都有遇到过吧,下面有个不错的解决方法,大家可以参考下
收藏 0 赞 0 分享

mysql通过查看跟踪日志跟踪执行的sql语句

在SQL SERVER下跟踪sql采用事件探查器,而在mysql下如何跟踪sql呢,下面有个不错的方法,大家可以参考下
收藏 0 赞 0 分享

MySQL错误代码大全

本章列出了当你用任何主机语言调用MySQL时可能出现的错误。首先列出了服务器错误消息。其次列出了客户端程序消息
收藏 0 赞 0 分享
查看更多