1: import javax.servlet.*; //servlet文件必须引入的包
2:
3: import javax.servlet.http.*; //servlet文件必须引入的包
4:
5: import java.io.*; //因为要抛出IO异常,所以引入IO包
6:
7: import java.sql.*; //因为要联接数据库,所以需要引入sql的?
8:
9:
10:
11: public class ConSql extends HttpServlet
12:
13: //新建的servlet应用程序必须继承HttpServlet类
14:
15: {
16:
17: public void init(ServletConfig config) throws ServletException
18:
19: //使用ServletConfig config对象对新建的Servlet进行初始化设置
20:
21: {
22:
23: super.init(config);
24:
25: //为确保形参中的config对象能正常进行初始化需要激活其父类的init方法
26:
27: try
28:
29: {
30:
31: Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
32:
33: //连接数据库第一步,在init方法中注册SQL数据库驱动程序是为了
34:
35: //添加数据库驱动程序
36:
37: //需要抛出异常
38:
39: //联接数据库时最好在这里先注册驱动程序
40:
41: //在doGet或者doPost方法中再建立数据链接
42:
43: }
44:
45: catch(Exception e)
46:
47: {
48:
49: e.printStackTrace();
50:
51: System.out.println(“数据库连接异常”);
52:
53: }
54:
55: }
56:
57: public void doGet(HttpServletRequest request, HttpServletResponse response)
58:
59: throws ServletException, IOException
60:
61: {
62:
63: response.setContentType("text/html; charset=gb2312");
64:
65: //设置返回的内容类型形式
66:
67: PrintWriter out = response.getWriter();
68:
69: //创建一个文本打印输出流
70:
71:
72:
73: /*
74:
75: out.println("<html>");
76:
77: out.println("<head><title>网页标题</title></head>");
78:
79: out.println("<body ">");
80:
81: out.println("网页内容");
82:
83: out.println("</body></html>");
84:
85: //用out.println动态的生成一个网页
86:
87: */
88:
89: try
90:
91: {
92:
93: String url="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=student";
94:
95: // jdbc是主协议
96:
97: // microsoft:sqlserver是子协议
98:
99: // localhost是本机名(或IP)
100:
101: // 1433端口为SQL默认端口
102:
103:
104:
105: Connection con=null;
106:
107: con=DriverManager.getConnection(url,"sa","");
108:
109: //连接数据库第二步
110:
111: //用Connection对象与数据库建立一个联接
112:
113: //sa是访问数据库的用户口令
114:
115: //sa后面的""是访问数据库的密码
116:
117: //在这里需要抛出一个异常
118:
119:
120:
121: Statement sta=null;
122:
123: sta=con.createStatement();
124:
125: //连接数据库第三步
126:
127: //创建一个操纵SQL语句的对象
128:
129:
130:
131: ResultSet res=sta.executeQuery("SELECT * FROM student");
132:
133: //res对象接收select返回的结果集
134:
135: //查询用executeQuery("select * from 表名")
136:
137: //增删改用executeUpdate("insert into 表名 values(,,,,)")
138:
139: while(res.next())//res.next()方法判断是否还有下一条记录
140:
141: {
142:
143: String str1=res.getString("学号");
144:
145: //str 得到数据库中id字段
146:
147: String str2=res.getString("姓名");
148:
149: //str0 得到数据库中name字段
150:
151: String str3=res.getString("年龄");
152:
153: String str4=res.getString("性别");
154:
155: String str5=res.getString("系别");
156:
157: out.println(str1);
158:
159: out.println(str2);
160:
161: out.println(str3);
162:
163: out.println(str4);
164:
165: out.println(str5);
166:
167: }
168:
169: res.close();
170:
171: sta.close();
172:
173: con.close();
174:
175:
176:
177: }
178:
179: catch(Exception e)
180:
181: {
182:
183: e.printStackTrace();
184:
185: }
186:
187: }
188:
189: public void doPost(HttpServletRequest request, HttpServletResponse response)
190:
191: throws ServletException, IOException
192:
193: {
194:
195: doGet(request,response);
196:
197: //在doPost方法中调用doGet方法,节省代码
198:
199: }
200:
201:
202:
203: public void destroy()
204:
205: {
206:
207: //垃圾回收
208:
209: }
210:
211: }
212:
213:
214:
215: 其他数据库连接驱动及URL.
216:
217: //SQL_Server:
218:
219: String driver = "com.microsoft.jdbc.sqlserver.SQLServerDriver";
220: String url = "jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=test";
221: String user = "sa";
222: String password = "";
223:
224:
225: //Oracle:
226:
227: String driver = "oracle.jdbc.driver.OracleDriver";
228: String url = "jdbc:oracle:thin:@localhost:1521:wanchao";
229: String user = "scott";
230: String password = "tiger";
231:
232:
233: //mysql
234: String driver="com.mysql.jdbc.Driver";
235: String url="jdbc:mysql://localhost:3306/chinabank?useUnicode=true&characterEncoding=GBK";
236: String user="root";
237: String passeord="root";
238:
239: Class.forName(driver);
240: con = DriverManager.getConnection(url,user,password);
241:
242: