access关系数据库的基本 *** 作有:
1、选择 *** 作:
从一个关系中选择若干条记录构成一个新的关系;
2、投影 *** 作:
从一个关系中选择如果属性构成一个新的关系;
3、连接 *** 作:
两个关系根据关联字段合并为一个新的关系。
学习数据库从了解到认识到使用是要很多时间的,需要学习的东西很多。如果为了企业的一些资料,数据便于利用存储,而且不是什么大企业还是什么大项目,用SQL有点专业了。你如果是自己用还是只是了解会一点,那就学个简单点的。
数据库都很复杂,不用的软件就是能实现的功能和他运行的速度有所不同。如果学的不是很深的话,就学office的access。一般是陪在office的办公软件里的。书籍先去看下电子书,下载个PDF可以浏览的软件,然后上网上去下载电子书,有数据库专用书之类的。里面还可以下载比较旧版本不用钱的软件,就如你要的SQL数据库或是Photoshop这些软件都有的。
SQL是Structured Query Language(结构化查询语言)的缩写。SQL是专为数据库而建立的 *** 作命令集,是一种功能齐全的数据库语言。在使用它时,只需要发出“做什么”的命令,“怎么做”是不用使用者考虑的。SQL功能强大、简单易学、使用方便,已经成为了数据库 *** 作的基础,并且现在几乎所有的数据库均支持SQL。
SQL语言的组成:
1一个SQL数据库是表(Table)的集合,它由一个或多个SQL模式定义。
2一个SQL表由行集构成,一行是列的序列(集合),每列与行对应一个数据项。
3一个表或者是一个基本表或者是一个视图。基本表是实际存储在数据库的表,而视图是由若干基本表或其他视图构成的表的定义。
4一个基本表可以跨一个或多个存储文件,一个存储文件也可存放一个或多个基本表。每个存储文件与外部存储上一个物理文件对应。
5用户可以用SQL语句对视图和基本表进行查询等 *** 作。在用户角度来看,视图和基本表是一样的,没有区别,都是关系(表格)。
6SQL用户可以是应用程序,也可以是终端用户。SQL语句可嵌入在宿主语言的程序中使用,宿主语言有FORTRAN,COBOL,PASCAL,PL/I,C和Ada语言等。SQL用户也能作为独立的用户接口,供交互环境下的终端用户使用。
创建一个以JDBC连接数据库的程序,包含7个步骤: \x0d\ 1、加载JDBC驱动程序: \x0d\ 在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机), \x0d\ 这通过javalangClass类的静态方法forName(String className)实现。 \x0d\ 例如: \x0d\ try{ \x0d\ //加载MySql的驱动类 \x0d\ ClassforName("commysqljdbcDriver") ; \x0d\ }catch(ClassNotFoundException e){ \x0d\ Systemoutprintln("找不到驱动程序类 ,加载驱动失败!"); \x0d\ eprintStackTrace() ; \x0d\ } \x0d\ 成功加载后,会将Driver类的实例注册到DriverManager类中。 \x0d\ 2、提供JDBC连接的URL \x0d\ •连接URL定义了连接数据库时的协议、子协议、数据源标识。 \x0d\ •书写形式:协议:子协议:数据源标识 \x0d\ 协议:在JDBC中总是以jdbc开始 \x0d\ 子协议:是桥连接的驱动程序或是数据库管理系统名称。 \x0d\ 数据源标识:标记找到数据库来源的地址与连接端口。 \x0d\ 例如:(MySql的连接URL) \x0d\ jdbc:mysql: \x0d\ //localhost:3306/testuseUnicode=true&characterEncoding=gbk ; \x0d\ useUnicode=true:表示使用Unicode字符集。如果characterEncoding设置为 \x0d\ gb2312或GBK,本参数必须设置为true 。characterEncoding=gbk:字符编码方式。 \x0d\ 3、创建数据库的连接 \x0d\ •要连接数据库,需要向javasqlDriverManager请求并获得Connection对象, \x0d\ 该对象就代表一个数据库的连接。 \x0d\ •使用DriverManager的getConnectin(String url , String username , \x0d\ String password )方法传入指定的欲连接的数据库的路径、数据库的用户名和 \x0d\ 密码来获得。 \x0d\ 例如: \x0d\ //连接MySql数据库,用户名和密码都是root \x0d\ String url = "jdbc:mysql://localhost:3306/test" ; \x0d\ String username = "root" ; \x0d\ String password = "root" ; \x0d\ try{ \x0d\ Connection con = \x0d\ DriverManagergetConnection(url , username , password ) ; \x0d\ }catch(SQLException se){ \x0d\ Systemoutprintln("数据库连接失败!"); \x0d\ seprintStackTrace() ; \x0d\ } \x0d\ 4、创建一个Statement \x0d\ •要执行SQL语句,必须获得javasqlStatement实例,Statement实例分为以下3 \x0d\ 种类型: \x0d\ 1、执行静态SQL语句。通常通过Statement实例实现。 \x0d\ 2、执行动态SQL语句。通常通过PreparedStatement实例实现。 \x0d\ 3、执行数据库存储过程。通常通过CallableStatement实例实现。 \x0d\ 具体的实现方式: \x0d\ Statement stmt = concreateStatement() ; \x0d\ PreparedStatement pstmt = conprepareStatement(sql) ; \x0d\ CallableStatement cstmt = \x0d\ conprepareCall("{CALL demoSp( , )}") ; \x0d\ 5、执行SQL语句 \x0d\ Statement接口提供了三种执行SQL语句的方法:executeQuery 、executeUpdate \x0d\ 和execute \x0d\ 1、ResultSet executeQuery(String sqlString):执行查询数据库的SQL语句 \x0d\ ,返回一个结果集(ResultSet)对象。 \x0d\ 2、int executeUpdate(String sqlString):用于执行INSERT、UPDATE或 \x0d\ DELETE语句以及SQL DDL语句,如:CREATE TABLE和DROP TABLE等 \x0d\ 3、execute(sqlString):用于执行返回多个结果集、多个更新计数或二者组合的 \x0d\ 语句。 \x0d\ 具体实现的代码: \x0d\ ResultSet rs = stmtexecuteQuery("SELECT FROM ") ; \x0d\ int rows = stmtexecuteUpdate("INSERT INTO ") ; \x0d\ boolean flag = stmtexecute(String sql) ; \x0d\ 6、处理结果 \x0d\ 两种情况: \x0d\ 1、执行更新返回的是本次 *** 作影响到的记录数。 \x0d\ 2、执行查询返回的结果是一个ResultSet对象。 \x0d\ • ResultSet包含符合SQL语句中条件的所有行,并且它通过一套get方法提供了对这些 \x0d\ 行中数据的访问。 \x0d\ • 使用结果集(ResultSet)对象的访问方法获取数据: \x0d\ while(rsnext()){ \x0d\ String name = rsgetString("name") ; \x0d\ String pass = rsgetString(1) ; // 此方法比较高效 \x0d\ } \x0d\ (列是从左到右编号的,并且从列1开始) \x0d\ 7、关闭JDBC对象 \x0d\ *** 作完成以后要把所有使用的JDBC对象全都关闭,以释放JDBC资源,关闭顺序和声 \x0d\ 明顺序相反: \x0d\ 1、关闭记录集 \x0d\ 2、关闭声明 \x0d\ 3、关闭连接对象 \x0d\ if(rs != null){ // 关闭记录集 \x0d\ try{ \x0d\ rsclose() ; \x0d\ }catch(SQLException e){ \x0d\ eprintStackTrace() ; \x0d\ } \x0d\ } \x0d\ if(stmt != null){ // 关闭声明 \x0d\ try{ \x0d\ stmtclose() ; \x0d\ }catch(SQLException e){ \x0d\ eprintStackTrace() ; \x0d\ } \x0d\ } \x0d\ if(conn != null){ // 关闭连接对象 \x0d\ try{ \x0d\ connclose() ; \x0d\ }catch(SQLException e){ \x0d\ eprintStackTrace() ; \x0d\ } \x0d\ }
1、新建数据库:
进入phpmyadmin管理界面以后,找到如下文字“创建一个新的数据库”,然后在下面填上要新建的数据库的名称,在后面的下拉列表中选择数据库的编码,如“utf8_general_ci”,点击“创建”按钮,这样就新建了一个数据库。
2、新建此数据库的对应帐户
在phpmyadmin管理界面点击“权限”,打开链接,点击“添加新用户”,在打开的页面中会看到“登入信息”,输入用户名、主机(一般为本地:localhost)、密码后,因为我们现在是要给单个用户配置单个数据库的权限,在这里不选择“全局权限”,然后点击最下面的“执行”按钮,这样就新建了一个用户名。
3、为新建的用户添加此数据库权限
添加完用户以后,管理界面的上方会提示“您已添加了一个新用户”,
现在就给新建的用户添加权限,在下面找到“按数据库指定权限”。
然后点击“在下列数据库添加权限”后面的下拉列表,选择数据库,选择数据下面的全部,然后选择结构除了最下面三个以外的复选框,其他一律不选,然后点击“执行”按钮,这样就配置好了这个用户完全管理这个数据库的权限了。
注:
1、只是要给这个用户管理这个数据库的全部权限,但是没有其他数据库的管理权限,所以在配置权限的时候一定要注意。
2、INFORMATION_SCHEMA是信息数据库,其中保存着关于MySQL服务器所维护的所有其他数据库的信息。假如不想在phpMyAdmin中显示的话只需要设置在configincphp(有的是configdefaultphp)中设置这样一句:$cfg['Servers'][$i]['hide_db']
= ‘information_schema';
此外,如果在创新用户时,选择“用户数据库”中的“给以 用户名_ 开头的数据库 (username\_%)
授予所有权限”选项,新建的用户就可以自己创建以“username_”开头的数据库。
创建一个以JDBC连接数据库的程序,包含7个步骤:
1、加载JDBC驱动程序:
在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机),
这通过javalangClass类的静态方法forName(String className)实现。
例如:
try{
//加载MySql的驱动类
ClassforName("commysqljdbcDriver") ;
}catch(ClassNotFoundException e){
Systemoutprintln("找不到驱动程序类 ,加载驱动失败!");
eprintStackTrace() ;
}
成功加载后,会将Driver类的实例注册到DriverManager类中。
2、提供JDBC连接的URL
•连接URL定义了连接数据库时的协议、子协议、数据源标识。
•书写形式:协议:子协议:数据源标识
协议:在JDBC中总是以jdbc开始
子协议:是桥连接的驱动程序或是数据库管理系统名称。
数据源标识:标记找到数据库来源的地址与连接端口。
例如:(MySql的连接URL)
jdbc:mysql:
//localhost:3306/testuseUnicode=true&characterEncoding=gbk ;
useUnicode=true:表示使用Unicode字符集。如果characterEncoding设置为
gb2312或GBK,本参数必须设置为true 。characterEncoding=gbk:字符编码方式。
3、创建数据库的连接
•要连接数据库,需要向javasqlDriverManager请求并获得Connection对象,
该对象就代表一个数据库的连接。
•使用DriverManager的getConnectin(String url , String username ,
String password )方法传入指定的欲连接的数据库的路径、数据库的用户名和
密码来获得。
例如:
//连接MySql数据库,用户名和密码都是root
String url = "jdbc:mysql://localhost:3306/test" ;
String username = "root" ;
String password = "root" ;
try{
Connection con =
DriverManagergetConnection(url , username , password ) ;
}catch(SQLException se){
Systemoutprintln("数据库连接失败!");
seprintStackTrace() ;
}
4、创建一个Statement
•要执行SQL语句,必须获得javasqlStatement实例,Statement实例分为以下3
种类型:
1、执行静态SQL语句。通常通过Statement实例实现。
2、执行动态SQL语句。通常通过PreparedStatement实例实现。
3、执行数据库存储过程。通常通过CallableStatement实例实现。
具体的实现方式:
Statement stmt = concreateStatement() ;
PreparedStatement pstmt = conprepareStatement(sql) ;
CallableStatement cstmt =
conprepareCall("{CALL demoSp( , )}") ;
5、执行SQL语句
Statement接口提供了三种执行SQL语句的方法:executeQuery 、executeUpdate
和execute
1、ResultSet executeQuery(String sqlString):执行查询数据库的SQL语句
,返回一个结果集(ResultSet)对象。
2、int executeUpdate(String sqlString):用于执行INSERT、UPDATE或
DELETE语句以及SQL DDL语句,如:CREATE TABLE和DROP TABLE等
3、execute(sqlString):用于执行返回多个结果集、多个更新计数或二者组合的
语句。
具体实现的代码:
ResultSet rs = stmtexecuteQuery("SELECT FROM ") ;
int rows = stmtexecuteUpdate("INSERT INTO ") ;
boolean flag = stmtexecute(String sql) ;
6、处理结果
两种情况:
1、执行更新返回的是本次 *** 作影响到的记录数。
2、执行查询返回的结果是一个ResultSet对象。
• ResultSet包含符合SQL语句中条件的所有行,并且它通过一套get方法提供了对这些
行中数据的访问。
• 使用结果集(ResultSet)对象的访问方法获取数据:
while(rsnext()){
String name = rsgetString("name") ;
String pass = rsgetString(1) ; // 此方法比较高效
}
(列是从左到右编号的,并且从列1开始)
7、关闭JDBC对象
*** 作完成以后要把所有使用的JDBC对象全都关闭,以释放JDBC资源,关闭顺序和声
明顺序相反:
1、关闭记录集
2、关闭声明
3、关闭连接对象
if(rs != null){ // 关闭记录集
try{
rsclose() ;
}catch(SQLException e){
eprintStackTrace() ;
}
}
if(stmt != null){ // 关闭声明
try{
stmtclose() ;
}catch(SQLException e){
eprintStackTrace() ;
}
}
if(conn != null){ // 关闭连接对象
try{
connclose() ;
}catch(SQLException e){
eprintStackTrace() ;
}
}
命令行
1、显示当前数据库服务器中的数据库列表:mysql> SHOW DATABASES;
2、建立数据库:mysql> CREATE DATABASE 库名;
3、建立数据表:mysql> USE 库名;mysql> CREATE TABLE 表名 (字段名 VARCHAR(20), 字段名 CHAR(1));
4、删除数据库:mysql> DROP DATABASE 库名;
5、删除数据表:mysql> DROP TABLE 表名;
6、将表中记录清空:mysql> DELETE FROM 表名;
7、往表中插入记录:mysql> INSERT INTO 表名 VALUES ("hyq","M");
8、更新表中数据:mysql-> UPDATE 表名 SET 字段名1='a',字段名2='b' WHERE 字段名3='c';
9、用文本方式将数据装入数据表中:mysql> load data local infile "d:/mysqltxt" into table 表名;
10、导入sql文件命令:mysql> USE 数据库名;mysql> source d:/mysqlsql;
11、命令行修改root密码:mysql> update mysqluser set password=password('新密码') where user='root';mysql> flush privileges;
12修改密码的三种方法:mysql>update user set password=password('123456') where user='joy_pen';mysql>flush privileges;mysql>set password for 'joy_oen'=password('123456');mysql>grant usage on to 'joy_pen' identified by '123456';
1、创建数据库
命令:create database <数据库名> 例如:建立一个名为xhkdb的数据库mysql> create database xhkdb;
2、显示所有的数据库
命令:show databases (注意:最后有个s)mysql> show databases;
3、删除数据库
命令:drop database <数据库名> 例如:删除名为 xhkdb的数据库mysql> drop database xhkdb;
4、连接数据库
命令: use <数据库名> 例如:如果xhkdb数据库存在,尝试存取它:mysql> use xhkdb; 屏幕提示:Database changed
5、当前选择(连接)的数据库mysql> select database();
6、当前数据库包含的表信息:mysql> show tables; (注意:最后有个s)
三、表 *** 作, *** 作之前应连接某个数据库
1、建表
命令:create table <表名> ( <字段名1> <类型1> [,<字段名n> <类型n>]);
mysql> create table MyClass(
> id int(4) not null primary key auto_increment,
> name char(20) not null,
> sex int(4) not null default ''0'',
> degree double(16,2));
2、获取表结构
命令: desc 表名,或者show columns from 表名
mysql>DESCRIBE MyClass
mysql> desc MyClass;
mysql> show columns from MyClass;
3、删除表
命令:drop table <表名>
例如:删除表名为 MyClass 的表 mysql> drop table MyClass;
4、插入数据
命令:insert into <表名> [( <字段名1>[,<字段名n > ])] values ( 值1 )[, ( 值n )]
例如,往表 MyClass中插入二条记录, 这二条记录表示:编号为1的名为Tom的成绩为9645, 编号为2 的名为Joan 的成绩为8299,编号为3 的名为Wang 的成绩为965
mysql> insert into MyClass values(1,'Tom',9645),(2,'Joan',8299), (2,'Wang', 9659);
5、查询表中的数据
1)、查询所有行
命令: select <字段1,字段2,> from < 表名 > where < 表达式 >
例如:查看表 MyClass 中所有数据 mysql> select from MyClass;
2)、查询前几行数据
例如:查看表 MyClass 中前2行数据
mysql> select from MyClass order by id limit 0,2;
6、删除表中数据
命令:delete from 表名 where 表达式
例如:删除表 MyClass中编号为1 的记录
mysql> delete from MyClass where id=1;
7、修改表中数据:update 表名 set 字段=新值,… where 条件
mysql> update MyClass set name=''Mary'' where id=1;
8、在表中增加字段:
命令:alter table 表名 add 字段 类型 其他;
例如:在表MyClass中添加了一个字段passtest,类型为int(4),默认值为0
mysql> alter table MyClass add passtest int(4) default ''0''
9、更改表名:
命令:rename table 原表名 to 新表名;
例如:在表MyClass名字更改为YouClass
mysql> rename table MyClass to YouClass;
更新字段内容
update 表名 set 字段名 = 新内容
update 表名 set 字段名 = replace(字段名,''旧内容'',''新内容'');
以上就是关于access关系数据库的基本 *** 作是什么全部的内容,包括:access关系数据库的基本 *** 作是什么、零基础如何学习数据库、java中使用JDBC完成数据库 *** 作的基本步骤是什么等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)