iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Mysql 数据库表如何增删改查
  • 629
分享到

Mysql 数据库表如何增删改查

2024-04-02 19:04:59 629人浏览 八月长安
摘要

这篇文章将为大家详细讲解有关Mysql 数据库表如何增删改查,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、表操作1、【增加】 create table

这篇文章将为大家详细讲解有关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(),<meta>)

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 -h227.0.0.1  -P3306  -uroot -p  > d:/data_back.sql;//备份库

Mysqldump -h227.0.0.1  -P3306 -uroot -p data_name  tb_studnet >d:/tb_back.sql;//备份表

3、还原数据库

Mysql -h227.0.0.1  -P3306  -uroot -p  data_name <d:/data_back.sql;

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 数据库表如何增删改查就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: Mysql 数据库表如何增删改查

本文链接: https://www.lsjlt.com/news/61355.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Mysql 数据库表如何增删改查
    这篇文章将为大家详细讲解有关Mysql 数据库表如何增删改查,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、表操作1、【增加】 create table ...
    99+
    2024-04-02
  • Mysql 数据库增删改查
    MySQL是目前最流行的关系型数据库。以下是MySQL数据库的增删改查操作。 1.数据库连接 在进行增删改查操作之前,需要先连接MySQL数据库。使用以下命令进行连接: import mysql.connectormydb = mysql....
    99+
    2023-08-31
    数据库 mysql oracle
  • mysql如何进行表数据的增删改查
    这篇文章主要介绍mysql如何进行表数据的增删改查,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在mysql中,可以使用SELECT语句进行表数据的查询,使用INSERT语句...
    99+
    2024-04-02
  • MySQL增删查改数据表详解
    目录前言一、新增数据二、查询数据全列查询指定列查询表达式查询指定别名查询去重查询排序查询条件查询分页查询三、修改数据四、删除数据前言 CRUD代表: 增加(create) ,查询(retrieve) ,更新(updat&...
    99+
    2022-11-19
    MySQL增删查改 MySQL数据库操作
  • 【MySql】数据库的CRUD(增删查改)
    写在最前面的话         哈喽,宝子们,今天给大家带来的是MySql数据库的CRUD(增删改查),CRUD是数据库非常基础的部分,也是后端开发日常工作中最主要的一项工作,接下来让我们一起进入学习吧,感谢大家的支持!喜欢的话可以三连...
    99+
    2023-09-08
    数据库 mysql sql
  • MySQL:数据的增删改查
    数据的增删改查 前言一、插入数据1、实际问题2、方式1:VALUES的方式添加3、方式2:将查询结果插入到表中 二、删除数据三、更新数据四、查询数据五、MySQL8新特性:计算列 前言 本博主将用CSDN记录软件开发求学...
    99+
    2023-08-17
    mysql android adb
  • 如何使用Jorm增删查改数据库
    这篇文章主要介绍“如何使用Jorm增删查改数据库”,在日常操作中,相信很多人在如何使用Jorm增删查改数据库问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用Jorm增删...
    99+
    2024-04-02
  • 数据库的增删改查如何实现
    数据库的增删改查操作可以通过SQL语句来实现。下面以MySQL数据库为例,介绍增删改查的常见操作:1. 增加(Insert):使用I...
    99+
    2023-08-31
    数据库
  • MySQL 表的增删改查
    MySQL 表的 CURD 什么是 CURD一、增加数据1. insert into 语句2. insert 语句注意事项 二、查询数据1. 全列查找2. 指定列查找3. 指定列查询为表达...
    99+
    2023-10-18
    数据库 mysql
  • MySQL | 数据库的管理和操作【表的增删改查】
    MySQL | 数据库的管理和操作【表的增删改查】 系列文章目录 第一章:MySQL | 数据库的管理和操作(基本介绍) 第二章:MySQL | 数据库的基本操作和表的基本操作 第三章:MySQL |...
    99+
    2023-10-27
    1024程序员节 mysql 数据库
  • 【数据库】MySQL表的增删改查(基础命令详解)
    目录 1.CRUD 2.新增(CREATE)  2.1 单行数据 + 全列插入 2.2 多行数据 + 指定列插入  3.查询(SELECT) 3.1全列查询 3.2指定列查询 3.3 查询字段为表达式 3.4别名 3.5去重 3.6 排序:...
    99+
    2023-09-29
    mysql 数据库 java
  • PHP+MySQL如何实现数据库的增删改查操作
    今天小编给大家分享一下PHP+MySQL如何实现数据库的增删改查操作的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、环境配...
    99+
    2023-07-05
  • MySQL表的CURD操作(数据的增删改查)
    目录一、SQL语句二、 基础表操作- 创建表- 查看库中的表- 查看表结构- 删除表- 重命名表三、mysql 中的增删查改操作- 增加(insert语句)- 查询(select语句)- 修改(update)-...
    99+
    2023-02-14
    mysql curd mysql表curd mysql表增删改查语句
  • 【MySQL】MySQL表的增删改查(CRUD)
    ✨个人主页:bit me👇 ✨当前专栏:MySQL数据库👇 ✨算法专栏:算法基础👇 ✨每日一语:生命久如暗室,不碍朝歌暮诗 目 录 🔓一. ...
    99+
    2023-08-19
    mysql 数据库 java
  • MySQL表的增删查改(CRUD)
    文章目录 前言一、新增数据二、查询数据全列查询指定列查询表达式查询指定别名查询去重查询排序查询条件查询分页查询 三、修改数据四、删除数据 前言 CRUD代表: 增加(create) ,查询(retrieve) ,更新(up...
    99+
    2023-08-22
    mysql 数据库 sql
  • MySQL表的增删改查(CRUD)
    目录一. CRUD二. 新增(Create)如何修改mysql配置:三. 查询(Retrieve)1. 全列查询2. 指定列查询3. 查询带有表达式 4. 起别名查询5. 去重查询6. 排序查询 7....
    99+
    2023-03-22
    数据库对表的增删改查语句 sql语句的增删改查
  • [MySQL] 表的增删查改(CURD)
      专栏简介 :MySql数据库从入门到进阶. 题目来源:leetcode,牛客,剑指offer. 创作目标:记录学习MySql学习历程 希望在提升自己的同时,帮助他人,,与大家一起共同进步,互相成长. 学历代表过去,能力代表...
    99+
    2023-09-20
    mysql 数据库
  • MySQl表的增删查改(CRUD)
    新增 1.单行插入        insert into 表名 values (值,值...);                            指定列插入    insert into 表名 (列名,列名...) value...
    99+
    2023-09-04
    mysql 数据库
  • 数据库的增删改查命令
    本篇内容介绍了“数据库的增删改查命令”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!表中数据简单管理(增 删...
    99+
    2024-04-02
  • django_数据库操作—增、删、改、查
    增加 增加数据有两种方法 1> sava >>> from datetime import date >>> book = BookInfo( btitle='西游记', bpub...
    99+
    2023-01-31
    操作 数据库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作