java mysql数据已存在 mysql表已存在_java mysql数据已存在


1、MySQL常用命令

create database name; 创建数据库

use databasename; 选择数据库

drop database name 直接删除数据库,不提醒

show tables; 显示表

describe tablename; 表的详细描述

select 中加上distinct去除重复字段

mysqladmin drop databasename 删除数据库前,有提示。

显示当前mysql版本和当前日期

select version(),current_date;

2、修改mysql中root的密码:

shell>mysql -u root -p

mysql> update user set password=password(”xueok654123″) where user=’root’;

mysql> flush privileges //刷新数据库

mysql>use dbname; 打开数据库:

mysql>show databases; 显示所有数据库

mysql>show tables; 显示数据库mysql中所有的表:先use mysql;然后

mysql>describe user; 显示表mysql数据库中user表的列信息);

3、grant

创建一个可以从任何地方连接服务器的一个完全的超级用户,但是必须使用一个口令something做这个

mysql> grant all privileges on *.* to user@localhost identified by ’something’ with

增加新用户

格式:grant select on 数据库.* to 用户名@登录主机 identified by “密码”

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;

删除授权:

mysql> revoke all privileges on *.* from root@”%”;

mysql> delete from user where user=”root” and host=”%”;

mysql> flush privileges;

创建一个用户custom在特定客户端http://it363.com登录,可访问特定数据库fangchandb

mysql >grant select, insert, update, delete, create,drop on fangchandb.* to custom@ http://it363.com identified by ‘ passwd’

重命名表:

mysql > alter table t1 rename t2;

4、mysqldump

备份数据库

shell> mysqldump -h host -u root -p dbname >dbname_backup.sql

恢复数据库

shell> mysqladmin -h myhost -u root -p create dbname

shell> mysqldump -h host -u root -p dbname < dbname_backup.sql

如果只想卸出建表指令,则命令如下:

shell> mysqladmin -u root -p -d databasename > a.sql

如果只想卸出插入数据的sql命令,而不需要建表命令,则命令如下:

shell> mysqladmin -u root -p -t databasename > a.sql

那么如果我只想要数据,而不想要什么sql命令时,应该如何操作呢?

   mysqldump -T./ phptest driver

其中,只有指定了-T参数才可以卸出纯文本文件,表示卸出数据的目录,./表示当前目录,即与mysqldump同一目录。如果不指定driver 表,则将卸出整个数据库的数据。每个表会生成两个文件,一个为.sql文件,包含建表执行。另一个为.txt文件,只包含数据,且没有sql指令。

5、可将查询存储在一个文件中并告诉mysql从文件中读取查询而不是等待键盘输入。可利用外壳程序键入重定向实用程序来完成这项工作。

例如,如果在文件my_file.sql 中存放有查

询,可如下执行这些查询:

例如,如果您想将建表语句提前写在sql.txt中:

mysql > mysql -h myhost -u root -p database < sql.txt

