zoukankan      html  css  js  c++  java
  • mysql -在终端操作数据库(不定时update)

    --mysql 学习笔记
    -- 关系型数据库
    
    --一、 如何使用终端操作数据库
    
    --1. 如何登陆数据库服务器
    fudandandembp:~ futantan$ mysql -u root -p
    Enter password: 
    
    --2. 如何查询数据库服务器中所有的数据库?
    
    mysql> show databases;  --一定要有英文的分号
    +--------------------+
    | Database           |
    +--------------------+
    | information_schema |
    | mysql              |
    | performance_schema |
    | sys                |
    +--------------------+
    4 rows in set (0.01 sec)
    
    mysql>
    
    --添加database :
    创建数据库,该命令的作用:
    如果数据库不存在则创建,存在则不创建。
    mysql> create database student;
    Query OK, 1 row affected (0.01 sec) 
    
    --3.如何选中某一个数据库进行操作
    mysql> select * from admin;
    ERROR 1046 (3D000): No database selected
    mysql> 
    
    mysql> use student;
    Database changed
    mysql> 
    
    --如何在数据库中创建数据库;
    create database test 
    mysql> create database test;
    Query OK, 1 row affected (0.00 sec)
    
    mysql> use test;
    Database changed
    mysql> 
    
    --如何查看数据哭中所有的数据哭;
    mysql> show tables;
    Empty set (0.01 sec)
    
    mysql> 
    
    --创建一个数据表;
    
    create TABLE PET(
        name VARCHAR(20),
        owner VARCHAR(20),
        species VARCHAR(20),
        sex CHAR(1),
        birth DATE,
        death DATE);
    
    mysql> show tables;
    +----------------+
    | Tables_in_test |
    +----------------+
    | PET            |
    +----------------+
    1 row in set (0.00 sec)
    
    mysql> 
    
    --查看数据表的结构;
    mysql> describe pet;
    +---------+-------------+------+-----+---------+-------+
    | Field   | Type        | Null | Key | Default | Extra |
    +---------+-------------+------+-----+---------+-------+
    | name    | varchar(20) | YES  |     | NULL    |       |
    | owner   | varchar(20) | YES  |     | NULL    |       |
    | species | varchar(20) | YES  |     | NULL    |       |
    | sex     | char(1)     | YES  |     | NULL    |       |
    | birth   | date        | YES  |     | NULL    |       |
    | death   | date        | YES  |     | NULL    |       |
    +---------+-------------+------+-----+---------+-------+
    6 rows in set (0.01 sec)
    
    mysql> 
    
    --查看数据表中的记录;
    mysql> select * from pet;
    Empty set (0.01 sec)
    
    mysql> 
    
    --如何在数据表中添加记录呢?
    INSERT INTO pet
    VALUES ('jianguo','xiaozhan','yingduan','f','2018-09-05',NULL);
    
    mysql> INSERT INTO pet
        -> VALUES ('jianguo','xiaozhan','yingduan','f','2018-09-05',NULL);
    Query OK, 1 row affected (0.00 sec)
    
    mysql> select * from pet;
    +---------+----------+----------+------+------------+-------+
    | name    | owner    | species  | sex  | birth      | death |
    +---------+----------+----------+------+------------+-------+
    | jianguo | xiaozhan | yingduan | f    | 2018-09-05 | NULL  |
    +---------+----------+----------+------+------------+-------+
    1 row in set (0.00 sec)
    
    mysql> 
    
    --再加一个;
    
    mysql> INSERT INTO pet
        -> VALUES ('wangcai','zhouxingchi','cat','m','2019-08-05',NULL);
    Query OK, 1 row affected (0.01 sec)
    
    mysql> select * from pet;
    +---------+-------------+----------+------+------------+-------+
    | name    | owner       | species  | sex  | birth      | death |
    +---------+-------------+----------+------+------------+-------+
    | jianguo | xiaozhan    | yingduan | f    | 2018-09-05 | NULL  |
    | wangcai | zhouxingchi | cat      | m    | 2019-08-05 | NULL  |
    +---------+-------------+----------+------+------------+-------+
    2 rows in set (0.00 sec)
    
    mysql> 
    
    --mysql 常用类型有哪些;
    https://www.runoob.com/mysql/mysql-data-types.html
    MySQL中定义数据字段的类型对你数据库的优化是非常重要的。
    MySQL支持多种类型,大致可以分为三类:
    数值
    日期/时间
    字符串(字符)类型
    类型    大小    范围(有符号)    范围(无符号)    用途
    TINYINT    1 byte    (-128127)    (0255)    小整数值
    SMALLINT    2 bytes    (-32 76832 767)    (065 535)    大整数值
    MEDIUMINT    3 bytes    (-8 388 6088 388 607)    (016 777 215)    大整数值
    INT或INTEGER    4 bytes    (-2 147 483 6482 147 483 647)    (04 294 967 295)    大整数值
    BIGINT        8 bytes    (-9,223,372,036,854,775,8089 223 372 036 854 775 807)    (018 446 744 073 709 551 615)    极大整数值
    FLOAT        4 bytes    (-3.402 823 466 E+38-1.175 494 351 E-38),0,(1.175 494 351 E-383.402 823 466 351 E+38)    0,(1.175 494 351 E-383.402 823 466 E+38)    单精度
    浮点数值
    DOUBLE        8 bytes    (-1.797 693 134 862 315 7 E+308-2.225 073 858 507 201 4 E-308),0,(2.225 073 858 507 201 4 E-3081.797 693 134 862 315 7 E+308)    0,(2.225 073 858 507 201 4 E-3081.797 693 134 862 315 7 E+308)    双精度
    浮点数值
    DECIMAL    对DECIMAL(M,D) ,如果M>D,为M+2否则为D+2    依赖于M和D的值    依赖于M和D的值    小数值
    

    --举个例子:

    
    

    mysql> create table testtype(
    -> number TINYINT
    -> );
    Query OK, 0 rows affected (0.01 sec)

    
    

    mysql> show tables
    -> exit;
    ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'exit' at line 2
    mysql> show tables;
    +----------------+
    | Tables_in_test |
    +----------------+
    | PET |
    | testtype |
    +----------------+
    mysql> INSERT INTO testtype VALUE(127);
    Query OK, 1 row affected (0.00 sec)

    
    

    mysql> INSERT INTO testtype VALUE(128);
    ERROR 1264 (22003): Out of range value for column 'number' at row 1
    mysql>

    
    

    --日期 选择按照格式
    日期和时间类型
    表示时间值的日期和时间类型为DATETIME、DATE、TIMESTAMP、TIME和YEAR。
    每个时间类型有一个有效值范围和一个"零"值,当指定不合法的MySQL不能表示的值时使用"零"值。
    TIMESTAMP类型有专有的自动更新特性,将在后面描述。
    类型 大小
    ( bytes) 范围 格式 用途
    DATE 3 1000-01-01/9999-12-31 YYYY-MM-DD 日期值
    TIME 3 '-838:59:59'/'838:59:59' HH:MM:SS 时间值或持续时间
    YEAR 1 1901/2155 YYYY 年份值
    DATETIME 8 1000-01-01 00:00:00/9999-12-31 23:59:59 YYYY-MM-DD HH:MM:SS 混合日期和时间值
    TIMESTAMP 4
    1970-01-01 00:00:00/2038
    结束时间是第 2147483647 秒,北京时间 2038-1-19 11:14:07,格林尼治时间 2038年1月19日 凌晨 03:14:07
    YYYYMMDD HHMMSS 混合日期和时间值,时间戳

    
    


    --数值和字符串按照大小
    字符串类型指CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM和SET。该节描述了这些类型如何工作以及如何在查询中使用这些类型。
    类型 大小 用途
    CHAR 0-255 bytes 定长字符串
    VARCHAR 0-65535 bytes 变长字符串
    TINYBLOB 0-255 bytes 不超过 255 个字符的二进制字符串
    TINYTEXT 0-255 bytes 短文本字符串
    BLOB 0-65 535 bytes 二进制形式的长文本数据
    TEXT 0-65 535 bytes 长文本数据
    MEDIUMBLOB 0-16 777 215 bytes 二进制形式的中等长度文本数据
    MEDIUMTEXT 0-16 777 215 bytes 中等长度文本数据
    LONGBLOB 0-4 294 967 295 bytes 二进制形式的极大文本数据
    LONGTEXT 0-4 294 967 295 bytes 极大文本数据

    
    

    --删除数据

    
    

    mysql> select * from pet;
    +----------+-------------+----------+------+------------+-------+
    | name | owner | species | sex | birth | death |
    +----------+-------------+----------+------+------------+-------+
    | jianguo | xiaozhan | yingduan | f | 2018-09-05 | NULL |
    | wangcai | zhouxingchi | cat | m | 2019-08-05 | NULL |
    | xiaowang | wangyibo | dog | f | 2018-08-05 | NULL |
    | xiaowang | wangyibo | dog | f | 2018-08-05 | NULL |
    +----------+-------------+----------+------+------------+-------+
    4 rows in set (0.00 sec)

    
    

    mysql> delete from pet where name='xiaowang';
    Query OK, 2 rows affected (0.00 sec)

    
    

    mysql> select * from pet;
    +---------+-------------+----------+------+------------+-------+
    | name | owner | species | sex | birth | death |
    +---------+-------------+----------+------+------------+-------+
    | jianguo | xiaozhan | yingduan | f | 2018-09-05 | NULL |
    | wangcai | zhouxingchi | cat | m | 2019-08-05 | NULL |
    +---------+-------------+----------+------+------------+-------+
    2 rows in set (0.00 sec)

    
    

    mysql>

    
    

    --如何修改数据

    
    

    mysql> update pet set name='wangwang' where owner='wangyibo';
    Query OK, 1 row affected (0.00 sec)
    Rows matched: 1 Changed: 1 Warnings: 0

    
    

    mysql> select * from pet;
    +----------+-------------+----------+------+------------+-------+
    | name | owner | species | sex | birth | death |
    +----------+-------------+----------+------+------------+-------+
    | jianguo | xiaozhan | yingduan | f | 2018-09-05 | NULL |
    | wangcai | zhouxingchi | cat | m | 2019-08-05 | NULL |
    | wangwang | wangyibo | dog | f | 2018-08-05 | NULL |
    +----------+-------------+----------+------+------------+-------+
    3 rows in set (0.00 sec)

    
    

    --总结一下:数据记录常见操作

    
    

    --增加:
    INSERT
    --删除:
    delete
    --修改:
    update :
    --查询:
    select

    --二、 如何使用可视化工具操作数据库
    
    --三、 如何在编程语言中操作数据库
  • 相关阅读:
    isa与hasa的关系
    两道笔试题的解法
    无耻的WoW打钱工作室
    我正处于恶性循环中——读wowar上的一篇帖子有感
    snippets from ObjectOriented Thought Process (1)
    使用C#获取当前Windows所设定的时区
    用ASP.NET模拟Windows Service来实现定时提醒之类的功能
    乱说 缓存
    认识数据库连接
    网站sql注入的技巧与防范
  • 原文地址:https://www.cnblogs.com/clairedandan/p/13237752.html
Copyright © 2011-2022 走看看