• mysql数据库操作


      1 一、连接数据库
      2 格式:mysql -h主机地址 -u用户名 -p用户密码
      3 1.1.连接到本机上的MYSQL。
      4 首先打开DOS窗口,然后进入目录mysqlin,再键入命令mysql -u root -p,回车后提示你输密码.
      5 注意用户名前可以有空格也可以没有空格,但是密码前必须没有空格,否则让你重新输入密码。
      6 如果刚安装好MYSQL,超级用户root是没有密码的,故直接回车即可进入到MYSQL中了,MYSQL的提示符是: mysql>
      7 
      8 1.2连接到远程主机上的MYSQL。
      9 
     10 假设远程主机的IP为:110.110.110.110,用户名为root,密码为abcd123。则键入以下命令:
     11  mysql -h110.110.110.110 -u root -p 123;(注:u与root之间可以不用加空格,其它也一样)
     12 1.3退出MYSQL命令: exit (回车)
     13 
     14 二、增加用户
     15 格式:grant select on 数据库.* to 用户名@登录主机 identified by “密码”
     16 2.1 增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。
     17 
     18 首先用root用户连入MYSQL,然后键入以下命令:
     19 
     20 复制代码 代码如下:
     21 grant select,insert,update,delete on *.* to [email=test1@”%]test1@”%[/email]” Identified by “abc”;
     22 但增加的用户是十分危险的,你想如某个人知道test1的密码,那么他就可以在internet上的任何一台电脑上登录你的mysql数据库并对你的数据可以为所欲为了,解决办法见2.2 23 2.2增加一个用户test2密码为abc,让他只可以在localhost上登录,并可以对数据库mydb进行查询、插入、修改、删除的操作(localhost指本地主机,即MYSQL数据库所在的那台主机),这样用户即使用知道test2的密码,他也无法从internet上直接访问数据库,只能通过MYSQL主机上的web页来访问。
     24 
     25 复制代码 代码如下:
     26 grant select,insert,update,delete on mydb.* to [email=test2@localhost]test2@localhost[/email] identified by “abc”;
     27 
     28 如果你不想test2有密码,可以再打一个命令将密码消掉。
     29 复制代码 代码如下:
     30 grant select,insert,update,delete on mydb.* to [email=test2@localhost]test2@localhost[/email] identified by “”
     31 三、操作数据库
     32 
     33 3.1创建数据库
     34 注意:创建数据库之前要先连接Mysql服务器
     35 命令:create database <数据库名>
     36 例1:建立一个名为xhkdb的数据库
     37   
     38 
     39 复制代码 代码如下:
     40 mysql> create database xhkdb;
     41 例2:创建数据库并分配用户
     42 ①CREATE DATABASE 数据库名;
     43 ②GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP,ALTER ON 数据库名.* TO 用户名@localhost IDENTIFIED BY '密码';
     44 ③SET PASSWORD FOR '数据库名'@'localhost' = OLD_PASSWORD('密码');
     45 依次执行3个命令完成数据库创建。
     46 注意:中文 “密码”和“数据库”是户自己需要设置的。
     47 
     48 3.2显示数据库
     49 命令:show databases (注意:最后有个s)
     50 
     51 复制代码 代码如下:
     52 mysql> show databases
     53 
     54 3.3 删除数据库
     55 命令:drop database <数据库名>
     56 例如:删除名为 xhkdb的数据库
     57 复制代码 代码如下:
     58 mysql> drop database xhkdb;
     59 例子1:删除一个已经确定存在的数据库
     60 
     61 复制代码 代码如下:
     62 mysql> drop database drop_database;
     63 Query OK, 0 rows affected (0.00 sec)
     64 例子2:删除一个不确定存在的数据库
     65 
     66 ?
     67 1
     68 2
     69 3
     70 4
     71 5
     72 6
     73 7
     74 8
     75 9
     76 mysql> drop database drop_database;
     77 ERROR 1008 (HY000): Can't drop database 'drop_database'; database doesn't exist
     78 //发生错误,不能删除'drop_database'数据库,该数据库不存在。
     79 mysql> drop database if exists drop_database;
     80 Query OK, 0 rows affected, 1 warning (0.00 sec)//产生一个警告说明此数据库不存在
     81 mysql> create database drop_database;
     82 Query OK, 1 row affected (0.00 sec)
     83 mysql> drop database if exists drop_database;//if exists 判断数据库是否存在,不存在也不产生错误
     84 Query OK, 0 rows affected (0.00 sec)
     85 3.4 连接数据库
     86 命令: use <数据库名>
     87 例如:如果xhkdb数据库存在,尝试存取它:mysql> use xhkdb;
     88 屏幕提示:Database changed
     89 use 语句可以通告MySQL把db_name数据库作为默认(当前)数据库使用,用于后续语句。该数据库保持为默认数据库,直到语段的结尾,或者直到发布一个不同的USE语句:
     90 
     91 ?
     92 1
     93 2
     94 3
     95 4
     96 mysql> USE db1;
     97 mysql> SELECT COUNT(*) FROM mytable; # selects from db1.mytable
     98 mysql> USE db2;
     99 mysql> SELECT COUNT(*) FROM mytable; # selects from db2.mytable
    100 使用USE语句为一个特定的当前的数据库做标记,不会阻碍您访问其它数据库中的表。下面的例子可以从db1数据库访问作者表,并从db2数据库访问编辑表:
    101 
    102 ?
    103 1
    104 2
    105 3
    106 mysql> USE db1;
    107 mysql> SELECT author_name,editor_name FROM author,db2.editor
    108  ->  WHERE author.editor_id = db2.editor.editor_id;
    109 要退出数据库或连接其他数据库直接 user '其他数据库名称'就可以了。
    110 
    111 3.5当前选择数据库
    112 命令:mysql> select database();
    113 MySQL中SELECT命令类似于其他编程语言里的print或者write,你可以用它来显示一个字符串、数字、数学表达式的结果等等。如何使用MySQL中SELECT命令的特殊功能?
    114 
    115 (1).显示MYSQL的版本
    116 
    117 ?
    118 1
    119 2
    120 3
    121 4
    122 5
    123 6
    124 7
    125 mysql> select version();
    126 +-----------------------+
    127 | version()    |
    128 +-----------------------+
    129 | 6.0.4-alpha-community |
    130 +-----------------------+
    131 1 row in set (0.02 sec)
    132 (2). 显示当前时间
    133 
    134 ?
    135 1
    136 2
    137 3
    138 4
    139 5
    140 6
    141 7
    142 mysql> select now();
    143 +---------------------+
    144 | now()    |
    145 +---------------------+
    146 | 2009-09-15 22:35:32 |
    147 +---------------------+
    148 1 row in set (0.04 sec)
    149 (3). 显示年月日
    150 
    151 ?
    152 1
    153 2
    154 3
    155 4
    156 5
    157 6
    158 7
    159 8
    160 9
    161 10
    162 11
    163 12
    164 13
    165 14
    166 15
    167 16
    168 17
    169 18
    170 19
    171 20
    172 21
    173 22
    174 23
    175 SELECT DAYOFMONTH(CURRENT_DATE);
    176 +--------------------------+
    177 | DAYOFMONTH(CURRENT_DATE) |
    178 +--------------------------+
    179 |      15 |
    180 +--------------------------+
    181 1 row in set (0.01 sec)
    182   
    183 SELECT MONTH(CURRENT_DATE);
    184 +---------------------+
    185 | MONTH(CURRENT_DATE) |
    186 +---------------------+
    187 |     9 |
    188 +---------------------+
    189 1 row in set (0.00 sec)
    190   
    191 SELECT YEAR(CURRENT_DATE);
    192 +--------------------+
    193 | YEAR(CURRENT_DATE) |
    194 +--------------------+
    195 |    2009 |
    196 +--------------------+
    197 1 row in set (0.00 sec)
    198 (4).显示字符串
    199 
    200 ?
    201 1
    202 2
    203 3
    204 4
    205 5
    206 6
    207 7
    208 mysql> SELECT "welecome to my blog!";
    209 +----------------------+
    210 | welecome to my blog! |
    211 +----------------------+
    212 | welecome to my blog! |
    213 +----------------------+
    214 1 row in set (0.00 sec)
    215 (5).当计算器用
    216 
    217 ?
    218 1
    219 2
    220 3
    221 4
    222 5
    223 6
    224 7
    225 select ((4 * 4) / 10 ) + 25;
    226 +----------------------+
    227 | ((4 * 4) / 10 ) + 25 |
    228 +----------------------+
    229 |    26.60 |
    230 +----------------------+
    231 1 row in set (0.00 sec)
    232 (6).串接字符串
    233 
    234 ?
    235 1
    236 2
    237 3
    238 4
    239 5
    240 6
    241 7
    242 8
    243 9
    244 10
    245 11
    246 12
    247 select CONCAT(f_name, " ", l_name)
    248 AS Name
    249 from employee_data
    250 where title = 'Marketing Executive';
    251 +---------------+
    252 | Name   |
    253 +---------------+
    254 | Monica Sehgal |
    255 | Hal Simlai |
    256 | Joseph Irvine |
    257 +---------------+
    258 3 rows in set (0.00 sec)
    259 注意:这里用到CONCAT()函数,用来把字符串串接起来。另外,我们还用到以前学到的AS给结果列'CONCAT(f_name, " ", l_name)'起了个假名
    260 
    261 四、对表的操作
    262 4.1创建表
    263 命令:create table <表名> ( <字段名1> <类型1> [,..<字段名n> <类型n>]);
    264 例如,建立一个名为MyClass的表
    265 
    266 ?
    267 1
    268 2
    269 3
    270 4
    271 5
    272 mysql> create table MyClass(
    273 > id int(4) not null primary key auto_increment,
    274 > name char(20) not null,
    275 > sex int(4) not null default '0',
    276 > degree double(16,2));
    277 4.2获取表结构
    278 命令: desc 表名,或者show columns from 表名
    279 
    280 ?
    281 1
    282 2
    283 mysql> desc MyClass;
    284 mysql> show columns from MyClass;
    285 使用MySQL数据库desc 表名时,我们看到Key那一栏,可能会有4种值,即' ''PRI''UNI''MUL'286 (1).如果Key是空的, 那么该列值的可以重复, 表示该列没有索引, 或者是一个非唯一的复合索引的非前导列;
    287 (2).如果Key是PRI,  那么该列是主键的组成部分;
    288 (3).如果Key是UNI,  那么该列是一个唯一值索引的第一列(前导列),并别不能含有空值(NULL);
    289 (4).如果Key是MUL,  那么该列的值可以重复, 该列是一个非唯一索引的前导列(第一列)或者是一个唯一性索引的组成部分但是可以含有空值NULL。
    290 如果对于一个列的定义,同时满足上述4种情况的多种,比如一个列既是PRI,又是UNI,那么"desc 表名"的时候,显示的Key值按照优先级来显,PRI->UNI->MUL。那么此时,显示PRI。
    291 一个唯一性索引列可以显示为PRI,并且该列不能含有空值,同时该表没有主键。
    292 一个唯一性索引列可以显示为MUL, 如果多列构成了一个唯一性复合索引,因为虽然索引的多列组合是唯一的,比如ID+NAME是唯一的,但是没一个单独的列依然可以有重复的值,只要ID+NAME是唯一的即可。
    293 
    294 4.3删除表
    295 命令:drop table <表名>
    296 例如:删除表名为 MyClass 的表
    297 
    298 复制代码 代码如下:
    299 mysql> drop table MyClass;
    300 DROP TABLE用于取消一个或多个表。您必须有每个表的DROP权限。所有的表数据和表定义会被取消,所以使用本语句要小心!
    301 注意:对于一个带分区的表,DROP TABLE会永久性地取消表定义,取消各分区,并取消储存在这些分区中的所有数据。DROP TABLE还会取消与被取消
    302 
    303 的表有关联的分区定义(.par)文件。
    304 对与不存在的表,使用IF EXISTS用于防止错误发生。当使用IF EXISTS时,对于每个不存在的表,会生成一个NOTE。
    305 RESTRICT和CASCADE可以使分区更容易。目前,RESTRICT和CASCADE不起作用。
    306 
    307 4.4向表插入数据
    308 命令:insert into <表名> [( <字段名1>[,..<字段名n > ])] values ( 值1 )[, ( 值n )]
    309 例如:往表 MyClass中插入二条记录, 这二条记录表示:编号为1的名为Tom的成绩为96.45, 编号为2 的名为Joan 的成绩为82.99, 编号为3 的名为
    310 
    311 Wang 的成绩为96.5312 mysql> insert into MyClass values(1,'Tom',96.45),(2,'Joan',82.99), (2,'Wang', 96.59);
    313 注意:insert into每次只能向表中插入一条记录。
    314 
    315 4.5查询表
    316 (1)、查询所有行
    317 命令: select <字段1,字段2,...> from < 表名 > where < 表达式 >
    318 例如:查看表 MyClass 中所有数据
    319 mysql> select * from MyClass;
    320 (2)、查询前几行数据
    321 例如:查看表 MyClass 中前2行数据
    322 mysql> select * from MyClass order by id limit 0,2;
    323 select一般配合where使用,以查询更精确更复杂的数据。
    324 
    325 4.6删除表
    326 命令:delete from 表名 where 表达式
    327 例如:删除表 MyClass中编号为1 的记录
    328 mysql> delete from MyClass where id=1;
    329 
    330 4.7修改表中的数据
    331 语法:update 表名 set 字段=新值,… where 条件
    332 mysql> update MyClass set name='Mary' where id=1;
    333 
    334 例子1:单表的MySQL UPDATE语句:
    335 
    336 复制代码 代码如下:
    337  UPDATE [LOW_PRIORITY] [IGNORE] tbl_name SET col_name1=expr1 [, col_name2=expr2 ...] [WHERE where_definition] [ORDER BY ...] [LIMIT row_count]
    338 
    339 例子2:多表的UPDATE语句:
    340 复制代码 代码如下:
    341 UPDATE [LOW_PRIORITY] [IGNORE] table_references SET col_name1=expr1 [, col_name2=expr2 ...] [WHERE where_definition]
    342 
    343 UPDATE语法可以用新值更新原有表行中的各列。SET子句指示要修改哪些列和要给予哪些值。WHERE子句指定应更新哪些行。如果没有WHERE子句,则更新所有的行。如果指定了ORDER BY子句,则按照被指定的顺序对行进行更新。LIMIT子句用于给定一个限值,限制可以被更新的行的数目。
    344 4.8增加表字段
    345 命令:alter table 表名 add字段 类型 其他;
    346 例如:在表MyClass中添加了一个字段passtest,类型为int(4),默认值为0
    347 mysql> alter table MyClass add passtest int(4) default '0'[/code]
    348 加索引:mysql> alter table 表名 add index 索引名 (字段名1[,字段名2 …]);
    349 例子: mysql> alter table employee add index emp_name (name);
    350 加主关键字的索引:mysql> alter table 表名 add primary key (字段名);
    351 例子: mysql> alter table employee add primary key(id);
    352 加唯一限制条件的索引:mysql> alter table 表名 add unique 索引名 (字段名);
    353 例子: mysql> alter table employee add unique emp_name2(cardnumber);
    354 删除某个索引:mysql> alter table 表名 drop index 索引名;
    355 例子: mysql>alter table employee drop index emp_name;
    356 增加字段:mysql> ALTER TABLE table_name ADD field_name field_type;
    357 修改原字段名称及类型:mysql> ALTER TABLE table_name CHANGE old_field_name new_field_name field_type;
    358 修改字段类型:mysql>ALTER TABLE table_name MODIFY colum_name field_type new_type
    359 删除字段:MySQL ALTER TABLE table_name DROP field_name;
    360 
    361 4.9修改表名
    362 命令:rename table 原表名 to 新表名;
    363 例如:在表MyClass名字更改为YouClass
    364 
    365 复制代码 代码如下:
    366 mysql> rename table MyClass to YouClass;
    367 
    368 当你执行 RENAME 时,你不能有任何锁定的表或活动的事务。你同样也必须有对原初表的 ALTER 和 DROP 权限,以及对新表的 CREATE 和 INSERT 权限。
    369 如果在多表更名中,MySQL 遭遇到任何错误,它将对所有被更名的表进行倒退更名,将每件事物退回到最初状态。
    370 RENAME TABLE 在 MySQL 3.23.23 中被加入。
    371 五、备份数据
    372 
    373 命令在DOS的[url=file://\mysql\bin]\mysql\bin[/url]目录下执行
    374 (1).导出整个数据库
    375 导出文件默认是存在mysqlin目录下
    376 mysqldump -u 用户名 -p 数据库名 > 导出的文件名
    377 mysqldump -u user_name -p123456 database_name > outfile_name.sql
    378 (2).导出一个表
    379 mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名
    380 mysqldump -u user_name -p database_name table_name > outfile_name.sql
    381 (3).导出一个数据库结构
    382 mysqldump -u user_name -p -d –add-drop-table database_name > outfile_name.sql
    383 -d 没有数据 –add-drop-table 在每个create语句之前增加一个drop table
    384 (4).带语言参数导出
    385 mysqldump -uroot -p –default-character-set=latin1 –set-charset=gbk –skip-opt database_name > outfile_name.sql
    386 例如,将aaa库备份到文件back_aaa中:
    387 
    388 复制代码 代码如下:
    389 [root@test1 root]# cd /home/data/mysql
    390 [root@test1 mysql]# mysqldump -u root -p --opt aaa > back_aaa
  • 相关阅读:
    《感想都是碎片》
    我容易么我……
    elvish Template Library
    可以直接在C++里面写类似RSL的shader了
    全身和鞘内注射依那西普抑制糖尿病小鼠的触觉异常痛敏
    针对英夫利昔单抗或阿达木单抗的抗体存在与否决定转用依那西普的疗效
    全基因组关联研究发现TNF抑制剂治疗RA与7个位点的多态性有关
    依那西普治疗幼年型特发性关节炎的疗效
    强直性脊柱炎中的髋关节受累:流行病学和髋关节置换术的相关危险因素
    长期使用依那西普对幼年型特发性关节炎患儿生长的影响
  • 原文地址:https://www.cnblogs.com/chengyunshen/p/7196321.html
Copyright © 2020-2023  润新知