mysql基础操作

  id INT PRIMARY KEY AUTO_INCREMENT, -- 账务ID
  Name1 VARCHAR(200), -- 账务名称
  money DOUBLE -- 金额
);
INSERT  INTO zhangwu(id,name1,money) VALUES (1,'吃饭支出',247);
INSERT  INTO zhangwu(id,name1,money) VALUES (2,'工资收入',12345);
INSERT  INTO zhangwu(id,name1,money) VALUES (3,'服装支出',1000);
INSERT  INTO zhangwu(id,name1,money) VALUES (4,'吃饭支出',325);
INSERT  INTO zhangwu(id,name1,money) VALUES (5,'股票收入',8000);
INSERT  INTO zhangwu(id,name1,money) VALUES (6,'打麻将支出',8000);
INSERT  INTO zhangwu(id,name1,money) VALUES (7,null,5000);
-- 1.将表明修改为order
RENAME TABLE zhangwu to order1;
-- 2.将字段money 更名为money1,设置为非空
ALTER TABLE order1 CHANGE money money1 INT NOT NULL;
-- 3.将id为5的账务名称改为游戏支出
UPDATE order1 SET name1='游戏支出'  WHERE id=5;
-- 4.删除账务名称为空的数据
DELETE FROM order1 WHERE name1 is null; -- !
-- 5.查询id,name1字段信息
SELECT id,name1 FROM order1;
-- 6.查询表中所有字段
SELECT * FROM order1;
-- 7.将所有账务的金额+10000元进行显示
SELECT name1,money1+10000 FROM order1;
-- .查询所有吃饭支出记录
SELECT  * FROM order1 WHERE name1='吃饭支出';
-- 查询出金额大于1000的信息
SELECT * FROM order1 WHERE money1>1000 ;
-- .查询出金额在2000-9000之间的账务信息
SELECT * FROM order1 WHERE money1 <=9000 AND money1 >=2000 ;
SELECT * FROM order1 WHERE money1 BETWEEN 2000 AND 9000;
-- 查询出金额是1000或5000或3500的商品信息
SELECT * FROM order1 WHERE money1=1000 OR money1=5000 OR money1=3500;
-- 12.查询出账务名称包含”支出”的账务信息。
SELECT * FROM order1 WHERE name1 LIKE '%支出%';
-- 查询出账务名称中是五个字的账务信息
SELECT * FROM order1 WHERE name1 LIKE '_____';
-- 查询收入平均值
SELECT AVG(money1) FROM order1 ;
-- .查询支出最大值取别名“最大支出”
SELECT MAX(money1) FROM order1;
-- 分页查询全部信息,每页4条数据,查看第2页
SELECT * FROM order1 LIMIT 2,4;
-- .根据账务名称进行分组,对钱进行降序排列
SELECT * FROM order1 where GROUP BY name1 ORDER BY money1 DESC;

-- 内连接查询
-- 注:当出现未匹配的信息,不会被省略
/*Select 表1.*,表2.* 。。。
   From 表1
   [Inner] Join 表2 on 表与表之间的关联*/
-- 1
SELECT s.stuid,s.stuname,s.gradeid,g.gradeid,g.gradename 
FROM student AS s
INNER JOIN grade AS g
on s.gradeid=g.gradeid AND s.gradeid='g001';
DESC user2;

/*
添加外键约束
alter table 从表表名 add constraint 约束名(形如:FK_XX) foreign key 从表(外键字段)  references 主表(主键字段);
     注意:建立外键约束时主表所关联的列必须是主键,从表和主表关联对应的列的数据类型相符
alter table   result
add CONSTRAINT fk_stuno FOREIGN key result(stuno) references student(stuno)
*/
-- 结婚
ALTER TABLE student ADD CONSTRAINT FOREIGN KEY student(gradeid) REFERENCES grade(gradeid);
-- 当课程班级中有学生的情况下,班级可以删除
DELETE FROM grade WHERE gradeid='g001';
DELETE FROM student WHERE gradeid='g002';
-- 主表中不能删除从表有引用的信息,从表中不能添加主表中没有的信息
INSERT INTO student (stuid,stuname,gradeid)values ('6','钟凡','g004');
-- 离婚 解除外键约束:alter table 从表  drop foreign key 外键字段名
ALTER TABLE student drop FOREIGN KEY student_ibfk_1;

-- 1.左外连接查询:
-- SELECT 字段…… FROM 表一 left [outer] JOIN 表2 ON 连接条件;
-- 注:当出现两个表中未匹配的信息,以左表为主(保证左表信息全部能够展示),右表中未匹配信息被省略
SELECT s.stuid,s.stuname,s.gradeid,g.gradeid,g.gradename 
FROM student s
LEFT OUTER JOIN grade g
ON s.gradeid=g.gradeid;
-- 2.右外连接查询:
-- SELECT 字段…… FROM 表一 RIGHT [outer] JOIN 表2 ON 连接条件;
-- 注:当出现两个表中未匹配的信息,以右表为主(保证右表信息全部能够展示),左表中未匹配信息被省略
SELECT s.stuid,s.stuname,s.gradeid,g.gradeid,g.gradename 
FROM student s
RIGHT OUTER JOIN grade g
ON s.gradeid=g.gradeid;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值