zoukankan      html  css  js  c++  java
  • 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进行了分组。

  • 相关阅读:
    Oracle 各种查询语句
    Win7下Eclipse中文字体太小
    ASP.NET MVC(Razor)上运用UEditor和xhEditor编辑器检测到有潜在危险的 Request.Form的真正解决办法
    Oracle 分页
    限制IIS访问流量提升IIS性能
    pl\sql工具导出表结构、序列和触发器方法
    JS 中面向对象的5种写法
    去除Windows 2003的登录CTRL+ALT+DEL
    List绑定时无法进行增删查改的解决办法
    .net工具
  • 原文地址:https://www.cnblogs.com/virusdefender/p/3413832.html
Copyright © 2011-2022 走看看