집 >데이터 베이스 >MySQL 튜토리얼 >MYSQL 명령줄 모드 관리에 대한 질문
이 기사는 주로 MYSQL 명령줄 모드 관리에 대한 문제를 소개합니다. 이제 특정 참조 가치가 있습니다. 필요한 친구가 참조할 수 있습니다.
MySql 데이터베이스는 중소 규모의 백엔드 데이터베이스를 위한 첫 번째 선택입니다. 중소형 웹사이트의 백엔드 데이터베이스에 적합하기 때문에 비상업적 애플리케이션은 무료입니다. 웹사이트 개발자는 가장 비용 효율적이고 효율적인 "Linux+Apache+PHP+MySql" 플랫폼을 구축할 수 있습니다. MySql을 개발에 사용할 때, MySql과 함께 제공되는 문서는 초보자에게 유용한 참고 자료입니다.
현재 일반 사용자를 위한 개발 환경은 대부분 Windows 또는 Linux입니다. 사용자는 http://www.codepub.com/software/index.html에 가서 해당 버전을 다운로드하여 설치하면 됩니다. 이 서비스가 시작되었는지 확인하십시오. 시작되지 않은 경우 net start mysql 명령을 사용하여 시작할 수 있습니다. Linux에서 시작할 때 "/etc/rc.d/init.d/mysqld start" 명령을 사용할 수 있습니다. 초기자에게는 관리자 권한이 있어야 합니다.
새로 설치된 MySql에는 비밀번호가 비어 있는 루트 계정과 익명 계정이 포함되어 있습니다. 이는 보안상 매우 위험합니다. 일부 중요한 애플리케이션의 경우 보안을 최대한 강화해야 하며, 여기서는 익명 계정을 삭제해야 합니다. 계정의 비밀번호를 설정하려면 다음 명령을 사용하면 됩니다.
use mysql; delete from User where User=""; update User set Password=PASSWORD('newpassword') where User='root';
사용자가 사용하는 로그인 터미널을 제한하려면 위의 내용을 작성한 후 User 테이블에서 해당 사용자의 Host 필드를 업데이트하면 됩니다. 변경 사항이 있는 경우 데이터베이스 서비스를 다시 시작하고 로그인해야 합니다. 다음과 유사한 명령을 사용할 수 있습니다.
mysql -uroot -p; mysql -uroot -pnewpassword; mysql mydb -uroot -p; mysql mydb -uroot -pnewpassword;
위 명령 매개변수는 일반적으로 사용되는 매개변수의 일부입니다. 자세한 내용은 설명서를 참조하세요. 여기서 Mydb는 로그인할 데이터베이스의 이름입니다.
개발 및 실제 적용 중에 사용자는 루트 사용자를 사용하여 데이터베이스에 연결해야 할 뿐만 아니라 테스트에 루트 사용자를 사용하는 것이 편리하지만 시스템에 심각한 보안 위험을 가져오고 개선에 도움이 되지 않습니다. 관리 기술. 우리는 애플리케이션에서 사용되는 사용자에게 가장 적절한 데이터베이스 권한을 부여합니다. 예를 들어, 데이터 삽입만 하는 사용자에게는 데이터 삭제 권한을 부여해서는 안 됩니다. MySql 사용자 관리는 User 테이블을 통해 구현됩니다. 하나는 User 테이블에 해당 데이터 행을 삽입하고 해당 권한을 설정하는 것입니다. GRANT 명령. GRANT의 일반적인 사용법은 다음과 같습니다.
"password"로 식별되는 NewUserName@HostName에 mydb.*의 모든 권한을 부여합니다.
"password"로 식별되는 NewUserName@HostName에 대한 사용 권한을 부여합니다. mydb .*에서 "password"로 식별된 NewUserName@HostName에
업데이트 부여, mydb.TestTable에서 "password"로 식별된 NewUserName@HostName 삭제
이 사용자에게 해당 권한을 관리할 수 있는 권한을 부여하려는 경우; 객체의 경우 GRANT 뒤에 WITH GRANT OPTION 옵션을 추가할 수 있습니다. User 테이블에 Insert하여 추가된 사용자의 경우, 부주의한 사람이 비밀번호를 엿볼 수 없도록 비밀번호 필드를 업데이트하고 PASSWORD 기능을 사용하여 암호화해야 합니다. 더 이상 사용하지 않는 사용자는 삭제되어야 하며, 권한이 한도를 초과한 사용자는 사용자 테이블의 해당 필드를 업데이트하거나 REVOKE 작업을 사용하여 즉시 회수되어야 합니다.
다음은 제가 다른 정보(www.cn-java.com)에서 얻은 공통 권한에 대한 설명입니다.
글로벌 관리 권한:
FILE: MySQL 서버에서 파일을 읽고 씁니다.
PROCESS: 다른 사용자에게 속한 서비스 스레드를 표시하거나 종료합니다.
RELOAD: 액세스 제어 목록 다시 로드, 로그 새로 고침 등
SHUTDOWN: MySQL 서비스를 종료합니다.
데이터베이스/데이터 테이블/데이터 열 권한:
변경: 기존 데이터 테이블(예: 열 추가/삭제) 및 인덱스를 수정합니다.
만들기: 새 데이터베이스 또는 데이터 테이블을 만듭니다.
삭제: 테이블의 기록을 삭제합니다.
삭제: 데이터 테이블이나 데이터베이스를 삭제합니다.
INDEX: 색인을 생성하거나 삭제합니다.
삽입: 테이블에 레코드를 추가합니다.
선택: 테이블의 기록을 표시/검색합니다.
업데이트: 테이블의 기존 기록을 수정합니다.
특별 권한:
ALL: 무엇이든 할 수 있습니다(루트와 동일).
사용법: 로그인만 허용되며 다른 것은 허용되지 않습니다.
마지막으로 RedHat9.0에서 MySql 작업 시연을 보여드리겠습니다.
로그인하려면 데이터베이스의 루트 사용자를 선택하세요.
[weiwen@weiwenlinux]$mysql -uroot -p Enter password:MyPassword mysql>create database mydb; Query OK, 1 row affected (0.02 sec) mysql>use mydb; Database changed mysql>create table TestTable(Id int aut_increment primary key, UserName varchar(16) not null, Address varchar(255)); Query OK, 0 rows affected (0.02 sec) mysql>grant all on mydb.* to test@localhost identified by "test"; Query OK, 0 rows affected (0.01 sec) mysql>quit Bye [weiwen@weiwenlinux]$mysql mydb -utest -ptest
其中test.sql是用vi编辑好的SQL脚本,其内容为:
Insert into TestTable(UserName,Address)values('Tom','shanghai');
Insert into TestTable(UserName,Address)values('John','beijing');
select * from TestTable;
运行已经编辑好的SQL脚本可以用source filename 或 .\ filename。
以上只是对新手的简单练习,要成为一个数据库好手,当以孜孜不倦地追求知识,不断地思考、尝试、再思考。
。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。
MySql常用命令总结
这两天搞个网站,又用到MySql,可是命令却一个都想不起来,所以,趁这次机会,把这些整理一下,权当作笔记吧,以便自己以后查阅!
1:使用SHOW语句找出在服务器上当前存在什么数据库:
mysql> SHOW DATABASES;
2:2、创建一个数据库MYSQLDATA
mysql> Create DATABASE MYSQLDATA;
3:选择你所创建的数据库
mysql> USE MYSQLDATA; (按回车键出现Database changed 时说明操作成功!)
4:查看现在的数据库中存在什么表
mysql> SHOW TABLES;
5:创建一个数据库表
mysql> Create TABLE MYTABLE (name VARCHAR(20), sex CHAR(1));
6:显示表的结构:
mysql> DESCRIBE MYTABLE;
7:往表中加入记录
mysql> insert into MYTABLE values ("hyq","M");
8:用文本方式将数据装入数据库表中(例如D:/mysql.txt)
mysql> LOAD DATA LOCAL INFILE "D:/mysql.txt" INTO TABLE MYTABLE;
9:导入.sql文件命令(例如D:/mysql.sql)
mysql>use database; mysql>source d:/mysql.sql;
10:删除表
mysql>drop TABLE MYTABLE;
11:清空表
mysql>delete from MYTABLE;
12:更新表中数据
mysql>update MYTABLE set sex="f" where name='hyq';
以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!
相关推荐:
위 내용은 MYSQL 명령줄 모드 관리에 대한 질문의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!