一 . 安装与配置MYSQL   二 . 常用mysql命令行命令
  1 .mysql的启动与停止
  启动MYSQL服务 net start mysql
  停止MYSQL服务 net stop mysql

  2 . netstat –na | findstr 3306 查看被监听的端口 , findstr用于查找后面的端口是否存在

  3 . 在命令行中登陆MYSQL控制台 , 即使用 MYSQL COMMEND LINE TOOL
   语法格式 mysql –user=root –password=123456 db_name
   或 mysql –u root –p123456 db_name

  4 . 进入MYSQL命令行工具后 , 使用status; 或/s 查看运行环境信息

  5 . 切换连接数据库的语法 : use new_dbname;
  6 . 显示所有数据库 : show databases;
  7 . 显示数据库中的所有表 : show tables;
  8 . 显示某个表创建时的全部信息 : show create table table_name;
  9 . 查看表的具体属性信息及表中各字段的描述
   Describe table_name; 缩写形式 : desc table_name;

 三 。 MySql中的SQL语句
  1 . 数据库创建 : Create database db_name;
  数据库删除 : Drop database db_name; 删除时可先判断是否存在,写成 : drop database if exits db_name
  2 . 建表 : 创建数据表的语法 : create table table_name (字段1 数据类型 , 字段2 数据类型);
   例 : create table mytable (id int , username char(20));
   删表 : drop table table_name; 例 : drop table mytable;
  8 . 添加数据 : Insert into 表名 [(字段1 , 字段2 , ….)] values (值1 , 值2 , …..);
  如果向表中的每个字段都插入一个值,那么前面 [ ] 括号内字段名可写也可不写
   例 : insert into mytable (id,username) values (1,’zhangsan’);
  9 . 查询 : 查询所有数据 : select * from table_name;
  查询指定字段的数据 : select 字段1 , 字段2 from table_name;
  例 : select id,username from mytable where id=1 order by desc;多表查询语句------------参照第17条实例
  10 . 更新指定数据 , 更新某一个字段的数据(注意,不是更新字段的名字)
  Update table_name set 字段名=’新值’ [, 字段2 =’新值’ , …..][where id=id_num] [order by 字段 顺序]
  例 : update mytable set username=’lisi’ where id=1;
  Order语句是查询的顺序 , 如 : order by id desc(或asc) , 顺序有两种 : desc倒序(100—1,即从最新数据往后查询),asc(从1-100),Where和order语句也可用于查询select 与删除delete
  11 . 删除表中的信息 :
   删除整个表中的信息 : delete from table_name;
   删除表中指定条件的语句 : delete from table_name where 条件语句 ; 条件语句如 : id=3;
  12 . 创建数据库用户
  一次可以创建多个数据库用户如:
  CREATE USER username1 identified BY ‘password’ , username2 IDENTIFIED BY ‘password’….
  13 . 用户的权限控制:grant
   库,表级的权限控制 : 将某个库中的某个表的控制权赋予某个用户
   Grant all ON db_name.table_name TO user_name [ indentified by ‘password’ ];
  14 . 表结构的修改
  (1)增加一个字段格式:
  alter table table_name add column (字段名 字段类型); ----此方法带括号
  (2)指定字段插入的位置:
  alter table table_name add column 字段名 字段类型 after 某字段;
  删除一个字段:
  alter table table_name drop字段名;
  (3)修改字段名称/类型
  alter table table_name change 旧字段名 新字段名 新字段的类型;
  (4)改表的名字
  alter table table_name rename to new_table_name;
  (5)一次性清空表中的所有数据
  truncate table table_name; 此方法也会使表中的取号器(ID)从1开始
  15 . 增加主键,外键,约束,索引。。。。(使用方法见17实例)
  ① 约束(主键Primary key、唯一性Unique、非空Not Null)
  ② 自动增张 auto_increment
  ③外键Foreign key-----与reference table_name(col_name列名)配合使用,建表时单独使用
  ④ 删除多个表中有关联的数据----设置foreign key 为set null ---具体设置参考帮助文档
  16 . 查看数据库当前引擎
   SHOW CREATE TABLE table_name;
   修改数据库引擎
   ALTER TABLE table_name ENGINE=MyISAM | InnoDB;

Linux常用命令名称

作用和用法说明

ls

查看目录与文件

#显示当前目录下所有文件的详细信息:ls -la

mkdir

创建目录

#在当前目录下创建test目录:mkdir test

#在/opt/test目录下创建目录img,若无test目录,先创建test目录:mkdir -p/opt/test/img

cat

查看文件内容

#查看desc.txt的内容:cat desc.txt

more

分页查看文件内容

#分页查看desc.txt文件的内容:more desc.txt

tail

查看文件尾部内容

#查看desc.txt的后100行内容:tail -100 desc.txt

cp

拷贝命令

#拷贝desc.txt文件到/mnt目录下:cp desc.txt /mnt/

#拷贝test目录到/mnt目录下:cp -r test /mnt

这里注意拷贝目录时,通过-r指明一下

mv

剪切或者改名

#剪切文件desc.txt到目录/mnt下:mv desc.txt /mnt/

这里注意,这个Linux命令有两种用法,剪切和改名

1、当源文件所在的目录跟目标目录不同时,就是剪切操作;
2、当源文件所在目录跟目标目录相同时,就是改名操作。

rm

删除命令

