您的当前位置:首页mysql 简单的增删改查语句

mysql 简单的增删改查语句

2023-11-09 来源:哗拓教育

mysql> insert into test values(‘sunshine_habit‘,‘hello_world_lyq@163.com‘2 -> ,1558888888,null);输出:3 Query OK, 1 row affected (0.10 sec)

查询记录:

1 mysql> select * from test where name=‘sunshine_habit‘;2 输出:3 +----------------+-------------------------+--------------+----+4 | name | email | phone_number | id |5 +----------------+-------------------------+--------------+----+6 | sunshine_habit | hello_world_lyq@163.com | 1558888888 | 1 |7 +----------------+-------------------------+--------------+----+8 1 row in set (0.00 sec)

 

mysql 简单的增删改查语句

标签:

小编还为您整理了以下内容,可能对您也有帮助:

数据库中增删改查的基本语句是什么

常见如下:

进入mysql命令行: mysql -uroot -p;查看所有数据库: show databases;增加创建数据库: create database niu charset utf8;删除数据库: drop database niu;选择数据库: use databases。

查看所有表: show tables;查看创建数据库的语句:show create database databasename;查看创建表的语句:show create table tablename;查看表结构:desc tablenmae。

相关简介

mysql_stmt_fetch是函数名,mysql_stmt_fetch()返回结果集中的下一行。

仅能当结果集存在时调用它,也就是说,调用了能创建结果集的mysql_stmt_execute()之后,或当mysql_stmt_execute()对整个结果集即行缓冲处理后调用了mysql_stmt_store_result()。

使用mysql_stmt_bind_result()绑定的缓冲,mysql_stmt_fetch()返回行数据。对于当前列集合中的所有列,它将返回缓冲内的数据,并将长度返回到长度指针。

数据库中增删改查的基本语句是什么

常见如下:

进入mysql命令行: mysql -uroot -p;查看所有数据库: show databases;增加创建数据库: create database niu charset utf8;删除数据库: drop database niu;选择数据库: use databases。

查看所有表: show tables;查看创建数据库的语句:show create database databasename;查看创建表的语句:show create table tablename;查看表结构:desc tablenmae。

相关简介

mysql_stmt_fetch是函数名,mysql_stmt_fetch()返回结果集中的下一行。

仅能当结果集存在时调用它,也就是说,调用了能创建结果集的mysql_stmt_execute()之后,或当mysql_stmt_execute()对整个结果集即行缓冲处理后调用了mysql_stmt_store_result()。

使用mysql_stmt_bind_result()绑定的缓冲,mysql_stmt_fetch()返回行数据。对于当前列集合中的所有列,它将返回缓冲内的数据,并将长度返回到长度指针。

mysql的增删改查语句

mysql的增删改查语句是怎么写的,跟sql有什么区别,基本没区别,都差不多,特殊的查询有区别。比如*结果就不是top了,而是limit 3,5。mysql数据库备份跟附加是不是必须要关闭tomcat,这个没必要,直接可以操作,不过如果程序做过映射,那要重新装载。

往数据中插入数据,在询问框中填写  INSERT INTO biao1(name1,age) VALUES('新增加1','1000')然后点击执行按钮 ,如果成功会显示执行一条语句,在运行查询所有语句会发现新插入的信息也能查询出来。

图书简介

MySQL数据库是以“客户端/服务器”模式实现的,是一个多用户、多线程的小型数据库。MySQL因其稳定、可靠、快速、管理方便以及支持众多系统平台的特点。

成为世界范围内最流行的开源数据库之一。《MySQL数据库入门》就是面向数据库初学者特地推出的一本进阶学习的入门教材,本教材站在初学者的角度,以形象的比喻、丰富的图解、实用的案例、通俗易懂的语言详细讲解了MySQL的开发和管理技术。

mysql的增删改查语句

mysql的增删改查语句是怎么写的,跟sql有什么区别,基本没区别,都差不多,特殊的查询有区别。比如*结果就不是top了,而是limit 3,5。mysql数据库备份跟附加是不是必须要关闭tomcat,这个没必要,直接可以操作,不过如果程序做过映射,那要重新装载。

往数据中插入数据,在询问框中填写  INSERT INTO biao1(name1,age) VALUES('新增加1','1000')然后点击执行按钮 ,如果成功会显示执行一条语句,在运行查询所有语句会发现新插入的信息也能查询出来。

图书简介

MySQL数据库是以“客户端/服务器”模式实现的,是一个多用户、多线程的小型数据库。MySQL因其稳定、可靠、快速、管理方便以及支持众多系统平台的特点。

成为世界范围内最流行的开源数据库之一。《MySQL数据库入门》就是面向数据库初学者特地推出的一本进阶学习的入门教材,本教材站在初学者的角度,以形象的比喻、丰富的图解、实用的案例、通俗易懂的语言详细讲解了MySQL的开发和管理技术。

MySQL操作基础之DML语句,数据操纵语言(增删改)

这里介绍DML语句(数据操纵语言),用于数据的 增加 、 删除 和 更改 ,也就是我们常说的 增删改 。

示例表:

示例数据库:testDatabase,示例表:myTable

格式:

示例:

1)只插入某一列的值

2)按规矩指定所有列名,并且每列都插入值

注意数据类型,如字符类型values值需要加 ` " " `

显示如下:

