MySQL创建数据库和数据库表及检索数据

更多的知识 见  http://pan.baidu.com/share/link?shareid=365521&uk=1360367844&fid=750852371

1、使用SHOW语句找出在服务器上当前存在什么数据库:

mysql> SHOW DATABASES; 
+----------+ 
| Database | 
+----------+ 
| mysql | 
| test | 
+----------+ 
3 rows in set (0.00 sec)


2、创建一个数据库abccs 
mysql> CREATE DATABASE abccs; 
注意不同操作系统对大小写的敏感。 


3、选择你所创建的数据库 
mysql> USE abccs 
Database changed 
此时你已经进入你刚才所建立的数据库abccs. 


4、 创建一个数据库表 
首先看现在你的数据库中存在什么表: 
mysql> SHOW TABLES; 
Empty set (0.00 sec) 
说明刚才建立的数据库中还没有数据库表。下面来创建一个数据库表mytable:   我们要建立一个你公司员工的生日表,表的内容包含员工姓名、性别、出生日期、出生城市。 

mysql> CREATE TABLE mytable (name VARCHAR(20), sex CHAR(1), 
-> birth DATE, birthaddr VARCHAR(20)); 
Query OK, 0 rows affected (0.00 sec)


由于name、birthadd的列值是变化的,因此选择VARCHAR,其长度不一定是20。可以选择从1到255的任何长度,如果以后需要改变它的字长,可以使用ALTER TABLE语句。);性别只需一个字符就可以表示:"m"或"f",因此选用CHAR(1);birth列则使用DATE数据类型。 
创建了一个表后,我们可以看看刚才做的结果,用SHOW TABLES显示数据库中有哪些表: 
<ccid_nobr>

mysql> SHOW TABLES; 
+---------------------+ 
| Tables in menagerie | 
+---------------------+ 
| mytables | 
+---------------------+


5、显示表的结构: 

mysql> DESCRIBE mytable; 
+-------------+-------------+------+-----+---------+-------+ 
| Field | Type | Null | Key | Default | Extra | 
+-------------+-------------+------+-----+---------+-------+ 
| name | varchar(20) | YES | | NULL | | 
| sex | char(1) | YES | | NULL | | 
| birth | date | YES | | NULL | | 
| deathaddr | varchar(20) | YES | | NULL | | 
+-------------+-------------+------+-----+---------+-------+ 
4 rows in set (0.00 sec)


6、 往表中加入记录 
我们先用SELECT命令来查看表中的数据: 
mysql> select * from mytable; 
Empty set (0.00 sec)
这说明刚才创建的表还没有记录。 加入一条新记录: 

mysql> insert into mytable 
-> values (′abccs′,′f′,′1977-07-07′,′china′); 
Query OK, 1 row affected (0.05 sec)


再用上面的SELECT命令看看发生了什么变化。我们可以按此方法一条一条地将所有员工的记录加入到表中。 


7、用文本方式将数据装入一个数据库表 
如果一条一条地输入,很麻烦。我们可以用文本文件的方式将所有记录加入你的数据库表中。创建一个文本文件“mysql.txt”,每行包含一个记录,用定位符(tab)把值分开,并且以在CREATE TABLE语句中列出的列次序给出,例如: 
<ccid_nobr>

abccs f 1977-07-07 china   
mary f 1978-12-12 usa 
tom m 1970-09-02 usa


使用下面命令将文本文件“mytable.txt”装载到mytable表中:mysql> LOAD DATA LOCAL INFILE "mytable.txt" INTO TABLE pet; 
再使用如下命令看看是否已将数据输入到数据库表中:mysql> select * from mytable;

 8:删除数据库和数据表

删除数据库  drop database db_name;

删除数据表   drop table table_name;

--------------------------------------------------------

1、从数据库表中检索信息 
实际上,前面我们已经用到了SELECT语句,它用来从数据库表中检索信息。 
select语句格式一般为: 
SELECT 检索关键词 FROM 被检索的表 WHERE 检索条件(可选) 
以前所使用的“ * ”表示选择所有的列。下面继续使用我们在上篇文章中创建的表mytable。 


2、查询所有数据: 

mysql> select * from mytable; 
+----------+------+------------+----------+ 
| name | sex | birth | birthaddr | 
+----------+------+------------+--------+ 
| abccs |f | 1977-07-07 | china | 
| mary |f | 1978-12-12 | usa | 
| tom |m | 1970-09-02 | usa | 
+----------+------+------------+----------+ 
3 row in set (0.00 sec)


3、修正错误记录: 
假如tom的出生日期有错误,应该是1973-09-02,则可以用update语句来修正: mysql> update mytable set birth = "1973-09-02" where name = "tom"; 再用2中的语句看看是否已更正过来。 


4、选择特定行 

上面修改了tom的出生日期,我们可以选择tom这一行来看看是否已经有了变化:

mysql> select * from mytable where name = "tom"; 
+--------+------+------------+------------+ 
| name |sex | birth | birthaddr | 
+--------+------+------------+------------+ 
| tom |m | 1973-09-02 | usa | 
+--------+------+------------+------------+ 
1 row in set (0.06 sec)


上面WHERE的参数指定了检索条件。我们还可以用组合条件来进行查询: 

mysql> SELECT * FROM mytable WHERE sex = "f" AND birthaddr = "china"; 
+--------+------+------------+------------+ 
| name |sex | birth | birthaddr | 
+--------+------+------------+------------+ 
| abccs |f | 1977-07-07 | china | 
+--------+------+------------+------------+ 
1 row in set (0.06 sec)


5、 选择特定列 
假如你想查看表中的所有人的姓名,则可以这样操作: 

mysql> SELECT name FROM mytable; 
+----------+ 
| name | 
+----------+ 
| abccs | 
| mary | 
| tom | 
+----------+ 
3 row in set (0.00 sec)


如果想列出姓名和性别两列,则可以用逗号将关键词name和birth分开: mysql> select name,birth from mytable; 


6、对行进行排序 
我们可以对表中的记录按生日大小进行排序: 

mysql> SELECT name, birth FROM mytable ORDER BY birth; 
+----------+------------+ 
| name | birth | 
+----------+------------+ 
| tom | 1973-09-02 | 
| abccs | 1977-07-07 | 
| mary | 1978-12-12 | 
+----------+------------+ 
3 row in set (0.00 sec)


我们可以用DESC来进行逆序排序: 

mysql> SELECT name, birth FROM mytable ORDER BY birth DESC; 
+----------+------------+ 
| name | birth | 
+----------+------------+ 
| mary | 1978-12-12 | 
| abccs | 1977-07-07 | 
| tom | 1973-09-02 | 
+----------+------------+ 
3 row in set (0.00 sec)


7、 行计数 
数据库经常要统计一些数据,如表中员工的数目,我们就要用到行计数函数COUNT()。COUNT()函数用于对非NULL结果的记录进行计数: 

mysql> SELECT COUNT(*) FROM mytable; 
+----------+ 
| COUNT(*) | 
+----------+ 
| 3 | 
+----------+ 
1 row in set (0.06 sec) 
员工中男女数量: 
mysql> SELECT sex, COUNT(*) FROM mytable GROUP BY sex; 
+------+----------+ 
| sex | COUNT(*) | 
+------+----------+ 
| f | 2 | 
| m | 1 | 
+------+----------+ 
2 row in set (0.00 sec)


注意我们使用了GROUP BY对SEX进行了分组。

原文地址:https://www.cnblogs.com/virusdefender/p/3413832.html