#删除test目录,-r递归删除,-f强制删除。数据无价,删除有风险,
删前需谨慎,切记!:rm -rf test

find

搜索文件命令

#在opt目录下查找以.txt结尾的文件:find /opt -name '.txt'

ln

创建链接文件

#创建目录/opt/test的符号链接:ln -s /opt/test ./link2test

man

命令帮助

#对你不熟悉的命令提供帮助和解释:man ls就可以查看ls相关的用法

cd+ pwd

路径操作命令

1、改变当前目录

#进入netseek目录:cd netseek

2、查看当前所在目录完整路径:pwd

shutdown

关机或重启命令

#立刻关机:shutdown -h now

#60s后重启:shutdown -r -t 60

netstat

显示网络相关信息

#列出所有端口:netstat -a

du

查看目录使用情况

#查看/opt/test目录的磁盘使用情况:du -h /opt/test

top

显示系统当前进程信息

kill

杀死进程

#杀死进程号为27810的进程,强制终止,系统资源无法回收:kill -s 9 27810

chmod

改变文件或目录的访问权限

#权限范围:u(拥有者)g(群组)o(其他用户),权限代号:r(读权限)w(写权限)x(执行权限)

#给文件拥有者增加test.sh的执行权限:chmod u+x test.sh

#给文件拥有者增加test目录及其下所有文件的执行权限:chmod u+x -R test

tar + vf

压缩和解压缩

#打包test目录为test.tar.gz文件,-z表示用gzip压缩:tar -zcvf test.tar.gz ./test

#解压test.tar.gz文件:tar -zxvf test.tar.gz

vim

文本编辑

#vim三种模式:命令模式、插入模式、编辑模式。使用ESC或i或:来切换模式

#命令模式下,

:q退出 :q!强制退出 :wq保存退出

:set number显示行号

/java 在文档中查找java

yy复制 p粘贴

#编辑desc.txt文件:vim desc.txt

clear命令

清屏,相当与DOS下的cls

date命令

显示当前时间

mount命令

加载一个硬件设备

mount [参数] 要加载的设备 载入点

mount /dev/cdrom

cd /mnt/cdrom //进入光盘目录

su命令

在不退出登陆的情况下,切换到另外一个人的身份

su -l 用户名(如果用户名缺省,则切换到root状态)

su -l netseek (切换到netseek这个用户,将提示输入密码)

whoami,whereis,which,id

//whoami:确认自己身份

//whereis:查询命令所在目录以及帮助文档所在目录

whereis bin 显示bin所在的目录,将显示为:/usr/local/bin

//which:查询该命令所在目录(类似whereis)

//id:打印出自己的UID以及GID。(UID:用户身份唯一标识。GID:用户组身份唯一标识。每一个用户只能有一个唯一的UID和 GID)

grep命令

该命令常用于分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等,它的简单语法为

grep:文本内容搜索;

grep success * /*查找当前目录下面所有文件里面含有success字符的文件

passwd命令

可以设置口令

history命令

可以显示用户过去使用的命令

finger命令

可以让使用者查询一些其他使用者的资料

finger root //查看root的资料

file命令

该命令用于判断接在file命令后的文件的基本数据,因为在Linux下文件的类型并不是以后缀为分的,所以这个命令对我们来说就很有用了,它的用法非常简单,基本语法如下:

file filename

gcc命令

对于一个用Linux开发C程序的人来说,这个命令就非常重要了,它用于把C语言的源程序文件,编译成可执行程序,由于g++的很多参数跟它非常相似,所以这里只介绍gcc的参数,它的常用参数如下:

-o :output之意,用于指定生成一个可执行文件的文件名

-c :用于把源文件生成目标文件(.o),并阻止编译器创建一个完整的程序

-I :增加编译时搜索头文件的路径

-L :增加编译时搜索静态连接库的路径

-S :把源文件生成汇编代码文件

-lm:表示标准库的目录中名为libm.a的函数库

-lpthread :连接NPTL实现的线程库

-std= :用于指定把使用的C语言的版本

# 例如:

# 把源文件test.c按照c99标准编译成可执行程序test

gcc -o test test.c -lm -std=c99

#把源文件test.c转换为相应的汇编程序源文件test.s

gcc -S test.c