3)如果不知道列,就要按规矩为每列都插入恰当的值

示例:

注: 这种方式,需要注意自增项的列(id),也需要赋值,可以自定义id值,也可以null,让自增。

4)批量插入数据的方法,提升效率

Delete,意为删除,顾名思义就是删除表中已有的某些记录。

格式:

示例:

注: 以上会删除所有同名为“lisi”的列,所有实际中以唯一量的值删除,如id。

例:

删除id为9和12的列。

Update,意为更新,顾名思义,就是修改表中原有的数据。

格式:

示例:

或者改多项值:

以上是基本的DML(数据操纵语言)语句。

数据库中增删改查的基本语句是什么?

数据库中增删改查基本语句:INSERT INTO,表名字段列表。

数据库是存放数据的仓库。它的存储空间很大,可以存放百万条、千万条、上亿条数据。但是数据库并不是随意地将数据进行存放,是有一定的规则的,否则查询的效率会很低。

当今世界是一个充满着数据的互联网世界,充斥着大量的数据。即这个互联网世界就是数据世界。数据的来源有很多,比如出行记录、消费记录、浏览的网页、发送的消息等等。除了文本类型的数据,图像、音乐、声音都是数据。

在数据库的发展历史上,数据库先后经历了层次数据库、网状数据库和关系数据库等各个阶段的发展,数据库技术在各个方面的快速的发展。特别是关系型数据库已经成为目前数据库产品中最重要的一员。

80年代以来,几乎所有的数据库厂商新出的数据库产品都支持关系型数据库,即使一些非关系数据库产品也几乎都有支持关系数据库的接口。

这主要是传统的关系型数据库可以比较好的解决管理和存储关系型数据的问题。随着云计算的发展和大数据时代的到来,关系型数据库越来越无法满足需要,这主要是由于越来越多的半关系型和非关系型数据需要用数据库进行存储管理。

数据库中增删改查的基本语句是什么?

数据库中增删改查基本语句:INSERT INTO,表名字段列表。

数据库是存放数据的仓库。它的存储空间很大,可以存放百万条、千万条、上亿条数据。但是数据库并不是随意地将数据进行存放,是有一定的规则的,否则查询的效率会很低。

当今世界是一个充满着数据的互联网世界,充斥着大量的数据。即这个互联网世界就是数据世界。数据的来源有很多,比如出行记录、消费记录、浏览的网页、发送的消息等等。除了文本类型的数据,图像、音乐、声音都是数据。

在数据库的发展历史上,数据库先后经历了层次数据库、网状数据库和关系数据库等各个阶段的发展,数据库技术在各个方面的快速的发展。特别是关系型数据库已经成为目前数据库产品中最重要的一员。

80年代以来,几乎所有的数据库厂商新出的数据库产品都支持关系型数据库,即使一些非关系数据库产品也几乎都有支持关系数据库的接口。

这主要是传统的关系型数据库可以比较好的解决管理和存储关系型数据的问题。随着云计算的发展和大数据时代的到来,关系型数据库越来越无法满足需要,这主要是由于越来越多的半关系型和非关系型数据需要用数据库进行存储管理。

SQL常用增删改查语句

结构化查询语言(Structured Query Language)简称SQL,是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。今天就给大家介绍数据库的基本SQL操作增删改查!!!

材料/工具

电脑SQL Server

为表添加主键

alter table

主键添加前:

主键添加后:

插入数据

insert into

查询

查询全部记录:

select * from

条件查询(查询全部字段用*,查询指定字段也可以):

select

带有Sql函数的查询:

select count(*) from

模糊查询(like语法):

select

删除(Delete)

delete from

更新(update)

update

为表添加一列

注意:列增加后不可删除。DB2中的列加上后数据类型也不能改变,唯一能改变的是增加varchar 的长度。

alter table

SQL常用增删改查语句

结构化查询语言(Structured Query Language)简称SQL,是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。今天就给大家介绍数据库的基本SQL操作增删改查!!!

材料/工具

电脑SQL Server

为表添加主键

alter table

主键添加前:

主键添加后:

插入数据

insert into

查询

查询全部记录:

select * from

条件查询(查询全部字段用*,查询指定字段也可以):

select

带有Sql函数的查询:

select count(*) from

模糊查询(like语法):

select

删除(Delete)

delete from

更新(update)

update

为表添加一列

注意:列增加后不可删除。DB2中的列加上后数据类型也不能改变,唯一能改变的是增加varchar 的长度。

alter table

php封装一个类能实现mysql数据库的增删改查(php增删改查mysql实例)

class

