MYSQL常用命令1.导出整个数据库mysqldump-u用户名-p--default-character-set=latin1数据库名导出的文件名(数据库默认编码是latin1)mysqldump-uwcnc-psmgp_apps_wcncwcnc.sql2.导出一个表mysqldump-u用户名-p数据库名表名导出的文件名mysqldump-uwcnc-psmgp_apps_wcncuserswcnc_users.sql3.导出一个数据库结构mysqldump-uwcnc-p-d–add-drop-tablesmgp_apps_wcncd:wcnc_db.sql-d没有数据–add-drop-table在每个create语句之前增加一个droptable4.导入数据库A:常用source命令进入mysql数据库控制台,如mysql-uroot-pmysqluse数据库然后使用source命令,后面参数为脚本文件(如这里用到的.sql)mysqlsourcewcnc_db.sqlB:使用mysqldump命令mysqldump-uusername-pdbnamefilename.sqlC:使用mysql命令mysql-uusername-p-Ddbnamefilename.sql一、启动与退出1、进入MySQL:启动MySQLCommandLineClient(MySQL的DOS界面),直接输入安装时的密码即可。此时的提示符是:mysql2、退出MySQL:quit或exit二、库操作1、、创建数据库命令:createdatabase数据库名例如:建立一个名为xhkdb的数据库mysqlcreatedatabasexhkdb;2、显示所有的数据库命令:showdatabases(注意:最后有个s)mysqlshowdatabases;3、删除数据库命令:dropdatabase数据库名例如:删除名为xhkdb的数据库mysqldropdatabasexhkdb;4、连接数据库命令:use数据库名例如:如果xhkdb数据库存在,尝试存取它:mysqlusexhkdb;屏幕提示:Databasechanged5、查看当前使用的数据库mysqlselectdatabase();6、当前数据库包含的表信息:mysqlshowtables;(注意:最后有个s)三、表操作,操作之前应连接某个数据库1、建表命令:createtable表名(字段名1类型1[,..字段名n类型n]);mysqlcreatetableMyClass(idint(4)notnullprimarykeyauto_increment,namechar(20)notnull,sexint(4)notnulldefault'0',degreedouble(16,2));2、获取表结构命令:desc表名,或者showcolumnsfrom表名mysqlDESCRIBEMyClassmysqldescMyClass;mysqlshowcolumnsfromMyClass;3、删除表命令:droptable表名例如:删除表名为MyClass的表mysqldroptableMyClass;4、插入数据命令:insertinto表名[(字段名1[,..字段名n])]values(值1)[,(值n)]例如,往表MyClass中插入二条记录,这二条记录表示:编号为1的名为Tom的成绩为96.45,编号为2的名为Joan的成绩为82.99,编号为3的名为Wang的成绩为96.5.mysqlinsertintoMyClassvalues(1,'Tom',96.45),(2,'Joan',82.99),(2,'Wang',96.59);5、查询表中的数据1)、查询所有行命令:select字段1,字段2,...from表名where表达式例如:查看表MyClass中所有数据mysqlselect*fromMyClass;2)、查询前几行数据例如:查看表MyClass中前2行数据mysqlselect*fromMyClassorderbyidlimit0,2;或者:mysqlselect*fromMyClasslimit0,2;6、删除表中数据命令:deletefrom表名where表达式例如:删除表MyClass中编号为1的记录mysqldeletefromMyClasswhereid=1;7、修改表中数据:update表名set字段=新值,…where条件mysqlupdateMyClasssetname='Mary'whereid=1;7、在表中增加字段:命令:altertable表名add字段类型其他;例如:在表MyClass中添加了一个字段passtest,类型为int(4),默认值为0mysqlaltertableMyClassaddpasstestint(4)default'0'8、更改表名:命令:renametable原表名to新表名;例如:在表MyClass名字更改为YouClassmysqlrenametableMyClasstoYouClass;更新字段内容update表名set字段名=新内容update表名set字段名=replace(字段名,'旧内容','新内容');文章前面加入4个空格updatearticlesetcontent=concat('',content);字段类型1.INT[(M)]型:正常大小整数类型2.DOUBLE[(M,D)][ZEROFILL]型:正常大小(双精密)浮点数字类型3.DATE日期类型:支持的范围是1000-01-01到9999-12-31。MySQL以YYYY-MM-DD格式来显示DATE值,但是允许你使用字符串或数字把值赋给DATE列4.CHAR(M)型:定长字符串类型,当存储时,总是是用空格填满右边到指定的长度5.BLOBTEXT类型,最大长度为65535(2^16-1)个字符。6.VARCHAR型:变长字符串类型5.导入数据库表(1)创建.sql文件(2)先产生一个库如auction.c:mysqlbinmysqladmin-uroot-pcreatauction,会提示输入密码,然后成功创建。(2)导入auction.sql文件c:mysqlbinmysql-uroot-pauctionauction.sql。通过以上操作,就可以创建了一个数据库auction以及其中的一个表auction。6.修改数据库(1)在mysql的表中增加字段:altertabledbnameaddcolumnuseridint(11)notnullprimarykeyauto_increment;这样,就在表dbname中添加了一个字段userid,类型为int(11)。7.mysql数据库的授权mysqlgrantselect,insert,delete,create,dropon*.*(或test.*/user.*/..)to用户名@localhostidentifiedby'密码';如:新建一个用户帐号以便可以访问数据库,需要进行如下操作:mysqlgrantusage-ONtest.*-TOtestuser@localhost;QueryOK,0rowsaffected(0.15sec)此后就创建了一个新用户叫:testuser,这个用户只能从localhost连接到数据库并可以连接到test数据库。下一步,我们必须指定testuser这个用户可以执行哪些操作:mysqlGRANTselect,insert,delete,update-ONtest.*-TOtestuser@localhost;QueryOK,0rowsaffected(0.00sec)此操作使testuser能够在每一个test数据库中的表执行SELECT,INSERT和DELETE以及UPDATE查询操作。现在我们结束操作并退出MySQL客户程序:mysqlexitBye9!1:使用SHOW语句找出在服务器上当前存在什么数据库:mysqlSHOWDATABASES;2:2、创建一个数据库MYSQLDATAmysqlCreateDATABASEMYSQLDATA;3:选择你所创建的数据库mysqlUSEMYSQLDATA;(按回车键出现Databasechanged时说明操作成功!)4:查看现在的数据库中存在什么表mysqlSHOWTABLES;5:创建一个数据库表mysqlCreateTABLEMYTABLE(nameVARCHAR(20),sexCHAR(1));6:显示表的结构:mysqlDESCRIBEMYTABLE;7:往表中加入记录mysqlinsertintoMYTABLEvalues(hyq,M);8:用文本方式将数据装入数据库表中(例如D:/mysql.txt)mysqlLOADDATALOCALINFILED:/mysql.txtINTOTABLEMYTABLE;9:导入.sql文件命令(例如D:/mysql.sql)mysqlusedatabase;mysqlsourced:/mysql.sql;10:删除表mysqldropTABLEMYTABLE;11:清空表mysqldeletefromMYTABLE;12:更新表中数据mysqlupdateMYTABLEsetsex=fwherename='hyq';以下是无意中在网络看到的使用MySql的管理心得,摘自:在windows中MySql以服务形式存在,在使用前应确保此服务已经启动,未启动可用netstartmysql命令启动。而Linux中启动时可用“/etc/rc.d/init.d/mysqldstart命令,注意启动者应具有管理员权限。刚安装好的MySql包含一个含空密码的root帐户和一个匿名帐户,这是很大的安全隐患,对于一些重要的应用我们应将安全性尽可能提高,在这里应把匿名帐户删除、root帐户设置密码,可用如下命令进行:usemysql;deletefromUserwhereUser=;updateUsersetPassword=PASSWORD('newpassword')whereUser='root';如果要对用户所用的登录终端进行限制,可以更新User表中相应用户的Host字段,在进行了以上更改后应重新启动数据库服务,此时登录时可用如下类似命令:mysql-uroot-p;mysql-uroot-pnewpassword;mysqlmydb-uroot-p;mysqlmydb-uroot-pnewpassword;上面命令参数是常用参数的一部分,详细情况可参考文档。此处的mydb是要登录的数据库的名称。在进行开发和实际应用中,用户不应该只用root用户进行连接数据库,虽然使用root用户进行测试时很方便,但会给系统带来重大安全隐患,也不利于管理技术的提高。我们给一个应用中使用的用户赋予最恰当的数据库权限。如一个只进行数据插入的用户不应赋予其删除数据的权限。MySql的用户管理是通过User表来实现的,添加新用户常用的方法有两个,一是在User表插入相应的数据行,同时设置相应的权限;二是通过GRANT命令创建具有某种权限的用户。其中GRANT的常用用法如下:grantallonmydb.*toNewUserName@HostNameidentifiedbypassword;grantusageon*.*toNewUserName@HostNameidentifiedbypassword;grantselect,insert,updateonmy