首页 热点资讯 义务教育 高等教育 出国留学 考研考公
您的当前位置:首页正文

二、获取数据库连接

2023-11-13 来源:花图问答
  • java.sql.Driver 接口是所有 JDBC 驱动程序需要实现的接口。这个接口是提供给数据库厂商使用的,不同数据库厂商提供不同的实现。

  • 在程序中不需要直接去访问实现了 Driver 接口的类,而是由驱动程序管理器类(java.sql.DriverManager)去调用这些Driver实现。

  • Oracle的驱动:oracle.jdbc.driver.OracleDriver
  • mySql的驱动: com.mysql.jdbc.Driver
  • 将驱动jar包拷贝到Java工程的一个目录中,习惯上新建一个lib文件夹。

  • 注意:如果是Dynamic Web Project(动态的web项目)话,则是把驱动jar放到WebContent(有的开发工具叫WebRoot)目录中的WEB-INF目录中的lib目录下即可。

    2.1.2 加载与注册JDBC驱动
  • 加载驱动:加载 JDBC 驱动需调用 Class 类的静态方法 forName(),向其传递要加载的 JDBC 驱动的类名

  • Class.forName(“com.mysql.jdbc.Driver”);
  • 注册驱动:DriverManager 类是驱动程序管理器类,负责管理驱动程序

  • 使用DriverManager.registerDriver(com.mysql.jdbc.Driver)来注册驱动

  • 通常不用显式调用 DriverManager 类的 registerDriver() 方法来注册驱动程序类的实例,因为 Driver 接口的驱动程序类都包含了静态代码块,在这个静态代码块中,会调用 DriverManager.registerDriver() 方法来注册自身的一个实例。下图是MySQL的Driver实现类的源码:

  • 技术图片

    2.2 要素二:URL
  • JDBC URL 用于标识一个被注册的驱动程序,驱动程序管理器通过这个 URL 选择正确的驱动程序,从而建立到数据库的连接。

  • JDBC URL的标准由三部分组成,各部分间用冒号分隔。

  • jdbc:子协议:子名称
  • 协议:JDBC URL中的协议总是jdbc
  • 子协议:子协议用于标识一个数据库驱动程序
  • 子名称:一种标识数据库的方法。子名称可以依不同的子协议而变化,用子名称的目的是为了定位数据库提供足够的信息。包含主机名(对应服务端的ip地址),端口号,数据库名
  • 举例:

  • 技术图片

  • 几种常用数据库的 JDBC URL

  • MySQL的连接URL编写方式:

  • jdbc:mysql://主机名称:mysql服务端口号/数据库名称?参数=值&参数=值
  • jdbc:mysql://localhost:3306/xiaoran
  • jdbc:mysql://localhost:3306/xiaoran?useUnicode=true&characterEncoding=utf8(如果JDBC程序与服务器端的字符集不一致,会导致乱码,那么可以通过参数指定服务器端的字符集)
  • jdbc:mysql://localhost:3306/xiaoran?user=root&password=123456
  • Oracle 9i的连接URL编写方式:

  • jdbc:oracle:thin:@主机名称:oracle服务端口号:数据库名称
  • jdbc:oracle:thin:@localhost:1521:xiaoran
  • SQLServer的连接URL编写方式:

  • jdbc:sqlserver://主机名称:sqlserver服务端口号:DatabaseName=数据库名称

  • jdbc:sqlserver://localhost:1433:DatabaseName=xiaoran

  • 2.3 要素三:用户名和密码
  • user,password可以用“属性名=属性值”方式告诉数据库
  • 可以调用 DriverManager 类的 getConnection() 方法建立到数据库的连接
  • 2.4 数据库连接方式举例2.4.1 连接方式一
    @Test public void testConnection1() { try { //1.提供java.sql.Driver接口实现类的对象 Driver driver = null; driver = new com.mysql.jdbc.Driver(); //2.提供url,指明具体操作的数据 String url = "jdbc:mysql://localhost:3306/school"; //3.提供Properties的对象,指明用户名和密码 Properties info = new Properties(); info.setProperty("user", "root"); info.setProperty("password", "abc123"); //4.调用driver的connect(),获取连接 Connection conn = driver.connect(url, info); System.out.println(conn); } catch (SQLException e) { e.printStackTrace(); } }

    说明:上述代码中显式出现了第三方数据库的API

    2.4.2 连接方式二
    @Test public void testConnection2() { try { //1.实例化Driver String className = "com.mysql.jdbc.Driver"; Class clazz = Class.forName(className); Driver driver = (Driver) clazz.newInstance(); //2.提供url,指明具体操作的数据 String url = "jdbc:mysql://localhost:3306/school"; //3.提供Properties的对象,指明用户名和密码 Properties info = new Properties(); info.setProperty("user", "root"); info.setProperty("password", "abc123"); //4.调用driver的connect(),获取连接 Connection conn = driver.connect(url, info); System.out.println(conn); } catch (Exception e) { e.printStackTrace(); } }

    说明:相较于方式一,这里使用反射实例化Driver,不在代码中体现第三方数据库的API。体现了面向接口编程思想。

    2.4.3 连接方式三
    @Test public void testConnection3() { try { //1.数据库连接的4个基本要素: String url = "jdbc:mysql://localhost:3306/school"; String user = "root"; String password = "abc123"; String driverName = "com.mysql.jdbc.Driver"; //2.实例化Driver Class clazz = Class.forName(driverName); Driver driver = (Driver) clazz.newInstance(); //3.注册驱动 DriverManager.registerDriver(driver); //4.获取连接 Connection conn = DriverManager.getConnection(url, user, password); System.out.println(conn); } catch (Exception e) { e.printStackTrace(); } }

    说明:使用DriverManager实现数据库的连接。

    2.4.4 连接方式四
    @Test public void testConnection4() { try { //1.数据库连接的4个基本要素: String url = "jdbc:mysql://localhost:3306/school"; String user = "root"; String password = "abc123"; String driverName = "com.mysql.jdbc.Driver"; //2.加载驱动 (①实例化Driver ②注册驱动) Class.forName(driverName); /* 在mysql的Driver类中声明有这样的静态方法: static { try { DriverManager.registerDriver(new Driver()); } catch (SQLException var1) { throw new RuntimeException("Can‘t register driver!"); } } */ //3.获取连接 Connection conn = DriverManager.getConnection(url, user, password); System.out.println(conn); } catch (Exception e) { e.printStackTrace(); } }

    说明:不必显式的注册驱动了。因为Driver类的源码中已经存在静态代码块,实现了驱动的注册。

    2.4.5 连接方式五(最终版)
     @Test public void testConnection5() throws Exception { //1.加载配置文件 InputStream is = ConnectionTest.class.getClassLoader().getResourceAsStream("jdbc.properties"); Properties pros = new Properties(); pros.load(is); //2.读取配置文件 String url = pros.getProperty("url"); String user = pros.getProperty("user"); String password = pros.getProperty("password"); String dirverClass = pros.getProperty("driverClass"); //3.加载驱动 Class.forName(dirverClass); //4.获取连接 Connection conn = DriverManager.getConnection(url, user, password); System.out.println(conn); }

    其中,配置文件声明在工程的src目录下:【jdbc.properties】

    user=rootpassword=123456url=jdbc:mysql://localhost:3306/schooldriverClass=com.mysql.jdbc.Driver

    说明:使用配置文件的方式保存配置信息,在代码中加载配置文件

    使用配置文件的好处:

    ①实现了代码和数据的分离,如果需要修改配置信息,直接在配置文件中修改,不需要深入代码②如果修改了配置信息,省去重新编译的过程。

    二、获取数据库连接

    标签:row   开发工具   直接   test   jar包   sqlserver   cep   开发   端口   

    小编还为您整理了以下内容,可能对您也有帮助:

    JDBC连接数据库的步骤都有哪些?

    1、首先我们通过数据库可视化工具navicate for mysql,新建一个数据库,名字叫test新建一张表。

    2、添加id,name字段,点击【保存】,设置表名称为user。

    3、最终数据库及表创建成功。

    4、然后我们添加一条数据。

    5、下载java mysql connector驱动,通过maven添加依赖即可。

    java中使用JDBC连接数据库的步骤?

    1.注册驱动

    Class.forname("com.mysql.jdbc.Driver");//这是连接mysql数据库的驱动

    2.获取数据库连接

    java.sql.Connection conn=java.sql.DriverManager.getConnection(); 3.获取表达式

    java.sql.Statement stmt=conn.createStatement("jdbc:mysql://localhost/test?useUnicode=true&characterEncoding=GBK","root","null");//三个参数分别是数据库连接的URL,用户名,密码 4.执行SQL

    java.sql.ResultSet rs=stmt.executeQuery("select * from user"); 5.显示结果集里面的数据

    while(rs.next()){

    System.out.println(rs.getInt(1));

    System.out.println(rs.getString("username"));

    System.out.println(rs.getString("password"));

    System.out.pringln();

    }//执行插入语句

    //stmt.executeUpdate("insert into user values(1,'中文','345')");

    6.释放资源

    rs.close();

    stmt.close();

    conn.close();

    链接数据库有哪些方法?

    常见的数据库连接方法如下:
      一、连接Access数据库
      1.
    使用已有DSN的连接字符串进行连接(ODBC);
      2.使用无DSN的连接字符串进行连接(ODBC);  
      3.使用连接字符串进行连接(OLEDB);
      4.使用UDL文件进行连接;
      使用UDL文件连接数据源的步骤如下:
      (1)新建一个记事本,其扩展名为.udl。
      (2)双击该UDL文件,弹出“数据连接属性”对话框。
      (3)该对话框首页显示“提供程序”选项卡,选择要使用的OLEDB提供程序。
      (4)单击“下一步”,显示"l连接“选项卡”,设置好正确的参数后,单击“测试连接”
      二、连接MySQL数据库
      1.使用已有DSN的连接字符串进行连接;
      2.使用无DSN的连接字符串进行连接;
      三、连接Oracle数据库
      1.使用Oracle.NET
    Data
    Provider(需要安装Oracle客户端)
      2.使用ODBC.NET
    Data
    Provider  
      3.使用OLE
    DB.NET
    Data
    Provider

    链接数据库有哪些方法?

    常见的数据库连接方法如下:
      一、连接Access数据库
      1.
    使用已有DSN的连接字符串进行连接(ODBC);
      2.使用无DSN的连接字符串进行连接(ODBC);  
      3.使用连接字符串进行连接(OLEDB);
      4.使用UDL文件进行连接;
      使用UDL文件连接数据源的步骤如下:
      (1)新建一个记事本,其扩展名为.udl。
      (2)双击该UDL文件,弹出“数据连接属性”对话框。
      (3)该对话框首页显示“提供程序”选项卡,选择要使用的OLEDB提供程序。
      (4)单击“下一步”,显示"l连接“选项卡”,设置好正确的参数后,单击“测试连接”
      二、连接MySQL数据库
      1.使用已有DSN的连接字符串进行连接;
      2.使用无DSN的连接字符串进行连接;
      三、连接Oracle数据库
      1.使用Oracle.NET
    Data
    Provider(需要安装Oracle客户端)
      2.使用ODBC.NET
    Data
    Provider  
      3.使用OLE
    DB.NET
    Data
    Provider

    如何获取SQL server数据库的连接字符串

    一:C# 连接SQL数据库

    Data Source=myServerAddress;Initial Catalog=myDataBase;User Id=myUsername;Password=myPassword;

    Data Source=190.190.200.100,1433;Network Library=DBMSSOCN;Initial Catalog=myDataBase;User ID=myUsername;Password=myPassword;

    Server=myServerAddress;Database=myDataBase;User ID=myUsername;Password=myPassword;Trusted_Connection=False;

    Server=myServerAddress;Database=myDataBase;Trusted_Connection=True;

    Server=myServerName\theInstanceName;Database=myDataBase;Trusted_Connection=True;

    Data Source=myServerAddress;Initial Catalog=myDataBase;Integrated Security=SSPI;

    1:Integrated Security参数

    当设置Integrated Security为 True 的时候,连接语句前面的 UserID, PW 是不起作用的,即采用windows身份验证模式。

    只有设置为 False 或省略该项的时候,才按照 UserID, PW 来连接。

    Integrated Security 还可以设置为:sspi ,相当于 True,建议用这个代替 True。

    Data Source=myServerAddress;Initial Catalog=myDataBase;Integrated Security=SSPI;

    Data Source=myServerAddress;Initial Catalog=myDataBase;Integrated Security=true;

    Data Source=myServerAddress;Initial Catalog=myDataBase;;User ID=myUsername;Password=myPasswordIntegrated Security=false;

    2:参数Trusted_Connection

    Trusted_Connection=true,将使用当前的 Windows 帐户凭据进行身份验证

    Trusted_Connection=false;将不采用信任连接方式(也即不采用Windows验证方式),而改由SQL Server 2000验证方式

    Server=myServerAddress;Database=myDataBase;User ID=myUsername;Password=myPassword;Trusted_Connection=false;

    Server=myServerAddress;Database=myDataBase;Trusted_Connection=True;

    3:Initial Catalog是你要连接的数据库的名字

    4:WINCE连接

    Data Source=myServerAddress;Initial Catalog=myDataBase;Integrated Security=SSPI;User ID=myDomain\myUsername;Password=myPassword;

    二:可以利用SqlConnectionStringBuilder,这样不必去记住名称。

    SqlConnectionStringBuilder scsb = new SqlConnectionStringBuilder();

    scsb.DataSource = @"(local)\SQLExpress";

    scsb.IntegratedSecurity = true;

    scsb.InitialCatalog = "Northwind";

    SqlConnection myConnection = new SqlConnection(scsb.ConnectionString);

    三:可以利用属性中的Setting来自动设置连接字符串

    1:在type中选择 (connection string),

    2:在DataSouce中选择数据源,然后再Server中输入服务器名,本地用(local)\SQLExpress

    3:选择登陆验证方式,本次选Windows验证(即信任连接Integrated Security=True)

    4:选择数据库名,确认即可

    Data Source=(local)\SQLExpress;Initial Catalog=Northwind;Integrated Security=True

    server = .\sqlexpress;integrated security = true;database = northwind

    四:SQL2005远程服务器连接方法

    如何打开sql server 2005 的1433端口:

    配置工具->Sql Server Configuration Manager->MSSQLSERVER的协议看看TCP/IP协议是否启动,如果启动,右键菜单点"属性" ,在分页菜单中选"IP地址",把"IP1"和"IP2"中"TCP端口"为1433,"已启用"改为"是"

    配置工具->Sql Server Configuration Manager->SQL Native Client 配置->客户端协议->TCP/IP选择TCP/IP右键菜单中"属性",确认"默认端口"是1433,"已启用"为"是"。

    SQL Server 2005 远程连接配置TCP/IP属性:

    Surface Area Configuration --> Database Engine --> Remote Connections --->Using TCP/IT SQL Server 外围应用配置器?服务和连接外围配置?database englie?远程连接?启用(远程连接的TCP/IP和named pipes)

    SQL Server Configuration Manager?SQL2005网络配置?启用TCP/IP和named pipes

    其他说明见下: sqlserver2005(Express版),为了便于管理,你还需要去下一个manage管理器:

    安装好manage管理器后,在程序中连接sqlserver2005,下面几点是要注意的。

    1. 开启sql2005远程连接功能,开启办法如下, 配置工具->sql server外围应用配置器->服务和连接的外围应用配置器->打开MSSQLSERVER节点下的Database Engine 节点,先择"远程连接",接下建议选择"同时使用TCP/IP和named pipes",确定后,重启数据库服务就可以了.

    2.登陆设置改为,Sql server and windows Authentication方式同时选中,具体设置如下: manage管理器->windows Authentication(第一次用windows方式进去),->对象资源管理器中选择你的数据服务器--右键>属性>security>Sql server and windows Authentication方式同时选中.

    3:设置一个Sql server方式的用户名和密码,具体设置如下: manage管理器->windows Authentication>new query>sp_password null,'sa123456','sa' 这样就设置了一个用户名为sa ,密码为:sa123456的用户,下次在登陆时,可以用Sql server方式, 用户名为sa ,密码为:sa123456的用户进数据库了.

    4: 做完上面三步后,这样写连接字符串就可以顺利进入数据库了,

    (server=.\sqlexpress;uid=sa;pwd=sa123456;database=master";

    五:SQL2000远程服务器连接方法

    1:看ping 服务器IP能否ping通。

    2:在Dos或命令行下输入telnet 服务器IP 端口,看能否连通。   如telnet 202.114.100.100 1433   通常端口值是1433,因为1433是sql server 2000的对于Tcp/IP的默认侦听端口。如果有问题,通常这一步会出问题。通常的提示是“……无法打开连接,连接失败"。   

    如果这一步有问题,应该检查以下选项。   

    1) 检查远程服务器是否启动了sql server 2000服务。如果没有,则启动。   

    2) 检查服务器端有没启用Tcp/IP协议,因为远程连接(通过因特网)需要靠这个协议。检查方法是,在服务器上打开 开始菜单-> 程序-> Microsoft SQL Server-> 服务器网络实用工具,看启用的协议里是否有tcp/ip协议,如果没有,则启用它。   

    3)检查服务器的tcp/ip端口是否配置为1433端口。仍然在服务器网络实用工具里查看启用协议里面的tcp/ip的属性,确保默认端口为1433,并且隐藏服务器复选框没有勾上。   事实上,如果默认端口被修改,也是可以的,但是在客户端做 telnet测试时,写服务器端口号时必须与服务器配置的端口号保持一致。如果隐藏服务器复选框被勾选,则意味着客户端无法通过枚举服务器来看到这台服务器,起到了保护的作用,但不影响连接,但是Tcp/ip协议的默认端口将被隐式修改为2433,在客户端连接时必须作相应的改变。   

    4)如果服务器端操作系统打过sp2补丁,则要对windows防火墙作一定的配置,要对它开放1433端口,通常在测试时可以直接关掉windows防火墙(其他的防火墙也关掉最好)。   

    5)检查服务器是否在1433端口侦听。如果服务器没有在tcp连接的1433端口侦听,则是连接不上的。检查方法是在服务器的dos或命令行下面输入  netstat -a -n 或者是netstat -an,在结果列表里看是否有类似 tcp 127.0.0.1 1433 listening 的项。如果没有,则通常需要给sql server 2000打上至少sp3的补丁。其实在服务器端启动查询分析器,输入 select @@version 执行后可以看到版本号,版本号在8.0.2039以下的都需要打补丁。  如果以上都没问题,这时你再做telnet 服务器ip 1433 测试,将会看到屏幕一闪之后光标在左上角不停闪动。恭喜你,你马上可以开始在企业管理器或查询分析器连接了。   

    3: 检查客户端设置  程序-> Microsoft SQL Server -> 客户端网络使用工具。像在服务器网络实用工具里一样,确保客户端tcp/ip协议启用,并且默认端口为1433(或其他端口,与服务器端保持一致就行)。  

    4:在企业管理器里或查询那分析器连接测试   企业管理器-> 右键SQlserver组-> 新建sqlserver注册-> 下一步-> 写入远程IP-> 下一步-> 选Sqlserver登陆-> 下一步-> 写入登陆名与密码(sa,password)-> 下一步-> 下一步-> 完成   查询分析器-> 文件-> 连接-> 写入远程IP-> 写入登录名和密码(sa,password)-> 确定  通常建议在查询分析器里做,因为默认情况下,通过企业管理器注册另外一台SQL Server的超时设置是4秒,而查询分析器是15秒。  修改默认连接超时的方法:   企业管理器-> 工具-> 选项-> 在弹出的"SQL Server企业管理器属性"窗口中,点击"高级"选项卡-> 连接设置-> 在 登录超时(秒) 后面的框里输入一个较大的数字  查询分析器-> 工具-> 选项-> 连接-> 在 登录超时(秒) 后面的框里输入一个较大的数字  通常就可以连通了,如果提示错误,则进入下一步。   

    5:错误产生的原因通常是由于SQL Server使用了"仅 Windows"的身份验证方式,因此用户无法使用SQL Server的登录帐户(如 sa )进行连接。解决方法如下所示:   

    1) 在服务器端使用企业管理器,并且选择"使用 Windows 身份验证"连接上 SQL Server。   

    2) 展开"SQL Server组",鼠标右键点击SQL Server服务器的名称,选择"属性",再选择"安全性" 选项卡。   

    3)在"身份验证"下,选择"SQL Server和 Windows "。   

    4) 重新启动SQL Server服务。(在dos或命令行下面net stop mssqlserver停止服务,net start mssqlserver启动服务,也是一种快捷的方法)。

    java 怎么连接sql数据库 帮忙步骤讲解以及代码参考

    首先,使用JDBC技术获取数据库连接:

    public static Connection getConnection(){

    try{

    Class.forName("oracle.jdbc.driver.OracleDriver");

    Connection con=DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:orcl", "root", "root");

    return con;

    }catch(Exception e){

    e.printStackTrace();

    return null;

    }

    }

    Class.forName(数据库驱动);

    这是JVM在加载数据库驱动。

    DriverManager.getConnection(url,username,password);

    url是指连接数据库的地址。

    像上面我写的URL是这样的:jdbc:oracle:thin:@127.0.0.1:1521:orcl

    127.0.0.1是指本机,也可以用localhost代替,1521是数据库端口号(本人用的是oracle10g),orcl是指oracle_sid。username/password数据库的用户名和密码。有的数据库的url可能不是这样。当然可以去网上查一下就知道了。

    这种连接方法是一次请求一次连接,是比较浪费资源的。

    像tomcat,weblogic等服务器都带有连接池来避免资源的浪费,而且现在好象有规定,只要是服务器就必须带有连接池。

    至于连接池的连接方法,不同的服务器有不同的获得方法。建议你用哪个就去学哪个。

    有连接就有关闭数据库,获得数据库连接后一定要记得关闭资源。

    public static void close(Connection con){

    if(con!=null){

    try{con.close();}catch(Exception e){}

    }

    }

    为了方便,不防写成一个方法。

    获取连接后,然后使用这个连接去创建相应的Statement来操作数据库。

    有Statement,PerparedStatement,CallableStatement这几种statement可以用来创建。

    我们先看看Statement的使用。

    public static void main(String[] args) {

    Connection con=JDBCUtil.getConnection();

    Statement stat=null;

    ResultSet rs=null;

    try{

    String sql="select a_id,a_name,a_no from a";

    stat=con.createStatement();

    rs=stat.executeQuery(sql);

    while(rs.next()){

    System.err.println(rs.getInt(1)+"/"+rs.getString(2)+"/"+rs.getInt(3));

    }

    }catch(Exception e){

    e.printStackTrace();

    }

    JDBCUtil.close(rs,stat,con);

    }

    注释:

    stat=con.createStatement();是用连接创建Statement对象。

    stat.executeQuery(sql);是执行查询语句。这个方法返回的是一个结果集。即ResultSet。可以将查询出来的结果放入结果集中。

    rs.next()这个方法返回的一个boolean类型的值,即当指针能够往下走时,返回true,否则返回false。这样就可以保证能够遍历这个结果集了。

    当然这里出现了Statement,ResultSet,那么close()方法也得变化了。

    如下:

    public static void close(ResultSet rs,Statement stat,Connection con){

    if(rs!=null){

    try{rs.close();}catch(Exception e){}

    }

    if(stat!=null){

    try{stat.close();}catch(Exception e){}

    }

    if(con!=null){

    try{con.close();}catch(Exception e){}

    }

    }

    注意关闭顺序,一定是先ResultSet,后Statement,最后Connection.

    由于PerparedStatement和CallableStatement都是Statement的实现类,根据JAVA多态的用法,close()方法就算完全写完了,不用改了。

    现在来看看结果:

    2/all/2

    1/hello/1

    ===================================================================

    现在我们用PerparedStatement来查询:

    Connection con=JDBCUtil.getConnection();

    PreparedStatement stat=null;

    ResultSet rs=null;

    try{

    String sql="select a_id,a_name,a_no from a where a_id=?";

    stat=con.prepareStatement(sql);

    stat.setInt(1, 1);

    rs=stat.executeQuery();

    while(rs.next()){

    System.err.println(rs.getInt(1)+"/"+rs.getString(2)+"/"+rs.getInt(3));

    }

    }catch(Exception e){

    e.printStackTrace();

    }

    JDBCUtil.close(rs,stat,con);

    这里的sql语句里有一个值是未确定的。这样就可以实现预编译,大大提高了程序的运行效率。流程如下:

    stat=con.prepareStatement(sql);这个方法就将这个sql语句进行了一次编译,查看有没有什么明显的语法错误等。

    如果没错,再通过stat.setInt(1, 1);将缺失的值补回去然后再执行sql查询。

    PreparedStatement为批处理提供了一系统方法,让批查询、批更新等更加的效率。

    让我们看看结果:

    1/hello/1

    ==============================================================

    CallableStatement是专门用于处理存储过程的。

    如果想深入的学习,建议你去查看相关资料。

    显示全文