mysql 两表连接删除数据库_Mysql (二)Mysql 数据库表增删改查
一、表操作
1、【增加】
create table DBname.table_name(id int, namevarchar(255))engine=MyISAM charset=gbk;
2、【删除】
删除表
drop table table_name;
3、【修改】
修改表选项
alter table table_name engine=myisamcharset=utf8;//修改字符集
rename table Old_tablename to new_tablename;//修改表名
4、【查询】
show tables like '%_name'; //查看表
show create table table_name //查看建表语句
desc table_name //查看表结构 (describe)
show variables like 'character_set%';//展示以character_set开头变量
二、表字段操作
1、【增加】
增加表字段
alter table table_name add column 字段定义 //增加字段
alter table table_name add column heightint after name;//增加一个字height字段在name之后
alter table table_name add column snvarchar(10) first;//在最形始增加sn字段、使用关键字first
2、【删除】
删除字段
alter table table_name drop columncolumn_name;
alter table table_name drop columnheight;//删除表table_name中height字段
3、【修改】
修改已有字段(修改字段定义)
alter table table_name modify columncolumn_name 新的定义;
alter table table_name modify column sn intafter name; //修改sn字段
修改字段
alter table table_name change column 原字段名 新字段名 新字段定义;
alter table table_name change column snnew_sn varchar(30) after age;//修改字段
4、【查询】
查看表和表结构
show tables like '%_name'; //查看表
show create table table_name //查看建表语句
desc table_name //查看表结构 (describe)
三、表数据操作
1、【增加】
insert into 表名(字段列表) values(与字段相对的值列表);
insert into table_name('name','age','height')values(ssw,22,180);
2、【删除】
delete from 表名 where 条件;(删除是不可逆的)
delete 时、支持order by 和limit来限制删除数据记录
delete from table_name where id>2;
delete from tb_student order by height desc limit 3;
truncate tb_student;//清空表
3、【修改】
update 表名 set 字段=新值,字段n=新值n where 条件;(也可用order by 和limit限制)
update table_name set name='php' where id=3;
4、【查询】
select [字段表达式列表] from 表名 [where 子句] [group by子句] [having 子句] [order by子句] [limit 子句]
select字段列表from表名[where条件表达式] (*表示所有字段)
select * from table_name where id>6;
select name from table_name where id>2;
select加法逻辑关系别名(as)//select运算
select 1+1; select 10>20; select 1 or 0;select 1+1 as a;
select * from tb1,tb2;//多表查询
select tb1.id as s_id, tb2.* from tb1,tb2;//字段别名多表查询
select tb1.id as s_ id, s.class_name, c.* from tb1 as s, tb2 as c;//表别名
where子句、查询条件子句:
关系:> >= < <= != =
Like:模糊查询、like ‘模式匹配符%和_’;(%任意字符,_表示一个字符)
Notlike: 是like取反
Betweennum1 and num2: 在某个区间、闭区间。
In(元素列表): 在某个集合之内
Notin(元素列表): 不在某个集合之内
Null判断、is null 或者is not null
事例:selsect * from tb1where class_name like ‘%22’;
selsect * from tb1 where class_name like ‘_22’;
select * from tb1 where id between 11 and 40;
select * from tb1 where id >=11 and id<=40;
select * from tb1 where id not in(11,30);
select * from tb1 where id in (11,20);
group by字段:分组查询
对查询结果(已经通过where子句过滤之后的数据),按照某个字段,进行分组!
合计函数:
count(): 统计记录数、可以是*和字段名
sum(字段表达式): 统让和、对某个字段求和、
avg(): 平均值
max(字段表达式):最大值
min(字段表达式):最小值
group_concat(字段表达式):组内连接字符串
select count(*),id from tb1 where 1 groub by id;
select sum(money),class_id from tb1 groub by class_id;
select avg(money),class_id from tb1 groub by class_id;
select concat(‘It’ ,’is’,’test’);
分组排序:
ASC: 升序
DESC:降序
Select count(*),class_id from tb1 group by class_id;
多字段分组:
Select count(*),class_id,class_name from tb1 groub by class_id,class_name;
Having子句:条件子句、功能和where类似
Select * from tb1 where money>300;
Select * from tb1 having money>300;
Having和where区别:having的结果一定是 where 已经过滤之后的结果!having对结果进行二次处理
Select avg(age),class_id from tb1 where 1 group by class_id having avg(age)>16;
Order by排序子句
Order by 字段名 [asc|desc],[字段名[asc|desc],]//对结果进行排序的语句!可对多个字段排序
Select * from tb1 order by class_id desc, age asc;
原则是,先按照第一个字段进行排序,如果字段值相同,则采用第二个,以此类推
Select class_id from tb1 group by class_id asc order by class_id desc;
Limit子句:限制结果记录的子句、limit start (起始位置), size(记录数);
Select * from tb1 limit 1,3;
执行顺序:字段表达式,from子句,where子句,group by子句,having子句,order by子句,limit子句
子查询语句:
select max(height) from tb1;
select * from tb1 where height=170;
select * from tb1 where height=(select max(height) from tb1);
子查询的两种分类依据:
依据子查询出现的位置!
where型子查询, 出现在where子句内!
from 型子查询, 出现在from子句内!
依据子查询的返回数据的格式!
标量子查询,返回值是一个数据,称之为标量子查询!
列子查询,返回一个列,
行子查询,返回一个行,
表子查询,返回的是一个二维表
Select * from tb1 where height=(selectmax(height) from tb1); //where型
需要,先用一个查询,得到身高排序结果,再将该结果分组
Select* from (select * from tb1 order byheight desc) group by class_id;//from型
Select* from (select * from tb1 order byheight desc) as tmp group by class_id;
列子查询:
Select * from tb1 where sex=’girl’ and class_id in(select class_id from tb1 where sex=’body’ group byclass_id); //找到班级内有女同学的男学生信息
Select * from tb1 where (height,money)=(selectmax(height),max(money) from tb1);
//找到,高富,最高并且最有钱!
exists型子查询:
select * from tb1 where exists(select * from tb2 where tb1.class_id = tb2.id);
连接查询,join:
连接多个表记录之间的连接!from 表名1 join 表名2 on 连接条件
Select name,class_id,age from tb_xue join tb_ban on tb_xue.class_id=tb_ban.id;
需要不单从 学生表获取数据,还需要从 班级表获得数据
内连接,inner join
mysql默认的连接就是 inner join
select stu_name,class_id,class_name fromselect_student inner join select_class onselect_student.class_id=select_class.id;(可省略inner)
外连接,left join,right join
Select stu_name,class_id,class_name from select_student left join select_classon select_student.class_id = select_class.id;
join关键字前面的(左边的)左表,join关键字后边的(右边的)右表!
左外:如果出现左表记录连接不上右表记录的,左表记录会出现正在最终的连接结果内!而右表记录相应设置成NULL。
右外:如果出现右表记录连接不上左表记录的,右表记录会出现正在最终的连接结果内!而左表记录相应设置成NULL。
交叉连接,cross join: 相当于是 没有条件的内连接
自然连接,natural join: mysql,自动判断连接条件,帮助我们完成连接!
Select stu_name,class_name from select_class natural join select_student;
而自然连接也分内连接与外连接!
自然内连接:natural join
自然左外:natural left join
自然右外:natual right join
总结:
最终的效果只有:内,左外,右外!
交叉,特殊的内!
自然,相当于自动判断连接条件,完成内,左外,右外!
连接条件,on,using:
on,后面使用一个连接条件表达式!
using(连接字段),要求使用同名字段进行连接!
Select class_name,stu_name from tb_class inner join tb_student on tb_class.class_id=tb_student.class_id;
Select class_name,stu_name from tb_class inner join tb_student using(class_id);
union查询,联合查询:
将多个查询的结果,并列到一个结果集合内!
(select stu_name,height from tb_student where sex=’girl’ order by height asc limit 1000) union(select stu_name ,height from tb_student where sex=’box’ order by height desc limit 1000 );
union 的连接的两个子句,不要求实同表,只要求,列的数量相同!
union会在联合时:主动去掉相同的记录:此时,可以使用 all关键字加以修正:
select 1=1 union all select 2;
select语句的选项:
distinct,取消相同的记录
select class_id from tb_student;
select all class_id from tb_student;
select distinct class_id from tb_student;
四、编码
1、建库,建表,建字段 设置(数据库中的数据的编码)
2、PHP作为mysql服务器的客户端,设置的客户端编码和连接编码(set names gbk/utf8)
3、设置php返回给浏览器数据的编码,(Content-Type,header(),)
4、PHP文件本身保存的编码(文件编码,通过文本编辑器设置)
五、视图
视图:就是通过一条查询语句得到一个张虚拟表!因此,视图就是 select语句的结果
作用:简化查询的业务逻辑,隐藏真实的表结构。
语法:create view 视图名字 as 查询语句
Create view view_name as select * from tb_student as s left join tb_class using(class_id);
Select * from view_name where id=22;
//取得每个班级最高的学生信息
Create view view_student as select * from view_student order by height desc;
Select * from view_student group by class_id;
六、事务
事务:一组 SQL 的集合,要不集体都执行成功,要不集体都失败,
语法:
开启事务:start transaction (可简写begin)
提交:commit (如果sql成功、则提交、将sql的执行结果保存到数据库里)
回滚:rollback (如果sql失败、则回滚、将sql的执行结果退到事务开始之前)
注:无论回滚还是提交,都会关闭该事务!(需要再次开启,才能使用)事务,只针对当前的连接生效!
事例:
Start transaction;
Update tb_student set money=money+1000 where id=10;
Commit;
七、数据库备份
1、备份单个表
select 字段列表into outfile文件地址 from 表名 where 其他的select子句
select * into outfile ‘d:/b.txt’
fields terminated by ‘,’
lines terminated by ‘\r\n’
from tb_student;
还原:load data infile filename into tb_name;
2、备份一个库
Mysqldump -h127.0.0.1 -P3306 -uroot -p > d:/data_back.sql;//备份库
Mysqldump -h127.0.0.1 -P3306 -uroot -p data_name tb_studnet >d:/tb_back.sql;//备份表
3、还原数据库
Mysql -h127.0.0.1 -P3306 -uroot -p data_name
Mysql>source d:/data_back.sql;(登录后还原)
3、忘记root密码
mysqld服务器程序,有一个选项,跳过权限认证选项!客户端登陆不用密码
my.ini里面要有这个选项、没有就手动填加添加skip-grant-tables(改好密码就删除这段)
第一步:
重新开启mysqld服务、直接mysql就能进去了。
cmd>mysql
第二步:
更新mysql.user表root用户的password字段
Update mysql.user set password=password(‘123456’) where user=’root’; 这个不行就用下面这个update mysql.user set authentication_string=password('**') where user='**';
第三步:
重启mysqld
八、PHP操作mysql服务器
php作为mysql服务器的客服端
php--链接认认证--发送sql--执行sql、生成结果--处理结果--关闭连接
1、【连接认证】
$_host = 'localhost';
$_port = '3306';
$_user = 'root';
$_pass = 'rootpass';
if(!$_link = mysql_connect("$_host:$_port",$_user, $_pass)){
die('连接失败!');
}
2、【向mysql服务器发送sql】
$_sql = 'show databases';
if(!$_result = mysql_query($_sql, $_link)){
echo'sql执行失败';
}
3、【处理返回的数据】
$_row = mysql_fetch_assoc($_result);
var_dump($_row);
结果集取出来的函数:
mysql_fetch_assoc() 函数从结果集中取得一行作为关联数组。
mysql_fetch_row() 函数从结果集中取得一行作为索引数组。
mysql_fetch_array() 函数从结果集中取得一行作为关联数组,或数字数组,或二者兼有
mysql_num_rows()函数返回结果集中行的数目。
注:任何有结果的sql操作,返回的都是结果集!结果集,就是一个二维表的结构!是一行行的记录组成!
4、【释放释源】
mysql_free_result($_result);结果集
mysql_close($_link);连接资源
微信扫一扫 、关注公众号
不定时分享资料视频
mysql 两表连接删除数据库_Mysql (二)Mysql 数据库表增删改查相关推荐
- mysql查询和修改一个命令_MYSQL的常用命令和增删改查语句
连接命令:mysql -h[主机地址] -u[用户名] -p[用户密码] 创建数据库:create database [库名] 显示所有数据库: show databases; 打开数据库:use [ ...
- Python语言学习之pandas:DataFrame二维表的简介、常用函数、常用案例(增删改查排序之选择指定列、根据条件选择特定数据、赋值、列名重命名、修改列数据、处理缺失值、列合并、分组之详细攻略
Python语言学习之pandas:DataFrame二维表的简介.常用函数.常用案例(增删改查排序之选择指定列.根据条件选择特定数据.赋值.列名重命名.修改列数据.处理缺失值.列合并.分组之详细攻略 ...
- Python进阶----表与表之间的关系(一对一,一对多,多对多),增删改查操作
Python进阶----表与表之间的关系(一对一,一对多,多对多),增删改查操作,单表查询,多表查询 一丶表与表之间的关系 背景: 由于如果只使用一张表存储所有的数据,就会操作数 ...
- 详解二叉搜索树的增删改查
文章目录 二叉搜索树 1.1 定义 二.二叉搜索树基本结构 三.二叉搜索树的具体实现 3.1 插入节点 3.2 查询节点 3.3 删除节点(⭐️) 3.4 二叉搜索树的遍历 四.二叉搜索树的性能分析和 ...
- c mysql 添加数据类型_MYSQL的常用命令和增删改查语句和数据类型
连接命令:mysql -h[主机地址] -u[用户名] -p[用户密码] 创建数据库:create database [库名] 显示所有数据库: show databases; 打开数据库:use [ ...
- Mendix一练一动: Mendix Studio Pro连接外围数据库(SQL Server)实现增删改查
一. 环境准备 1: 连接外围数据库是Mendix的内置功能,不同数据库的连接方式都大同小异,本文以SQL Server为例讲解: 2:本文假设读者是Mendix初级学者,因此对每一步骤作者都尽量表述 ...
- SpringBoot+MySql实现一对多再多对多的数据库的设计以及业务层增删改查的实现
场景 SpringBoot+MySql+ElementUI实现一对多的数据库的设计以及增删改查的实现 https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article ...
- C/C++编程操作Redis数据库,hiredis包装redis数据库操作接口及测试(增删改查与连接)
介绍一个实际应用场景,对于客户频繁需要查询的信息,可以将其放在redis内存数据库中,相当于一个缓存,每次查的时候先去redis内存数据库中去查询,如果查询不到再去oracle数据库中查询,这样提高了 ...
- springboot集合MySQL删除_SpringBoot集成Spring JdbcTemplate并完成增删改查操作
JdbcTemplate是Spring用来简化JDBC操作的核心类,有助于与Spring集成,并且避免了过多冗长的JDBC代码.不过在实际使用中,我们通常使用NamedParameterJdbcTem ...
- MySQL笔记(二)基础的增删改查
这是我在学习Mysql之路上做的笔记,今天将它粘出来.这一篇主要是简单增删改查.有错误的欢迎大家指出... #增删改查 #创建部门表 CREATE TABLE IF NOT EXISTS tb_dep ...
最新文章
- springboot 启动时could not exec java_面试被问为什么使用Spring Boot?答案好像没那么简单...
- pb graph鼠标移上显示数据_Plotly数据可视化:离线版、微软vscode版的Python的基本作图...
- python相关知识介绍一种理财方法_我是如何使用python来确定理财策略的
- matlab打开笔记本摄像头_基于MATLAB调用电脑摄像头获取视频和图像
- 【程序员薪资】2021年04月新鲜出炉,看看你拖后腿了吗?
- 使用XStream进行对象和xml的转换,极度舒适
- mysql两条完全相同的数据_两条完全相同的数据怎么用sql语句删除一条
- uml类图用什么软件画_为什么需要UML类图建模?
- 共享文件服务器密码更换,服务器共享文件密码
- STM32程序中使用printf打印中文字符乱码
- linux 内存对齐,Windows和Linux下的字节对齐(转载)
- 使用wordpress的心得
- 使用Statistic统计代码行数
- 惠普HP LaserJet Pro M405d 打印机驱动
- Combined Cycle Power Plant Data Set(初学练手:详解)
- 自然语言处理和编译器的对比
- PyGame|给程序插入背景音乐
- IOT语义互操作性之标准与开源
- FL Studio 教程之扫弦简介
- uci数据集中的缺失数据_从uci早期糖尿病风险预测数据集中创建分类器