1、MySQL插入数据

-  表中使用INSERT INTO SQL语句来插入数据。

-  你可以通过mysql>命令提示窗口中向数据表中插入数据。以下为MySQL数据表插入数据通用的INSERT INTO SQL语法:

INSERT INTO table_name ( field1, field2,...fieldN )
                       VALUES
                       ( value1, value2,...valueN );

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


-  以下实例中我们将向runoob_tbl表中插入三条数据:

root@host# mysql -u root -p password;
Enter password:*******
mysql> use RUNOOB;
Database changed
mysql> INSERT INTO runoob_tbl 
    -> (runoob_title, runoob_author, submission_date)
    -> VALUES
    -> ("学习 PHP", "菜鸟", NOW());
Query OK, 1 rows affected, 1 warnings (0.01 sec)
mysql> INSERT INTO runoob_tbl
    -> (runoob_title, runoob_author, submission_date)
    -> VALUES
    -> ("学习 MySQL", "菜鸟", NOW());
Query OK, 1 rows affected, 1 warnings (0.01 sec)
mysql> INSERT INTO runoob_tbl
    -> (runoob_title, runoob_author, submission_date)
    -> VALUES
    -> ("JAVA 教程", "RUNOOB.COM", '2016-05-06');
Query OK, 1 rows affected (0.00 sec)
mysql>

-  需要注意,使用箭头标记 -> 不是SQL语句的一部分,它仅仅表示一个新行,如果一条SQL语句太长,我们可以通过回车键来创建一个新行来编写SQL语句,SQL语句的命令结束符为分号;。

-  在以上实例中,我们并没有提供runoob_id的数据,因为该字段在创建表的时候已经设置为AUTO_INCREMENT(自动增加)属性。所以,该字段会自动递增而不需要我们去设置,实例中NOW()是一个MySQL函数,该函数返回日期和时间。接下来我们可以通过以下语句来查看数据表数据:

-  读取数据表:

select * from runoob_tbl;

-  输出结果:

ded034344fa7562a29f8c28ac38b8321.jpg



2、MySQL查询数据

-  MySQL数据库库使用SQL SELECT语句来查询数据。

-   你可以通过mysql> 命令提示窗口中在数据库中查询数据。以下为在MySQL数据库中查询数据通用的SELECT语法:

SELECT column_name,column_name
FROM table_name
[WHERE Clause]
[OFFSET M ][LIMIT N]

-  查询语句中你可以使用一个或者多个表,表之间使用逗号(,)分割,并使用WHERE语句来设定查询条件。

-  SELECT命令可以读取一条或者多条记录。

-  你可以使用星号(*)来代替其他字段,SELECT语句会返回表的所有字段数据。

-  你可以使用WHERE语句来包含任何条件。

-  你可以通过OFFSET指定SELECT语句开始查询的数据偏移量。默认的情况下偏移量为0。

-  你可以使用LIMIT属性来设定返回的记录数。



3、MySQL WHERE 子句

-  我们知道从MySQL表中使用SQL SELECT语句来读取数据。

-  如需有条件地从表中选取数据,可将WHERE子句添加到SELECT语句中。以下是SQL SELECT语句使用 WHERE子句从数据表中读取数据的通用语法:

SELECT field1, field2,...fieldN FROM table_name1, table_name2...
[WHERE condition1 [AND [OR]] condition2.....

-  查询语句中你可以使用一个或者多个表,表之间使用逗号(,)分割,并使用WHERE语句来设定查询条件。

-  你可以在WEHRE子句中指定任何条件。

-  你可以使用AND或者OR指定一个或者多个条件。

-  WHERE子句也可以运用于SQL的DELETE或者UPDATE命令。

-  WHERE子句类似于程序语言中的if条件,根据MySQL表中的字段值来读取指定的数据。


-  以下为操作符列表,可用于WHERE子句中。

-  下表中实例假定A为10,B为20:

操作符描述实例
=等号,检测两个值是否相等,如果相等返回true(A = B) 返回false。
<>, !=不等于,检测两个值是否相等,如果不相等返回true(A != B) 返回 true。
>大于号,检测左边的值是否大于右边的值, 如果左边的值大于右边的值返回true(A > B) 返回false。
<小于号,检测左边的值是否小于右边的值, 如果左边的值小于右边的值返回true(A < B) 返回 true。
>=大于等于号,检测左边的值是否大于或等于右边的值, 如果左边的值大于或等于右边的值返回true(A >= B) 返回false。
<=小于等于号,检测左边的值是否小于于或等于右边的值, 如果左边的值小于或等于右边的值返回true(A <= B) 返回 true。

-  如果我们想在MySQL数据表中读取指定的数据,WHREE子句是费用有用的。

-  使用主键来作为WHERE子句的条件查询是非常快速的。

-  如果给定的条件在表中没有任何匹配的记录,那么查询不会返回任何数据。


-  以下实例将读取数据表runoob_tbl表中的runoob_author字段值为“菜鸟”的所有记录:

SELECT * from runoob_tbl WHERE runoob_author='菜鸟';

-  输出结果为:

391b97be1e707025324e1c61f02afd62.jpg

-  MySQL中的WHERE子句的字符串比较是不区分大小写的。你可以使用BINARY关键字来设定WHERE子句的字符串比较是区分大小写的,如下实例:

ysql> SELECT * from runoob_tbl WHERE BINARY runoob_author='runoob.com';
Empty set (0.01 sec)
 
mysql> SELECT * from runoob_tbl WHERE BINARY runoob_author='RUNOOB.COM';
+-----------+---------------+---------------+-----------------+
| runoob_id | runoob_title  | runoob_author | submission_date |
+-----------+---------------+---------------+-----------------+
| 3         | JAVA 教程   | RUNOOB.COM    | 2016-05-06      |
| 4         | 学习 Python | RUNOOB.COM    | 2016-03-06      |
+-----------+---------------+---------------+-----------------+
2 rows in set (0.01 sec)

-  实例中使用了BINARY关键字,是区分大小写的,所以runoob_author='runoob.com'的查询条件是没有数据的。



4、MySQL UPDATE查询

-  如果我们需要修改或者更新MySQL中的数据,我们可以使用SQL UPDATE命令来操作。

-  以下是UPDATE命令修改MySQL数据表数据的通用SQL语法:

UPDATE table_name SET field1=new-value1, field2=new-value2
[WHERE Clause]

-  你可以同时更新一个或者多个字段。

-  你可以在WEHRE子句中指定任何条件。

-  你可以在一个单独表中同时更新数据。


-  以下实例将更新数据表中的runoob_id为3的runoob_title字段值:

mysql> UPDATE runoob_tbl SET runoob_title='学习 C++' WHERE runoob_id=3;
Query OK, 1 rows affected (0.01 sec)
 
mysql> SELECT * from runoob_tbl WHERE runoob_id=3;
+-----------+--------------+---------------+-----------------+
| runoob_id | runoob_title | runoob_author | submission_date |
+-----------+--------------+---------------+-----------------+
| 3         | 学习 C++   | RUNOOB.COM    | 2016-05-06      |
+-----------+--------------+---------------+-----------------+
1 rows in set (0.01 sec)

-  从结果上看,runoob_id为3的runoob_title已被修改。



5、MySQL DELETE语句

-  你可以使用SQL的DELETE FROM命令来删除MySQL数据库中的记录。以下是SQL DELETE语句从MySQL数据表中删除数据的通用语法:

DELETE FROM table_name [WHERE Clause]

-  如果没有指定WHERE子句,MySQL表中的所有记录都将被删除。

-  你可以在WHERE子句中指定任何条件。

-  你可以在单个表中一次性删除记录。


-  以下实例将删除runoob_tbl表中的runoob_id为3的记录:

mysql> use RUNOOB;
Database changed
mysql> DELETE FROM runoob_tbl WHERE runoob_id=3;
Query OK, 1 row affected (0.23 sec)