sqlHelper{

public

$conn;

public

$dbname="数据库名称";

public

$username="数据库用户名";

public

$password="数据库密码";

public

$host="localhost";

//连接数据库

public

function

__construct(){

$this-

if(!$this-

die("连接失败".mysql_error());

}

mysql_select_db($this-

}

//执行查询语句

public

function

execute_dql($sql){

$res=mysql_query($sql,$this-

return

$res;

}

//执行增填改语句

public

function

execute_dml($sql){

$b=mysql_query($sql,$this-

if(!$b){

return

3;

}else{

if(mysql_affected_rows($this-

return

1;//表示OK

}else{

return

2;//表示没有行收到影响

}

}

}

}

php封装一个类能实现mysql数据库的增删改查(php增删改查mysql实例)

class

sqlHelper{

public

$conn;

public

$dbname="数据库名称";

public

$username="数据库用户名";

public

$password="数据库密码";

public

$host="localhost";

//连接数据库

public

function

__construct(){

$this-

if(!$this-

die("连接失败".mysql_error());

}

mysql_select_db($this-

}

//执行查询语句

public

function

execute_dql($sql){

$res=mysql_query($sql,$this-

return

$res;

}

//执行增填改语句

public

function

execute_dml($sql){

$b=mysql_query($sql,$this-

if(!$b){

return

3;

}else{

if(mysql_affected_rows($this-

return

1;//表示OK

}else{

return

2;//表示没有行收到影响

}

}

}

}

SQl常用增删改查

结构化查询语言(Structured Query Language)简称SQL,是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。今天就给大家介绍数据库的基本SQL操作增删改查!!!

材料/工具

电脑SQL Server

为表添加主键

alter table

主键添加前:

主键添加后:

插入数据

insert into

查询

查询全部记录:

select * from

条件查询(查询全部字段用*,查询指定字段也可以):

select

带有Sql函数的查询:

select count(*) from

模糊查询(like语法):

select

删除(Delete)

delete from

更新(update)

update

为表添加一列

注意:列增加后不可删除。DB2中的列加上后数据类型也不能改变,唯一能改变的是增加varchar 的长度。

alter table

SQl常用增删改查

结构化查询语言(Structured Query Language)简称SQL,是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。今天就给大家介绍数据库的基本SQL操作增删改查!!!

材料/工具

电脑SQL Server

为表添加主键

alter table

主键添加前:

主键添加后:

插入数据

insert into

查询

查询全部记录:

select * from

条件查询(查询全部字段用*,查询指定字段也可以):

select

带有Sql函数的查询:

select count(*) from

模糊查询(like语法):

select

删除(Delete)

delete from

更新(update)

update

为表添加一列

注意:列增加后不可删除。DB2中的列加上后数据类型也不能改变,唯一能改变的是增加varchar 的长度。

alter table

数据库增删改查的基本命令

(推荐教程:mysql视频教程)

数据库增删改查基本语句

数据库增加数据

在 MySQL 中可以使用 INSERT INTO 语句向数据库已有的表中插入一行或者多行元组数据。

语法格式:

INSERT INTO 表名 ( 列名1, 列名2,...列名N ) VALUES ( 值1, 值2,...值N );

如果数据是字符型,必须使用单引号或者双引号,如:"value"。

  • 表名:指定被操作的表名。

  • 列名:指定需要插入数据的列名。若向表中的所有列插入数据,则全部的列名均可以省略,直接采用 INSERT<表名>VALUES(…) 即可。

  • VALUE 子句:该子句包含要插入的数据清单。数据清单中数据的顺序要和列的顺序相对应。

  • 示例:在 tb_courses 表中插入一条新记录,course_id 值为 1,course_name 值为“Network”,course_grade 值为 3,info 值为“Computer Network”。

    在执行插入操作之前,查看 tb_courses 表

    mysql> SELECT * FROM tb_courses;Empty set (0.00 sec)

    查询结果显示当前表内容为空,没有数据,接下来执行插入数据的操作,输入的 SQL 语句和执行过程如下所示。

    mysql> INSERT INTO tb_courses -> (course_id,course_name,course_grade,course_info) -> VALUES(1,'Network',3,'Computer Network');Query OK, 1 rows affected (0.08 sec)mysql> SELECT * FROM tb_courses;+-----------+-------------+--------------+------------------+| course_id | course_name | course_grade | course_info |+-----------+-------------+--------------+------------------+| 1 | Network | 3 | Computer Network |+-----------+-------------+--------------+------------------+1 row in set (0.00 sec)

    可以看到插入记录成功。在插入数据时,指定了 tb_courses 表的所有字段,因此将为每一个字段插入新的值。

    说明:

  • INSERT 语句后面的列名称顺序可以不是 tb_courses 表定义时的顺序,即插入数据时,不需要按照表定义的顺序插入,只要保证值的顺序与列字段的顺序相同就可以。

  • 使用 INSERT 插入数据时,允许列名称列表 column_list 为空,此时值列表中需要为表的每一个字段指定值,并且值的顺序必须和数据表中字段定义时的顺序相同。

  • 注意:虽然使用 INSERT 插入数据时可以忽略插入数据的列名称,若值不包含列名称,则 VALUES 关键字后面的值不仅要求完整,而且顺序必须和表定义时列的顺序相同。如果表的结构被修改,对列进行增加、删除或者位置改变操作,这些操作将使得用这种方式插入数据时的顺序也同时改变。如果指定列名称,就不会受到表结构改变的影响。

    数据库删除数据

    在 MySQL 中,可以使用 DELETE 语句来删除表的一行或者多行数据。

    语法格式为:

    DELETE FROM 表名 [WHERE 子句] [ORDER BY 子句] [LIMIT 子句]

    删除指定数据:

    DELETE FROM 表名称 WHERE 列名称 = 值

    语法说明如下:

  • 表名:指定要删除数据的表名。

  • ORDER BY 子句:可选项。表示删除时,表中各行将按照子句中指定的顺序进行删除。

  • WHERE 子句:可选项。表示为删除操作限定删除条件,若省略该子句,则代表删除该表中的所有行。

  • LIMIT 子句:可选项。用于告知服务器在控制命令被返回到客户端前被删除行的最大值。

  • 注意:在不使用 WHERE 条件的时候,将删除所有数据。

    示例1:删除表中的全部数据

    删除 tb_courses_new 表中的全部数据,输入的 SQL 语句和执行结果如下所示。

    mysql> DELETE FROM tb_courses_new;Query OK, 3 rows affected (0.12 sec)mysql> SELECT * FROM tb_courses_new;Empty set (0.00 sec)

    示例2:根据条件删除表中的数据

    在 tb_courses_new 表中,删除 course_id 为 4 的记录,输入的 SQL 语句和执行结果如下所示。

    mysql> DELETE FROM tb_courses -> WHERE course_id=4;Query OK, 1 row affected (0.00 sec)mysql> SELECT * FROM tb_courses;+-----------+-------------+--------------+------------------+| course_id | course_name | course_grade | course_info |+-----------+-------------+--------------+------------------+| 1 | Network | 3 | Computer Network || 2 | Database | 3 | MySQL || 3 | Java | 4 | Java EE |+-----------+-------------+--------------+------------------+3 rows in set (0.00 sec)

    由运行结果可以看出,course_id 为 4 的记录已经被删除。

    数据库修改数据

    在 MySQL 中,可以使用 UPDATE 语句来修改、更新一个或多个表的数据。

    语法格式为:

    UPDATE 表名 SET 字段=值 [WHERE 子句 ][ORDER BY 子句] [LIMIT 子句]

    例:

    UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值

    语法说明如下:

  • 表名:用于指定要更新的表名称。

  • SET 子句:用于指定表中要修改的列名及其列值。其中,每个指定的列值可以是表达式,也可以是该列对应的默认值。如果指定的是默认值,可用关键字 DEFAULT 表示列值。

  • WHERE 子句:可选项。用于限定表中要修改的行。若不指定,则修改表中所有的行。

  • ORDER BY 子句:可选项。用于限定表中的行被修改的次序。

  • LIMIT 子句:可选项。用于限定被修改的行数。

  • 注意:修改一行数据的多个列值时,SET 子句的每个值用逗号分开即可。

    示例1:修改表中的数据

    在 tb_courses_new 表中,更新所有行的 course_grade 字段值为 4,输入的 SQL 语句和执行结果如下所示。

    mysql> UPDATE tb_courses_new -> SET course_grade=4;Query OK, 3 rows affected (0.11 sec)Rows matched: 4 Changed: 3 Warnings: 0mysql> SELECT * FROM tb_courses_new;+-----------+-------------+--------------+------------------+| course_id | course_name | course_grade | course_info |+-----------+-------------+--------------+------------------+| 1 | Network | 4 | Computer Network || 2 | Database | 4 | MySQL || 3 | Java | 4 | Java EE || 4 | System | 4 | Operating System |+-----------+-------------+--------------+------------------+4 rows in set (0.00 sec)

    示例1:根据条件修改表中的数据

    在 tb_courses 表中,更新 course_id 值为 2 的记录,将 course_grade 字段值改为 3.5,将 course_name 字段值改为“DB”,输入的 SQL 语句和执行结果如下所示。

    mysql> UPDATE tb_courses_new -> SET course_name='DB',course_grade=3.5 -> WHERE course_id=2;Query OK, 1 row affected (0.13 sec)Rows matched: 1 Changed: 1 Warnings: 0mysql> SELECT * FROM tb_courses_new;+-----------+-------------+--------------+------------------+| course_id | course_name | course_grade | course_info |+-----------+-------------+--------------+------------------+| 1 | Network | 4 | Computer Network || 2 | DB | 3.5 | MySQL || 3 | Java | 4 | Java EE || 4 | System | 4 | Operating System |+-----------+-------------+--------------+------------------+4 rows in set (0.00 sec)

    注意:保证 UPDATE 以 WHERE 子句结束,通过 WHERE 子句指定被更新的记录所需要满足的条件,如果忽略 WHERE 子句,MySQL 将更新表中所有的行。

    数据库查询数据

    在 MySQL 中,可以使用 SELECT 语句来查询数据。查询数据是指从数据库中根据需求,使用不同的查询方式来获取不同的数据,是使用频率最高、最重要的操作。

    SELECT 的语法格式如下:

    SELECT{* | <字段列名>}[FROM <表 1>, <表 2>…[WHERE <表达式>[GROUP BY <group by definition>[HAVING <expression> [{<operator> <expression>}…]][ORDER BY <order by definition>][LIMIT[<offset>,] <row count>]]

    其中,各条子句的含义如下:

  • {*|<字段列名>}包含星号通配符的字段列表,表示所要查询字段的名称。

  • <表 1>,<表 2>…,表 1 和表 2 表示查询数据的来源,可以是单个或多个。

  • WHERE <表达式>是可选项,如果选择该项,将限定查询数据必须满足该查询条件。

  • GROUP BY< 字段 >,该子句告诉 MySQL 如何显示查询出来的数据,并按照指定的字段分组。

  • [ORDER BY< 字段 >],该子句告诉 MySQL 按什么样的顺序显示查询出来的数据,可以进行的排序有升序(ASC)和降序(DESC),默认情况下是升序。

  • [LIMIT[<offset>,]<row count>],该子句告诉 MySQL 每次显示查询出来的数据条数。

  • 下面先介绍一些简单的 SELECT 语句,关于 WHERE、GROUP BY、ORDER BY 和 LIMIT 等限制条件就不细说了。

    1、查询表中所有字段

    查询所有字段是指查询表中所有字段的数据。MySQL 提供了以下 2 种方式查询表中的所有字段。

    SELECT 可以使用“*”查找表中所有字段的数据,语法格式如下:

    SELECT * FROM 表名;

    使用“*”查询时,只能按照数据表中字段的顺序进行排列,不能改变字段的排列顺序。

    示例:从 tb_students_info 表中查询所有字段的数据,SQL 语句和运行结果如下所示。

    mysql> use test_db;Database changedmysql> SELECT * FROM tb_students_info;+----+--------+---------+------+------+--------+------------+| id | name | dept_id | age | sex | height | login_date |+----+--------+---------+------+------+--------+------------+| 1 | Dany | 1 | 25 | F | 160 | 2015-09-10 || 2 | Green | 3 | 23 | F | 158 | 2016-10-22 || 3 | Henry | 2 | 23 | M | 185 | 2015-05-31 || 4 | Jane | 1 | 22 | F | 162 | 2016-12-20 || 5 | Jim | 1 | 24 | M | 175 | 2016-01-15 || 6 | John | 2 | 21 | M | 172 | 2015-11-11 || 7 | Lily | 6 | 22 | F | 165 | 2016-02-26 || 8 | Susan | 4 | 23 | F | 170 | 2015-10-01 || 9 | Thomas | 3 | 22 | M | 178 | 2016-06-07 || 10 | Tom | 4 | 23 | M | 165 | 2016-08-05 |+----+--------+---------+------+------+--------+------------+10 rows in set (0.26 sec)

    结果显示,使用“*”通配符时,将返回所有列,数据列按照创建表时的顺序显示。

    注意:一般情况下,除非需要使用表中所有的字段数据,否则最好不要使用通配符“*”。虽然使用通配符可以节省输入查询语句的时间,但是获取不需要的列数据通常会降低查询和所使用的应用程序的效率。使用“*”的优势是,当不知道所需列的名称时,可以通过“*”获取它们。

    2、查询表中指定的字段

    查询表中的某一个字段的语法格式为:

    SELECT < 列名 > FROM < 表名 >;

    示例:

    查询 tb_students_info 表中 name 列所有学生的姓名,SQL 语句和运行结果如下所示。

    mysql> SELECT name FROM tb_students_info;+--------+| name |+--------+| Dany || Green || Henry || Jane || Jim || John || Lily || Susan || Thomas || Tom |+--------+10 rows in set (0.00 sec)

    输出结果显示了 tb_students_info 表中 name 字段下的所有数据。

    使用 SELECT 声明可以获取多个字段下的数据,只需要在关键字 SELECT 后面指定要查找的字段名称,不同字段名称之间用逗号“,”分隔开,最后一个字段后面不需要加逗号,语法格式如下:

    SELECT <字段名1>,<字段名2>,…,<字段名n> FROM <表名>;

    示例:

    从 tb_students_info 表中获取 id、name 和 height 三列,SQL 语句和运行结果如下所示。

    mysql> SELECT id,name,height -> FROM tb_students_info;+----+--------+--------+| id | name | height |+----+--------+--------+| 1 | Dany | 160 || 2 | Green | 158 || 3 | Henry | 185 || 4 | Jane | 162 || 5 | Jim | 175 || 6 | John | 172 || 7 | Lily | 165 || 8 | Susan | 170 || 9 | Thomas | 178 || 10 | Tom | 165 |+----+--------+--------+10 rows in set (0.00 sec)

    输出结果显示了 tb_students_info 表中 id、name 和 height 三个字段下的所有数据。

    更多编程相关知识,请访问:编程视频!!

    数据库增删改查的基本命令

    (推荐教程:mysql视频教程)

    数据库增删改查基本语句

    数据库增加数据

    在 MySQL 中可以使用 INSERT INTO 语句向数据库已有的表中插入一行或者多行元组数据。

    语法格式:

    INSERT INTO 表名 ( 列名1, 列名2,...列名N ) VALUES ( 值1, 值2,...值N );

    如果数据是字符型,必须使用单引号或者双引号,如:"value"。

  • 表名:指定被操作的表名。

  • 列名:指定需要插入数据的列名。若向表中的所有列插入数据,则全部的列名均可以省略,直接采用 INSERT<表名>VALUES(…) 即可。

  • VALUE 子句:该子句包含要插入的数据清单。数据清单中数据的顺序要和列的顺序相对应。

  • 示例:在 tb_courses 表中插入一条新记录,course_id 值为 1,course_name 值为“Network”,course_grade 值为 3,info 值为“Computer Network”。

    在执行插入操作之前,查看 tb_courses 表

    mysql> SELECT * FROM tb_courses;Empty set (0.00 sec)

    查询结果显示当前表内容为空,没有数据,接下来执行插入数据的操作,输入的 SQL 语句和执行过程如下所示。

    mysql> INSERT INTO tb_courses -> (course_id,course_name,course_grade,course_info) -> VALUES(1,'Network',3,'Computer Network');Query OK, 1 rows affected (0.08 sec)mysql> SELECT * FROM tb_courses;+-----------+-------------+--------------+------------------+| course_id | course_name | course_grade | course_info |+-----------+-------------+--------------+------------------+| 1 | Network | 3 | Computer Network |+-----------+-------------+--------------+------------------+1 row in set (0.00 sec)

    可以看到插入记录成功。在插入数据时,指定了 tb_courses 表的所有字段,因此将为每一个字段插入新的值。

    说明:

  • INSERT 语句后面的列名称顺序可以不是 tb_courses 表定义时的顺序,即插入数据时,不需要按照表定义的顺序插入,只要保证值的顺序与列字段的顺序相同就可以。

  • 使用 INSERT 插入数据时,允许列名称列表 column_list 为空,此时值列表中需要为表的每一个字段指定值,并且值的顺序必须和数据表中字段定义时的顺序相同。

  • 注意:虽然使用 INSERT 插入数据时可以忽略插入数据的列名称,若值不包含列名称,则 VALUES 关键字后面的值不仅要求完整,而且顺序必须和表定义时列的顺序相同。如果表的结构被修改,对列进行增加、删除或者位置改变操作,这些操作将使得用这种方式插入数据时的顺序也同时改变。如果指定列名称,就不会受到表结构改变的影响。

    数据库删除数据

    在 MySQL 中,可以使用 DELETE 语句来删除表的一行或者多行数据。

    语法格式为:

    DELETE FROM 表名 [WHERE 子句] [ORDER BY 子句] [LIMIT 子句]

    删除指定数据:

    DELETE FROM 表名称 WHERE 列名称 = 值

    语法说明如下:

  • 表名:指定要删除数据的表名。

  • ORDER BY 子句:可选项。表示删除时,表中各行将按照子句中指定的顺序进行删除。

  • WHERE 子句:可选项。表示为删除操作限定删除条件,若省略该子句,则代表删除该表中的所有行。

  • LIMIT 子句:可选项。用于告知服务器在控制命令被返回到客户端前被删除行的最大值。

  • 注意:在不使用 WHERE 条件的时候,将删除所有数据。

    示例1:删除表中的全部数据

    删除 tb_courses_new 表中的全部数据,输入的 SQL 语句和执行结果如下所示。

    mysql> DELETE FROM tb_courses_new;Query OK, 3 rows affected (0.12 sec)mysql> SELECT * FROM tb_courses_new;Empty set (0.00 sec)

    示例2:根据条件删除表中的数据

    在 tb_courses_new 表中,删除 course_id 为 4 的记录,输入的 SQL 语句和执行结果如下所示。

    mysql> DELETE FROM tb_courses -> WHERE course_id=4;Query OK, 1 row affected (0.00 sec)mysql> SELECT * FROM tb_courses;+-----------+-------------+--------------+------------------+| course_id | course_name | course_grade | course_info |+-----------+-------------+--------------+------------------+| 1 | Network | 3 | Computer Network || 2 | Database | 3 | MySQL || 3 | Java | 4 | Java EE |+-----------+-------------+--------------+------------------+3 rows in set (0.00 sec)

    由运行结果可以看出,course_id 为 4 的记录已经被删除。

    数据库修改数据

    在 MySQL 中,可以使用 UPDATE 语句来修改、更新一个或多个表的数据。

    语法格式为:

    UPDATE 表名 SET 字段=值 [WHERE 子句 ][ORDER BY 子句] [LIMIT 子句]

    例:

    UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值

    语法说明如下:

  • 表名:用于指定要更新的表名称。

  • SET 子句:用于指定表中要修改的列名及其列值。其中,每个指定的列值可以是表达式,也可以是该列对应的默认值。如果指定的是默认值,可用关键字 DEFAULT 表示列值。

  • WHERE 子句:可选项。用于限定表中要修改的行。若不指定,则修改表中所有的行。

  • ORDER BY 子句:可选项。用于限定表中的行被修改的次序。

  • LIMIT 子句:可选项。用于限定被修改的行数。

  • 注意:修改一行数据的多个列值时,SET 子句的每个值用逗号分开即可。

    示例1:修改表中的数据

    在 tb_courses_new 表中,更新所有行的 course_grade 字段值为 4,输入的 SQL 语句和执行结果如下所示。

    mysql> UPDATE tb_courses_new -> SET course_grade=4;Query OK, 3 rows affected (0.11 sec)Rows matched: 4 Changed: 3 Warnings: 0mysql> SELECT * FROM tb_courses_new;+-----------+-------------+--------------+------------------+| course_id | course_name | course_grade | course_info |+-----------+-------------+--------------+------------------+| 1 | Network | 4 | Computer Network || 2 | Database | 4 | MySQL || 3 | Java | 4 | Java EE || 4 | System | 4 | Operating System |+-----------+-------------+--------------+------------------+4 rows in set (0.00 sec)

    示例1:根据条件修改表中的数据

    在 tb_courses 表中,更新 course_id 值为 2 的记录,将 course_grade 字段值改为 3.5,将 course_name 字段值改为“DB”,输入的 SQL 语句和执行结果如下所示。

    mysql> UPDATE tb_courses_new -> SET course_name='DB',course_grade=3.5 -> WHERE course_id=2;Query OK, 1 row affected (0.13 sec)Rows matched: 1 Changed: 1 Warnings: 0mysql> SELECT * FROM tb_courses_new;+-----------+-------------+--------------+------------------+| course_id | course_name | course_grade | course_info |+-----------+-------------+--------------+------------------+| 1 | Network | 4 | Computer Network || 2 | DB | 3.5 | MySQL || 3 | Java | 4 | Java EE || 4 | System | 4 | Operating System |+-----------+-------------+--------------+------------------+4 rows in set (0.00 sec)

    注意:保证 UPDATE 以 WHERE 子句结束,通过 WHERE 子句指定被更新的记录所需要满足的条件,如果忽略 WHERE 子句,MySQL 将更新表中所有的行。

    数据库查询数据

    在 MySQL 中,可以使用 SELECT 语句来查询数据。查询数据是指从数据库中根据需求,使用不同的查询方式来获取不同的数据,是使用频率最高、最重要的操作。

    SELECT 的语法格式如下:

    SELECT{* | <字段列名>}[FROM <表 1>, <表 2>…[WHERE <表达式>[GROUP BY <group by definition>[HAVING <expression> [{<operator> <expression>}…]][ORDER BY <order by definition>][LIMIT[<offset>,] <row count>]]

    其中,各条子句的含义如下:

  • {*|<字段列名>}包含星号通配符的字段列表,表示所要查询字段的名称。

  • <表 1>,<表 2>…,表 1 和表 2 表示查询数据的来源,可以是单个或多个。

  • WHERE <表达式>是可选项,如果选择该项,将限定查询数据必须满足该查询条件。

  • GROUP BY< 字段 >,该子句告诉 MySQL 如何显示查询出来的数据,并按照指定的字段分组。

  • [ORDER BY< 字段 >],该子句告诉 MySQL 按什么样的顺序显示查询出来的数据,可以进行的排序有升序(ASC)和降序(DESC),默认情况下是升序。

  • [LIMIT[<offset>,]<row count>],该子句告诉 MySQL 每次显示查询出来的数据条数。

  • 下面先介绍一些简单的 SELECT 语句,关于 WHERE、GROUP BY、ORDER BY 和 LIMIT 等限制条件就不细说了。

    1、查询表中所有字段

    查询所有字段是指查询表中所有字段的数据。MySQL 提供了以下 2 种方式查询表中的所有字段。

    SELECT 可以使用“*”查找表中所有字段的数据,语法格式如下:

    SELECT * FROM 表名;

    使用“*”查询时,只能按照数据表中字段的顺序进行排列,不能改变字段的排列顺序。

    示例:从 tb_students_info 表中查询所有字段的数据,SQL 语句和运行结果如下所示。

    mysql> use test_db;Database changedmysql> SELECT * FROM tb_students_info;+----+--------+---------+------+------+--------+------------+| id | name | dept_id | age | sex | height | login_date |+----+--------+---------+------+------+--------+------------+| 1 | Dany | 1 | 25 | F | 160 | 2015-09-10 || 2 | Green | 3 | 23 | F | 158 | 2016-10-22 || 3 | Henry | 2 | 23 | M | 185 | 2015-05-31 || 4 | Jane | 1 | 22 | F | 162 | 2016-12-20 || 5 | Jim | 1 | 24 | M | 175 | 2016-01-15 || 6 | John | 2 | 21 | M | 172 | 2015-11-11 || 7 | Lily | 6 | 22 | F | 165 | 2016-02-26 || 8 | Susan | 4 | 23 | F | 170 | 2015-10-01 || 9 | Thomas | 3 | 22 | M | 178 | 2016-06-07 || 10 | Tom | 4 | 23 | M | 165 | 2016-08-05 |+----+--------+---------+------+------+--------+------------+10 rows in set (0.26 sec)

    结果显示,使用“*”通配符时,将返回所有列,数据列按照创建表时的顺序显示。

    注意:一般情况下,除非需要使用表中所有的字段数据,否则最好不要使用通配符“*”。虽然使用通配符可以节省输入查询语句的时间,但是获取不需要的列数据通常会降低查询和所使用的应用程序的效率。使用“*”的优势是,当不知道所需列的名称时,可以通过“*”获取它们。

    2、查询表中指定的字段

    查询表中的某一个字段的语法格式为:

    SELECT < 列名 > FROM < 表名 >;

    示例:

    查询 tb_students_info 表中 name 列所有学生的姓名,SQL 语句和运行结果如下所示。

    mysql> SELECT name FROM tb_students_info;+--------+| name |+--------+| Dany || Green || Henry || Jane || Jim || John || Lily || Susan || Thomas || Tom |+--------+10 rows in set (0.00 sec)

    输出结果显示了 tb_students_info 表中 name 字段下的所有数据。

    使用 SELECT 声明可以获取多个字段下的数据,只需要在关键字 SELECT 后面指定要查找的字段名称,不同字段名称之间用逗号“,”分隔开,最后一个字段后面不需要加逗号,语法格式如下:

    SELECT <字段名1>,<字段名2>,…,<字段名n> FROM <表名>;

    示例:

    从 tb_students_info 表中获取 id、name 和 height 三列,SQL 语句和运行结果如下所示。

    mysql> SELECT id,name,height -> FROM tb_students_info;+----+--------+--------+| id | name | height |+----+--------+--------+| 1 | Dany | 160 || 2 | Green | 158 || 3 | Henry | 185 || 4 | Jane | 162 || 5 | Jim | 175 || 6 | John | 172 || 7 | Lily | 165 || 8 | Susan | 170 || 9 | Thomas | 178 || 10 | Tom | 165 |+----+--------+--------+10 rows in set (0.00 sec)

    输出结果显示了 tb_students_info 表中 id、name 和 height 三个字段下的所有数据。

    更多编程相关知识,请访问:编程视频!!

    MySQL详解

    数据查询语言(凡是带有 select 关键字的都是查询语句)

    select...

    数据操作语言(凡是对表中的 数据 进行增删改的都是 DML)

    insert 增 delete 删 update 改

    数据定义语言(凡是带有 create、drop、alter 的都是 DDL)

    主要操作的是 表的结构 ,不是表的数据

    事务控制语言(包括:事务提交 commit、事务回滚 rollback)

    数据控制语言(授权 grant、撤销权限 revoke)

    select 字段 from 表名 where 条件;

    in(具体值,具体值,......) 不是区间

    一个输入对应一个输出,和其对应的是多行处理函数(多个输入,对应一个输出)

    输入多行,最终输出一行

    如果你 没有对数据进行分组,整张表默认为一组 。

    在实际的应用中,可能需要先进行分组,然后对每一组的数据进行操作

    案例: 查询每个员工所在部门的名称,显示员工名和部门名?

    emp e 和 dept d 表进行连接。条件是:e.deptno = d.deptno

    SQL92语法:(结构不够清晰,表的连接条件和后期进一步筛选的条件,都放到了 where 子句中)

    SQL99语法:(表连接的条件是的,连接之后,如果还需要进一步筛选,再往后继续添加 where 子句)

    技巧: 把一张表看成两张表

    思考: 外连接的查询结果条数 >= 内连接的查询结果条数

    select 语句中 嵌套 select 语句,被嵌套的 select 语句称为 子查询。

    将查询结果集的一部分取出来。(通常使用在分页查询当中)

    将字符串 varchar 类型转换成 date 类型

    将日期转换成字符串

    可以获取当前系统的时间,并且获取的时间是 datetime 类型的

    注意:若没有条件将会导致所有数据全部更新。

    注意:若没有条件,会删除整张表的数据。

    constraint

    not null 约束的字段 不能为 NULL (只有列级约束)

    unique 约束的字段 不能重复 ,但是可以为 NULL

    primary key

    foreign key

    transaction

    实现原理 :缩小扫描的范围(形成树),避免全表扫描

    Database Administrator 数据库管理员

    数据库表的设计依据。教你怎么进行数据库表的设计。

    免费领取有关于java面试题材料和讲解!

    用SQL语句随便写一条数据库增删改查语句

    一、增:有2种方法

    1.使用insert插入单行数据:

    语法:insert [into] <表名> [列名] values <列值>

    例:insert into Strdents (姓名,性别,出生日期) values ('王伟华','男','1983/6/15')

    注意:如果省略表名,将依次插入所有列

    2.使用insert,select语句将现有表中的 数据添加到已有的新表中

    语法:insert into <已有的新表> <列名> select <原表列名> from <原表名>

    例:insert into addressList ('姓名','地址','电子邮件')select name,address,email          

    from  Strdents 

    注意:查询得到的数据个数、顺序、数据类型等,必须与插入的项保持一致

    二、删:有2中方法

    1.使用delete删除数据某些数据

    语法:delete from <表名> [where <删除条件>]    

    例:delete from a where name='王伟华'(删除表a中列值为王伟华的行)  

    注意:删除整行不是删除单个字段,所以在delete后面不能出现字段名

    2.使用truncate table 删除整个表的数据

    语法:truncate table <表名>

    例:truncate table addressList

    注意:删除表的所有行,但表的结构、列、约束、索引等不会被删除;不能

    用于有外建约束引用的表

    三、改  使用update更新修改数据         

    语法:update <表名> set <列名=更新值> [where <更新条件>]

    例:update addressList set 年龄=18 where 姓名='王伟华'

    注意:set后面可以紧随多个数据列的更新值(非数字要引号);where子句是可选的(非数字要引号),用来条件,如果不选则整个表的所有行都被更新

    四、查

    语法:select <列名> from <表名> [where <查询条件表达试>] [order by <排序的列  

    名>[asc或desc]]

    1).查询所有数据行和列

    例:select * from a

    说明:查询a表中所有行和

    2).查询部分行列--条件查询

    例:select i,j,k   from  a   where f=5

    说明:查询表a中f=5的所有行,并显示i,j,k3列

    3).在查询中使用AS更改列名

    例:select name as 姓名 from a where  gender='男'

    说明:查询a表中性别为男的所有行,显示name列,并将name列改名为(姓名)显示

    4).查询空行

    例:select name from a where email is null

    说明:查询表a中email为空的所有行,并显示name列;SQL语句中用is null或者is not null

    来判断是否为空行

    5).在查询中使用常量

    例:select name '北京' as 地址 from a

    说明:查询表a,显示name列,并添加地址列,其列值都为'北京'

    6).查询返回行数(关键字:top )

    例1:select top 6 name from a

    说明:查询表a,显示列name的前6行,top为关键字(oracle 中没有top关键字

    用rownum替代)

    select   *   from   a where   rownum<6  

    7).查询排序(关键字:order by , asc , desc)

    例:select name

    from a

    where grade>=60

    order by desc

    说明:查询表中成绩大于等于60的所有行,并按降序显示name列;默认为ASC升序

    显示全文