zoukankan      html  css  js  c++  java
  • 数据库管理及增删改查基本操作小结

     
    一. 数据库查询语言
     
    1)查询employees数据表中的所有数据记录: select * from employees;
    2)查询employees表中的employee_id, first_name记录:select employee_id,first_name from employees;
    3)查询test表中score列数据的所有平均值:select AVG(score) from test;
    4)统计有多少条employee_id记录,显示最终统计个数:select count(employee_id) from employees;
    5)如果有多条相同的email记录,DISTINCT可以去除重复记录:select distinct(e_mail) from employees;
    6)查询last_name为willian的所有记录,并显示出相应的first_name记录:select first_name from employees where last_name="willian";
    7)查询表中所有记录,按周hire_date列排序,DESC为降序,AES为升序:select * from employees order by hire_date DESC;
    8)限制仅显示数据记录中的前两行记录:select * from employees limit 2;
     
     
    二. 数据库定义语言
     
    1. 新建数据库:create database hr;
    2. 显示所有数据库:show databases;
    3. 新建数据库中的表:首先进入相应的数据库 use hr; 然后create table + 表名(表项1,表项2...)
           
        其中ENGINE=innodb DEFAULT CHARSET=UTF8; #设置默认存储引擎和默认字体,也可单独写
    4. show tables;查看数据表(只显示表名,如果想查看详细信息,describe + 表名,如5)
    5. 查看数据表的数据结构 :describe employee;
    6. alter database:修改数据库属性,属性被保存在数据库目录的db.opt文件中。
         例如:修改数据库默认字符集和排序规则
        alter database hr default character set=utf8;
        alter database hr default collate=utf8_general_ci;
    7. 修改数据表结构,如添加删除的列,创建删除的索引,修改数据类型等
        例如:创建数据表test1后,通过alter语句修改数据表的相关信息
         create table test1(id int, name char(20));
         alter table test1 rename test2; #修改test1名字为test2
         alter table test2 add date timestamp;  #添加date项,类型为时间戳
         alter table test2 add note char(50); #增加note项
         alter table test2 add index (date); #给date项添加普通索引
         alter table test2 modify id tinyint not null, change name first_name char(20); #修改id类型为tinyint,并设为非空,修改name值为first_name
         alter table test2 add primary key(id); #给id添加主索引
         alter table test2 drop column note; #删除note行
    8. 删除名为hr的数据表:drop table hr;
    9 对一个或多个数据表重命名
          rename table test1 to temp, test3 to test1, temp to test3;
    10. 删除数据库及当中的数据表
          drop database hr;
    11. 删除索引
    删除索引可以使用ALTER TABLE或DROP INDEX语句来实现。DROP INDEX可以在ALTER TABLE内部作为一条语句处理,其格式如下:
    drop index index_name on table_name ; #一般用这个就足够了
    alter table table_name drop index index_name ;
    alter table table_name drop primary key ;
    其中,在前面的两条语句中,都删除了table_name中的索引index_name。而在最后一条语句中,只在删除PRIMARY KEY索引中使用,因为一个表只可能有一个PRIMARY KEY索引,因此不需要指定索引名。
    如果没有创建PRIMARY KEY索引,但表具有一个或多个UNIQUE索引,则MySQL将删除第一个UNIQUE索引。
    如果从表中删除某列,则索引会受影响。对于多列组合的索引,如果删除其中的某列,则该列也会从索引中删除。如果删除组成索引的所有列,则整个索引将被删除。
     
    例如:
     

    使用命令 mysql> drop index date on test2;

     

     

     
     
    三. 数据库操作语言
    1. insert

    结果如下

     

    2. update
    用来更新数据表中现有的数据值(仅修改满足where条件的数据记录)
    update hr.employee set name="luck" where id=3;  #修改lucky为luck
     
    3. load data infile
    快速从文本文件中读取数据到数据表中
    分隔符:文件默认使用Tab键位列分隔符,换行符为行分隔符,可以使用FIELDS TERMINATED BY 设置列分隔符,通过LINES STARTING BY设置行分隔符。
     
    例如:提前创建数据文件/tmp/txt与txt2,通过LOAD语句加载数据到employee数据表
    cat /tmp/txt
    004    ellis    ellis@gmail.com    sale
    mysql> load data infile '/tmp/txt' into table hr.employee;
    cat /tmp/txt2
    005,berry,berry@gmail.com,admin
    mysql> load data infile '/tmp/txt2' into table hr.employee fields terminated by ',';
    结果如下
     
     
    4.delete
    把满足条件的数据记录删除并返回删除的记录数量,如下
    mysql> use hr;
    mysql> delete from employee where id=5;
    mysql> delete from employee where name="ellis";
     
     
    四. 添加删除用户,授权,修改用户密码

    1. 创建用户:

    命令:CREATE USER 'username'@'host' IDENTIFIED BY 'password';
    例子: CREATE USER 'hong'@'localhost' IDENTIFIED BY '123456';
             CREATE USER 'cat'@'localhost' IDENTIFIED BY '';
     
    注意:
    username - 你将创建的用户名,
    host - 指定该用户在哪个主机上可以登陆,此处的"localhost",是指该用户只能在本地登录,不能在另外一台机器上远程登录;
              如果想远程登录的话,将"localhost"改为"%",表示在任何一台电脑上都可以登录;
              也可以指定某台机器可以远程登录,此时用指定机器的ip;
    password - 该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器。
     

    2. 授权:

    命令:GRANT privileges ON databasename.tablename TO 'username'@'host'
     
    注意:
         privileges - 用户的操作权限,如SELECT , INSERT , UPDATE 等(详细列表见该文最后面).如果要授予所的权限则使用ALL.;
         databasename - 数据库名,
         tablename-表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示, 如*.*.
     
    例子: GRANT SELECT, INSERT ON mq.* to 'hong'@'localhost';
     

    3. 创建用户同时授权

    1.创建tomcat账户,该账户仅可以通过本机连接mysql服务器,对hr数据库中的所有数据表拥有所有权限
    mysql> grant all privileges on hr.* to 'tomcat'@'localhost' identified by '1234'; #注意中间没逗号,这是一个语句
     
    2. 创建tomcat账户,此账户只能从主机192.168.0.88连接到服务器,对hr数据库中的所有数据表仅有查询权限
    mysql > grant select on hr.* to 'tomcat'@’192.168.0.88‘ identified by 'pass';
     
    3. 创建admin账户,赋予该账户对所有数据库的管理权限,不需密码即可从本机连接mysql服务器
    mysql>grant reload,process on *.* to 'admin'@'localhost';
     
    4. 创建jacob账户,赋予jacob对hr数据库中所有数据表的所有权限,该账户可从任何主机连接服务器
    mysql> grant all on hr.* to 'jacob'@'%' identified by 'pass';
    mysql> flush privileges;
     
    PS:必须执行flush privileges; 
    否则登录时提示:ERROR 1045 (28000): Access denied for user 'user'@'localhost' (using password: YES ) 
     

    4. 设置与更改用户密码的3种方式

    1.通过命令:SET PASSWORD设置密码
    格式:SET PASSWORD FOR 'username'@'host' = PASSWORD('newpassword');
    例子: SET PASSWORD FOR 'admin'@'localhost' = PASSWORD("321");
    2. 直接修改数据库权限数据表mysql.user
    mysql>update mysql.user set password=password('新密码') where User="admin" and Host="localhost";
    mysql>flush privileges;
    注意:MySQL5.7 mysql.user表没有password字段改 authentication_string;
     
    3. 通过mysqladmin设置账户密码
    mysqladmin -u root -p password '123'
    -p的作用是提示输入旧密码,若没有旧密码,可忽略。
     
    4. 有时候设置的root密码会忘记,怎么修改呢?  
     
    【mysql 5.6】
    vim /etc/mysql/my.cnf(有的版本是  /etc/my.cnf
    在[mysqld]的段中加上一句:skip-grant-tables 保存并且退出vim
    重新启动mysqld
    # /etc/init.d/mysql restart ( service mysql restart )
    登录并修改MySQL的root密码
    mysql> USE mysql ;
    mysql> UPDATE user SET Password = password ( 'new-password' ) WHERE User = 'root' ;
    mysql> flush privileges ;
    mysql> quit
    将MySQL的登录设置修改回来
    vim /etc/my.cnf
    将刚才在[mysqld]的段中加上的skip-grant-tables删除 或者注释掉
    重新启动mysqld
    # /etc/init.d/mysql restart  ( service mysq
    l restart )
    [mysql5.7]
    进入mysql之前不变,只改一句。
    mysql> update mysql.user set authentication_string=password('123qwe') where user='root' and Host = 'localhost';
     
     
    补充内容:
    mysql 5.6,5.7装好之后会有一个临时密码,存放位置  grep "temporary password" /var/log/mysqld.log 

     

    5. 撤销用户权限

    命令: REVOKE privilege ON databasename.tablename FROM 'username'@'host';
    例子: REVOKE SELECT ON hr.* FROM 'admin'@'localhost'; 
            revoke all on hr.* from tomcat@'%'; #撤销tomcat对hr数据库的所有权限
            revoke select on *.* from jacob@'%'; #撤销jacob对所有数据库的查询权限
    注意:
    假如你在给用户'hong'@'localhost''授权的时候是这样的(或类似的):GRANT SELECT ON test.user TO 'hong'@'localhost', 则在使用REVOKE SELECT ON *.* FROM 'hong'@'localhost';命令并不能撤销该用户对test数据库中user表的SELECT 操作.
    相反,如果授权使用的是GRANT SELECT ON *.* TO 'hong'@'localhost';则REVOKE SELECT ON test.user FROM 'hong'@'localhost';也不能撤销该用户对test数据库中user表的Select 权限.
    具体信息用命令SHOW GRANTS FOR 'hong'@'localhost'; 查看.
     

    6.删除用户

    命令: DROP USER 'username'@'host';

    比如:mysql> drop user jerry@'172.16.0.253';
    有时候可能需要先查看用户有哪些,命令如下
    mysql> use mysql;
    mysql> select host,user from mysql.user;
     

    7.查看用户的授权

    mysql> show grants for hong@localhost;
    +---------------------------------------------+
    | Grants for dog@localhost |
    +---------------------------------------------+
    | GRANT USAGE ON *.* TO 'hong'@'localhost' |
    | GRANT INSERT ON `mq`.* TO 'hong'@'localhost' |
    +---------------------------------------------+
    2 rows in set (0.00 sec)
    注意:GRANT USAGE: usage权限就是空权限,默认create user的权限,只能连库,啥也不能干
     
     
     
     
    五.  MySQL在Linux下数据库名、表名、列名、别名大小写规则是这样的:
     
      1、数据库名与表名是严格区分大小写的;
     
      2、表的别名是严格区分大小写的;
     
      3、列名与列的别名在所有的情况下均是忽略大小写的;
     
      4、变量名也是严格区分大小写的;
     
    比如select * from mysql.user;命令中,User,Host均是列名,所以大小写忽略。
     
     
     
    六. 数据表的常用数据类型和常用属性
     
    常用数据类型
     
    常用属性

    七. 用户权限说明表

     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
  • 相关阅读:
    谈谈toLocaleString()
    如何理解NaN?
    Element--->>>最新骨架屏Skeleton使用
    自定义select组件
    微信小程序之配置业务域名踩过的坑
    Vue watch监听 date中的变量 与 数组或者对象的数据变化
    Vue + Element table的@select方法获取当table中的id值都相同时,获取他们索引
    Vue + Element table中的某行触发enter事件后,使该行disabled
    Vue + Element tree树形控件的懒加载使用
    Vue web使用LeapFTP 上传到服务器
  • 原文地址:https://www.cnblogs.com/regit/p/7803639.html
Copyright © 2011-2022 走看看