zoukankan      html  css  js  c++  java
  • mysql数据库基本使用(增删改查)

    数据库
    db,database
    数据库:依照某种数据模型进行组织并存放到存储器的数据集合
    dbms,database management system
    数据库管理系统:用来操作和管理数据库的大型服务软件
    dbs,database system
    数据库系统:db+dbms,指带有数据库并整合了数据库管理软件的计算机系统

    mysql简介
    最著名,应用最广泛的开源数据库软件,最早隶属于瑞典的mysql ab公司
    崭新的开源分支mariadb

    mysql的特点及应用
    主要特点
    适用于中小规模,关系型数据库系统
    支持linux unix windows等多种操作系统
    使用c和c++编写,可移植性强
    通过api支持python java perl php等语言
    典型应用环境
    lamp平台,与apache http server组合
    lnmp平台,与nginx组合

    ——————————————————————————————————————————

    主配置文件:/etc/my.cnf
    端口:3306
    数据库目录:/var/lib/mysql
    链接数据库初始随机密码:/root/.mysql_secret

    安装mysql(从官网下载)
    MySQL-embedded-5.6.15-1.el6.x86_64.rpm
    MySQL-server-5.6.15-1.el6.x86_64.rpm
    MySQL-shared-5.6.15-1.el6.x86_64.rpm
    MySQL-shared-compat-5.6.15-1.el6.x86_64.rpm
    MySQL-test-5.6.15-1.el6.x86_64.rpm

    [root@mysql ~]# rpm -Uvh MySQL-*.rpm(安装)
    [root@mysql ~]# service mysql start(起服务)
    [root@mysql ~]# chkconfig mysql on(开机自启)
    [root@mysql ~]# cat /root/.mysql_secret(查看初始随机密码)
    # The random password set for the root user at Mon Aug 28 05:21:00 2017 (local time): 8qtuNmuK
    [root@mysql ~]# mysql -uroot -p8qtuNmuK(登陆)
    mysql> set password for root@"localhost"=password("123456");(修改登陆密码,退出重登)
    [root@mysql ~]# mysql -uroot -p123456(新密码登陆)
    mysql> show databases;(sql命令,每条命令必须要分号(;)结尾,不区分大小写)
    +--------------------+
    | Database |
    +--------------------+
    | information_schema |
    | mysql |
    | performance_schema |
    | test |
    +--------------------+
    4 rows in set (0.06 sec)
    mysql> show databasesc(结束命令以c结束)

    ——————————————————————————————————————————————————

    数据库的基本使用

    库管理:
    库的命名规则:
    可以使用数字(不能使用纯数字),字母,下划线,具有唯一性,区分大小写
    不要使用特殊字符和sql关键字
    存储在数据库服务器上的数据,都是以文件形势存放数据库目录里
    mysql> show databases;(查看已有的库)
    mysql> create database hydra;(创建新库)
    mysql> use hydra;(切换库)
    mysql> select database();(显示当前所在库)
    mysql> show tables;(显示当前库有哪些表)
    mysql> drop database hydra;(删除库)

    表管理:
    表用来存储数据
    mysql> create table 表名(字段名 类型,字段名 类型);(建表)
    mysql> select * from 表名;(查看表记录)
    mysql> desc 表名(查看表结构)
    mysql> insert into 表名 values(字段值列表);(插入记录)
    mysql> delete from 表名;(删除表记录)
    mysql> drop table 表名;(删除表)

    示例:
    mysql> use hydra01;(进hydra01库)
    mysql> create table hydra((建表)
    -> name char(3),(char(3)限制名字有几个字符,默认1个)
    -> age int(字段名 类型)
    -> );
    mysql> insert into hydra values("abc",21),("bcd",21);(插入记录)
    mysql> select * from hydra;(查看表记录)
    mysql> desc hydra(查看表结构)
    mysql> delete from hydra;(删除表记录)
    mysql> drop table hydra;(删除表)


    mysql数据类型
    字符类型
    数值类型
    日期时间类型
    枚举类型


    字符类型:(姓名 地址)
    字符类型的值要用引号括起来
    char:定长,最大为255
    varchar:变长,最大为65532
    mysql> create table hydraxx(name char(20),school char(10),mail varchar(30));(建表)
    mysql> insert into hydraxx values("hydra","kailhydra","hydra@hydra.net")(插入数据)
    mysql> select * from hydraxx;
    +-------+-----------+-----------------+
    | name | school | mail |
    +-------+-----------+-----------------+
    | hydra | kailhydra | hydra@hydra.net |
    +-------+-----------+-----------------+

    数值类型:(年龄 工资 学费 成绩)
    整数和小数(浮点)类型
    整型:根据存储数值的大小分为(有符号 无符号)
    微小整型:tinyint 有符号:-128到127 无符号:0-255
    小整型: smallint 有符号:-32768到32767 无符号:0-65535
    中整型: mediumint
    大整型: int
    极大整型:bigint
    浮点型:单精度 4个字节,双精度 8个字节
    单精度:float(M,N)(M总位数,N小数的位数)
    双精度:double(M,N)
    mysql> create table t1(name char(10),age tinyint unsigned);
    mysql> insert into t1 values("hydra",20)(unsigned为取反,默认为有符号)
    mysql> select * from t1;
    +-------+------+
    | name | age |
    +-------+------+
    | hydra | 20 |
    +-------+------+
    mysql> create table t2(name char(10),age int unsigned);
    mysql> insert into t2 values("xxxx",10000);
    mysql> select * from t2;
    +------+-------+
    | name | age |
    +------+-------+
    | xxxx | 10000 |
    +------+-------+
    mysql> create table t3(name char(10),age bigint unsigned);(极大整数)
    mysql> insert into t3 values("xxxxx",10000000);
    mysql> select * from t3;
    +-------+----------+
    | name | age |
    +-------+----------+
    | xxxxx | 10000000 |
    +-------+----------+
    mysql> create table t5(name char(10),age tinyint(2) unsigned,pay float(7,2));(浮点,总的有7个数,两个小数)
    mysql> insert into t5 values("hydra",20,20000.00);
    mysql> select * from t5;
    +-------+------+----------+
    | name | age | pay |
    +-------+------+----------+
    | hydra | 20 | 20000.00 |
    +-------+------+----------+
    mysql> insert into t5 values("hydra1",21,20581.78);
    mysql> select * from t5;
    +--------+------+----------+
    | name | age | pay |
    +--------+------+----------+
    | hydra | 20 | 20000.00 |
    | hydra1 | 21 | 20581.78 |
    +--------+------+----------+

    日期时间类型:(生日 注册时间 入学时间)
    year年:yyyy 2017
    dete日期:yyyymmdd 20170828
    time时间:hhmmss 184250
    日期时间:datetime/timestamp yyyymmddhhmmss 20170828184250
    datetime与timestamp区别:
    datetime:1000-01-01 00:00:00.000000
    9999-12-31 23:59:59.999999
    timestamp:1970-01-01 00:00:00.000000
    2038-01-10 03::14:07.999999
    使用mysql的时间函数获取时间给字段赋值
    now() year() month() date() day() time()
    mysql> create table t6(name char(10),age tinyint(2) unsigned,pay float(7,2),birthdat date,class time,meetting datetime);
    mysql> insert into t6 values("hydraxx",21,17800.15,20170828,190320,20170915203051);
    mysql> select * from t6;
    +---------+------+----------+------------+----------+---------------------+
    | name | age | pay | birthdat | class | meetting |
    +---------+------+----------+------------+----------+---------------------+
    | hydraxx | 21 | 17800.15 | 2017-08-28 | 19:03:20 | 2017-09-15 20:30:51 |
    +---------+------+----------+------------+----------+---------------------+
    mysql> insert into t6 values("boy",21,17800.15,now(),now(),now());
    mysql> select * from t6;
    +---------+------+----------+------------+----------+---------------------+
    | name | age | pay | birthdat | class | meetting |
    +---------+------+----------+------------+----------+---------------------+
    | hydraxx | 21 | 17800.15 | 2017-08-28 | 19:03:20 | 2017-09-15 20:30:51 |
    | boy | 21 | 17800.15 | 2017-08-28 | 11:18:07 | 2017-08-28 11:18:07 |
    +---------+------+----------+------------+----------+---------------------+
    mysql> insert into t7 values(now(),now());
    mysql> insert into t7 values(time2)(20170828193356);(给第二个字段赋值)
    mysql> select * from t7;
    +---------------------+---------------------+
    | time1 | time2 |
    +---------------------+---------------------+
    | 2017-08-28 11:32:23 | 2017-08-28 11:32:23 |
    | NULL | 2017-08-28 19:33:56 |
    +---------------------+---------------------+

    枚举类型:(兴趣 爱好 专业 部门)
    字段的值只能在列举的列表里选择
    enum(值列表):只能在列表选择一个值
    set(值列表):可以在列表选择一个或多个值
    mysql> create table t10(name char(10),age int,sex enum("boy","girl"),likes set("girl","linux"))
    mysql> insert into t10 values("Anonymous",20,"boy","girl,linux");
    mysql> select * from t10;
    +-----------+------+------+------------+
    | name | age | sex | likes |
    +-----------+------+------+------------+
    | Anonymous | 20 | boy | girl,linux |
    +-----------+------+------+------------+
    mysql> insert into t11 values("hydra",20,"1","girl,linux");(枚举可以用数字代表值,数字1代表第一个值)
    mysql> select * from t11;
    +-----------+------+------+------------+
    | name | age | sex | likes |
    +-----------+------+------+------------+
    | Anonymous | 20 | boy | girl,linux |
    | hydra | 20 | boy | girl,linux |
    +-----------+------+------+------------+

    约束条件:
    是否允许给字段赋null(空)值,默认允许赋null值
    not null(不允许赋空值)
    Default:给字段设置默认值,当向表中插入新纪录时,不给字段赋值
    给自己赋值,默认值在不设置的情况下,默认值的值是null值
    default 值(默认值要与字段类型匹配)
    mysql> create table t12(name char(10) not null,age int default 21,sex enum("boy","girl"),likes set("girl","linux","it"));
    mysql> desc t12;
    +-------+--------------------------+------+-----+---------+-------+
    | Field | Type | Null | Key | Default | Extra |
    +-------+--------------------------+------+-----+---------+-------+
    | name | char(10) | NO | | NULL | |
    | age | int(11) | YES | | 21 | |
    | sex | enum('boy','girl') | YES | | NULL | |
    | likes | set('girl','linux','it') | YES | | NULL | |
    +-------+--------------------------+------+-----+---------+-------+
    mysql> insert into t12 values("hydra",20,"boy","girl,linux");


    修改表结构:
    alter table 表名 执行动作;

    执行动作:

    添加新字段
    add 字段名 类型(宽度) 约束条件;
    first:把新字段添加在所有字段的前边
    after:把新字段添加在指定字段的后面
    mysql> alter table t12 add qq char(10),add mial varchar(30) default Anonymous@hydra.net;
    mysql> select * from t12;
    +-------+------+------+------------+------+---------------------+
    | name | age | sex | likes | qq | mial |
    +-------+------+------+------------+------+---------------------+
    | hydra | 20 | boy | girl,linux | NULL | Anonymous@hydra.net |
    +-------+------+------+------------+------+---------------------+
    mysql> alter table t12 add id char(9) first;(把新字段添加在所有字段前边)
    mysql> alter table t12 add tel char(11) after name;(把新字段添加在name字段后面)
    mysql> desc t12;
    mysql> desc t12;
    +-------+--------------------------+------+-----+---------------------+-------+
    | Field | Type | Null | Key | Default | Extra |
    +-------+--------------------------+------+-----+---------------------+-------+
    | id | char(9) | YES | | NULL | |
    | name | char(10) | NO | | NULL | |
    | tel | char(11) | YES | | NULL | |
    | age | int(11) | YES | | 21 | |
    | sex | enum('boy','girl') | YES | | NULL | |
    | likes | set('girl','linux','it') | YES | | NULL | |
    | qq | char(10) | YES | | NULL | |
    | mial | varchar(30) | YES | | Anonymous@hydra.net | |
    +-------+--------------------------+------+-----+---------------------+-------+

    删除已有字段
    drop 字段名;
    mysql> alter table t12 drop age;
    mysql> desc t12;
    +-------+--------------------------+------+-----+---------------------+-------+
    | Field | Type | Null | Key | Default | Extra |
    +-------+--------------------------+------+-----+---------------------+-------+
    | id | char(9) | YES | | NULL | |
    | name | char(10) | NO | | NULL | |
    | tel | char(11) | YES | | NULL | |
    | sex | enum('boy','girl') | YES | | NULL | |
    | likes | set('girl','linux','it') | YES | | NULL | |
    | qq | char(10) | YES | | NULL | |
    | mial | varchar(30) | YES | | Anonymous@hydra.net | |
    +-------+--------------------------+------+-----+---------------------+-------

    修改字段类型(修改后的类型不能和已有的数据冲突)
    modify 字段名 类型(宽度) 约束条件;
    mysql> alter table t12 modify qq varchar(10);
    +-------+--------------------------+------+-----+---------------------+-------+
    | Field | Type | Null | Key | Default | Extra |
    +-------+--------------------------+------+-----+---------------------+-------+
    | id | char(9) | YES | | NULL | |
    | name | char(10) | NO | | NULL | |
    | tel | char(11) | YES | | NULL | |
    | sex | enum('boy','girl') | YES | | NULL | |
    | likes | set('girl','linux','it') | YES | | NULL | |
    | qq | varchar(10) | YES | | NULL | |
    | mial | varchar(30) | YES | | Anonymous@hydra.net | |
    +-------+--------------------------+------+-----+---------------------+-------+

    修改字段名
    change 原字段名 新字段名 类型(宽度) 约束条件;
    mysql> alter table t12 change qq twitter varchar(30);
    +---------+--------------------------+------+-----+---------------------+-------+
    | Field | Type | Null | Key | Default | Extra |
    +---------+--------------------------+------+-----+---------------------+-------+
    | id | char(9) | YES | | NULL | |
    | name | char(10) | NO | | NULL | |
    | tel | char(11) | YES | | NULL | |
    | sex | enum('boy','girl') | YES | | NULL | |
    | likes | set('girl','linux','it') | YES | | NULL | |
    | twitter | varchar(30) | YES | | NULL | |
    | mial | varchar(30) | YES | | Anonymous@hydra.net | |
    +---------+--------------------------+------+-----+---------------------+-------+
    综合使用:
    mysql> alter table t12 add cj int(3) default 100,drop tel,modify twitter varchar(50);
    mysql> desc t12;
    +---------+--------------------------+------+-----+---------------------+-------+
    | Field | Type | Null | Key | Default | Extra |
    +---------+--------------------------+------+-----+---------------------+-------+
    | id | char(9) | YES | | NULL | |
    | name | char(10) | NO | | NULL | |
    | sex | enum('boy','girl') | YES | | NULL | |
    | likes | set('girl','linux','it') | YES | | NULL | |
    | twitter | varchar(50) | YES | | NULL | |
    | mial | varchar(30) | YES | | Anonymous@hydra.net | |
    | cj | int(3) | YES | | 100 | |
    +---------+--------------------------+------+-----+---------------------+-------+


    ——————————————————————————————————————————————————————————————————

  • 相关阅读:
    MYSQL利用merge存储引擎来实现分表
    IoC原理及实现
    prometheus + grafana安装部署(centos6.8)
    PHP Laravel定时任务Schedule
    排序算法杂谈(三) —— 归并排序的非递归实现
    排序算法杂谈(二) —— 冒泡排序的递归实现
    排序算法杂谈(一) —— 量化数组的有序程度
    排序算法(七) —— 快速排序
    排序算法(六) —— 归并排序
    排序算法(五) —— 堆排序
  • 原文地址:https://www.cnblogs.com/Hydraxx/p/7449777.html
Copyright © 2011-2022 走看看