一起为生活努力加油.

发布新日志

  • Mysql的远程登录

    2009-02-27 20:36:08

     

     Mysql默认是不允许远程连接的,因为有很大的安全隐患。

      需要手动增加可以远程访问数据库的用户。

      方法一、本地登入mysql,更改 "mysql" 数据库里的 "user" 表里的 "host" 项,将"localhost"改为"%"


    #mysql -u root -proot
    mysql>use mysql;
    mysql>update user set host = '%' where user = 'root';
    mysql>select host, user from user;

      方法二、直接授权(推荐)

      从任何主机上使用root用户,密码:youpassword(你的root密码)连接到mysql服务器:

    # mysql -u root -proot
    mysql>GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'youpassword' WITH GRANT OPTION;

      允许地址202.11.10.253上用root用户,密码dboomysql来连接mysql的所有数据库,付给select,insert,update,delete权限。

    # mysql -u root -proot
    grant select,insert,update,delete on *.* to root@"202.11.10.253" Identified by "dboomysql";

      允许地址202.11.10.253上用root用户,密码dboomysql来连接mysql的所有数据库,付给所有权限。

    # mysql -u root -proot
    grant all on *.* to root@"202.11.10.253" Identified by "dboomysql"

      重启Mysql服务后,这样就可用图形化数据库管理软件(Navicat MySQL是个不错的选择)远程访问Mysql

     

    mysql技巧总结


    1.修改mysql中root的密码:
    shell>mysql -u root -p
    mysql>SET PASSWORD FOR root=PASSWORD("root");

    2.远程登录mysql server:(当然server必须首先给某个远程用户授权了)
    shell>mysql -h host -u user -p

    3.打开数据库:use dbname;
    显示所有数据库:show databases;
    显示数据库mysql中所有的表:先use mysql;然后show tables;
    显示表的列信息:describe user;(显示表mysql数据库中user表的信息);

    4.创建一个可以从任何地方连接服务器的一个完全的超级用户,但是必须使用一个口令something做这个
    GRANT ALL PRIVILEGES ON *.* TO monty@localhost IDENTIFIED BY 'something' WITH GRANT OPTION;
    GRANT ALL PRIVILEGES ON *.* TO monty@"%" IDENTIFIED BY 'something' WITH GRANT OPTION;

    5.删除授权:
    REVOKE ALL PRIVILEGES ON *.* FROM root@"%";
    USE mysql;
    DELETE FROM user WHERE User="root" and Host="%";
    FLUSH PRIVILEGES;

    6. 创建一个用户custom在特定客户端weiqiong.com登录,可访问特定数据库bankaccount
    mysql> GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP ON bankaccount.*
    TO custom@weiqiong.com IDENTIFIED BY 'stupid';

    7.重命名表:
    ALTER TABLE t1 RENAME t2;

    为了改变列a,从INTEGER改为TINYINT NOT NULL(名字一样),
    并且改变列b,从CHAR(10)改为CHAR(20),同时重命名它,从b改为c:
    ALTER TABLE t2 MODIFY a TINYINT NOT NULL, CHANGE b c CHAR(20);

    增加一个新TIMESTAMP列,名为d:
    ALTER TABLE t2 ADD d TIMESTAMP;

    在列d上增加一个索引,并且使列a为主键:
    ALTER TABLE t2 ADD INDEX (d), ADD PRIMARY KEY (a);

    删除列c:
    ALTER TABLE t2 DROP COLUMN c;

    增加一个新的AUTO_INCREMENT整数列,命名为c:
    ALTER TABLE t2 ADD c INT UNSIGNED NOT NULL AUTO_INCREMENT,ADD INDEX (c);
    注意,我们索引了c,因为AUTO_INCREMENT柱必须被索引,并且另外我们声明c为NOT NULL,
    因为索引了的列不能是NULL。

    8.删除记录:
    DELETE FROM t1 WHERE C>10;

    6.改变某几行:
    UPDATE t1 SET user=weiqiong,password=weiqiong;

    7.使用name列的头10个字符创建一个索引:
    CREATE INDEX part_of_name ON customer (name(10));

    呵呵,遇到问题时查找的一些资料,摘录下来,希望可以给大家带来点小小帮助

数据统计

  • 访问量: 3315
  • 日志数: 3
  • 建立时间: 2008-11-16
  • 更新时间: 2009-02-27

RSS订阅

Open Toolbar