真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

java代碼怎么創(chuàng)建表,java 創(chuàng)建數(shù)據(jù)庫,創(chuàng)建表

如何用java應用程序創(chuàng)建表格

多少有點麻煩

成都創(chuàng)新互聯(lián)公司自2013年起,公司以網(wǎng)站制作、做網(wǎng)站、系統(tǒng)開發(fā)、網(wǎng)絡(luò)推廣、文化傳媒、企業(yè)宣傳、平面廣告設(shè)計等為主要業(yè)務(wù),適用行業(yè)近百種。服務(wù)企業(yè)客戶超過千家,涉及國內(nèi)多個省份客戶。擁有多年網(wǎng)站建設(shè)開發(fā)經(jīng)驗。為企業(yè)提供專業(yè)的網(wǎng)站建設(shè)、創(chuàng)意設(shè)計、宣傳推廣等服務(wù)。 通過專業(yè)的設(shè)計、獨特的風格,為不同客戶提供各種風格的特色服務(wù)。

建意不要用java來實現(xiàn)

JTable 組件:

類層次結(jié)構(gòu)圖:

java.lang.Object

--java.awt.Component

--java.awt.Container

--javax.swing.JComponent

--javax.swing.JTabel

在使用 JTable 以前,我們先看一下它的構(gòu)造函數(shù)有哪些, 以及應該如何使用:

JTabel 構(gòu)造函數(shù):

JTable():建立一個新的 JTables,并使用系統(tǒng)默認的 Model.

JTable(int numRows,int numColumns):建立一個具有 numRows 行,numColumns 列的空表格,

使用的是 DefaultTableModel.

JTable(Object[ ][ ] rowData,Object[ ][ ] columnNames):建立一個顯示二維數(shù)組數(shù)據(jù)的表格,且可

以顯示列的名稱。

JTable(TableModeldm):建立一個 JTable,有默認的字段模式以及選擇模式,并設(shè)置數(shù)據(jù)模式。

JTable(TableModeldm,TableColumnModel cm):建立一個 JTable,設(shè)置數(shù)據(jù)模式與字段模式,并

有默認的選擇模式。

JTable(TableModel dm,TableColumnModel cm,ListSelectionModel sm):建立一個 JTable,設(shè)置數(shù)

據(jù)模式、字段模式、與選擇模式。

JTable(Vector rowData,Vector columnNames):建立一個以 Vector 為輸入來源的數(shù)據(jù)表格,可顯

示行的名稱。

我們先以 Array 構(gòu)造方式,說明如何利用 JTable 來建立一個簡單的表格:

import javax.swing.*;

import java.awt.*;

import java.awt.event.*;

import java.util.*;

public class SimpleTable{

public SimpleTable(){

JFrame f=new JFrame();

Object[ ][ ] playerInfo={

{" 阿 呆 ",new Integer(66),new Integer(32),new Integer(98),new

Boolean(false)},

{"阿呆",new Integer(82),new Integer(69),new Integer(128),new

Boolean(true)},

};

String[ ] Names={"姓名","語文","數(shù)學","總分","及格"};

JTable table=new JTable(playerInfo,Names);

table.setPreferredScrollableViewportSize(new Dimension(550,30));

JScrollPane scrollPane=new JScrollPane(table);

f.getContentPane().add(scrollPane,BorderLayout.CENTER);

f.setTitle("SimpleTable");

f.pack();

f.show();

f.addWindowListener(newWindowAdapter() {

public void windowClosing(WindowEvent e) {

System.exit(0);

}

});

}

public static void main(String[] args){

SimpleTable b=new SimpleTable();

}

}

表格由兩部份組成:分別是行標題(Column Header)與行對象(Column Object).利用 JTable

所提供的 getTableHeader()方法取得行標題。在這個例子中,我們將 JTable 放在 JScrollPane

中,這種做法可以將 Column Header 與 Colmn Object 完整的顯示出來,因為 JScrollPane 會自

動 取 得 Column Header. 但 如 果 文 壇 讀 者 將 上 面 第 15 行 去 掉 并 修 改 第 16 行 :

f.getContentPane().add(table,BorderLayout.CENTER);

則運行結(jié)果你會發(fā)現(xiàn) Column Header 不見了。

如果你不想用 JScrollPane,要解決這個問題,你必須將程序修改如下:

JTable table=new JTable(p,n);

table.setPreferredScrollableViewportSize(new Dimension(550,30));

f.getContentPane().add(table.getTableHeader(),BorderLayout.NORTH);

f.getContentPane().add(table,BorderLayout.CENTER);

運行結(jié)果就會跟之前一樣有行標題了.

上面的運行結(jié)果就會跟發(fā)現(xiàn),每個字段的寬度都是一樣的,除非你自行拉曳某個列寬。若

我們想一開始就設(shè)置列寬的值,可以利

用 TableColumn 類所提供的 setPreferredWidth()方法來設(shè)置,并可利用 JTable 類所提供的

setAutoResizeMode()方法來設(shè)置調(diào)整某個

列寬時其他列寬的變化情況,我們看下面這個例子:

import javax.swing.*;

import javax.swing.table.*;

import java.awt.*;

import java.awt.event.*;

import java.util.*;

public class SimpleTable2{

public SimpleTable2(){

JFrame f=new JFrame();

Object[][] p={

{" 阿 呆 ",new Integer(66),new Integer(32),new Integer(98),new

Boolean(false),new Boolean(false)},

{" 阿 呆 ",new Integer(82),new Integer(69),new Integer(128),new

Boolean(true),new Boolean(false)},

};

String[] n={"姓名","語文","數(shù)學","總分","及格","作弊"};

TableColumn column=null;

JTable table=new JTable(p,n);

table.setPreferredScrollableViewportSize(new Dimension(550,30));

table.setAutoResizeMode(JTable.AUTO_RESIZE_SUBSEQUENT_COLUMNS);

for (int i=0;i6;i++){

//利用 JTable 中的 getColumnModel()方法取得 TableColumnModel 對象;再利用

TableColumnModel 界面所定義的 getColumn()方法取

//TableColumn 對象,利用此對象的 setPreferredWidth()方法就可以控制字段的寬度.

column=table.getColumnModel().getColumn(i);

if ((i%2)==0)

column.setPreferredWidth(150);

else

column.setPreferredWidth(50);

}

JScrollPane scrollPane=new JScrollPane(table);

f.getContentPane().add(scrollPane,BorderLayout.CENTER);

f.setTitle("SimpleTable");

f.pack();

f.show();

f.setVisible(true);

f.addWindowListener(newWindowAdapter() {

public void windowClosing(WindowEvent e) {

System.exit(0);

}

});

}

public static void main(String[] args){

new SimpleTable2();

}

}

列可調(diào)整的 5 個參數(shù):

AUTO_RESIZE_SUBSEQUENT_COLUMENS:當調(diào)整某一列寬時,此字段之后的所有字段列

寬都會跟著一起變動。此為系統(tǒng)默認值。

AUTO_RESIZE_ALL_COLUMNS:當調(diào)整某一列寬時,此表格上所有字段的列寬都會跟著一

起變動。

AUTO_RESIZE_OFF:當調(diào)整某一列寬時,此表格上所有字段列寬都不會跟著改變。

AUTO_RESIZE_NEXT_COLUMN:當調(diào)整某一列寬時,此字段的下一個字段的列寬會跟著改

變,其余均不會變。

AUTO_RESIZE_LAST_COLUMN:當調(diào)整某一列寬時,最后一個字段的列寬會跟著改變,其

余均不會改變。

由以上范例可知,利用 Swing 來構(gòu)造一個表格其實很簡單的,只要你利用 Vector 或 Array

來作為我們表格的數(shù)據(jù)輸入,將 Vector 或 Array 的

內(nèi)容填入 JTable 中,一個基本的表格就產(chǎn)生了。不過,雖然利用 JTable(Object[][]

rowData,Object[][] columnNames)以及

JTable(Vector rowData,Vector columnNames)構(gòu)造函數(shù)來構(gòu)造構(gòu)造 JTable 很方便,但卻有些缺

點。例如上例中,我們表格中的每個字段

(cell)一開始都是默認為可修改的,用戶因此可能修改到我們的數(shù)據(jù);其次,表格中每個單元

(cell)中的數(shù)據(jù)類型將會被視為同一種。在我

們的例子中,數(shù)據(jù)類型皆被顯示為 String 的類型,因此,原來的數(shù)據(jù)類型聲明為 Boolean 的

數(shù)據(jù)會以 String 的形式出現(xiàn)而不是以檢查框(

Check Box)出現(xiàn)。

除此之外,如果我們所要顯示的數(shù)據(jù)是不固定的,或是隨情況而變,例如同樣是一份成績

單,老師與學生所看到的表格就不會一樣,顯

示的外觀或操作模式也許也不相同。為了因應這些種種復雜情況,上面簡單的構(gòu)造方式已不

宜使用,Swing 提供各種 Model(如:

TableModel、TableColumnModel 與 ListSelectionModel)來解決上述的不便,以增加我們設(shè)計

表格的彈性。我們下面就先對 TableModel 來

做介紹:

TableModel

TableModel類本身是一個interface,在這個interface里面定義了若干的方法:包括了存取表

格字段(cell)的內(nèi)容、計算表格的列數(shù)等等的基本存取操作,讓設(shè)計者可以簡單地利用

TableModel 來實作他所想要的表格。TableModel 界面是放在 javax.swing.table package 中,

這個 package 定義了許多 JTable 會用到的各種 Model,讀者可利用 java api 文件找到這個

package,并由此 package 找到各類或界面所定義的方法。

TableModel 方法:

void addTableModelListener(TableModelListener l):使表格具有處理 TableModelEvent 的能

力。當表格的 Table Model 有所變化時,會發(fā)出 TableModel Event 事件信息.

Class getColumnClass(int columnIndex):返回字段數(shù)據(jù)類型的類名稱.

int getColumnCount():返回字段(行)數(shù)量.

String getColumnName(int columnIndex):返回字段名稱.

int getRowCount():返回數(shù)據(jù)列數(shù)量.

Object getValueAt(int rowIndex,int columnIndex):返回數(shù)據(jù)某個 cell 中的值.

boolean isCellEditable(int rowIndex,int columnIndex):返回cell是否可編輯,true的話

為可編輯.

void removeTableModelListener(TableModelListener l):從 TableModelListener 中

移除一個 listener.

void setValueAt(Object aValue,int rowIndex,int columnIndex): 設(shè) 置 某 個

cell(rowIndex,columnIndex)的值;

由于TableModel本身是一個Interface,因此若要直接實現(xiàn)此界面來建立表格并不是件輕松

的事.幸好 java 提供了兩個類分別實現(xiàn)了這個界面,一個是 AbstractTableModel 抽象類,一個是

DefaultTableModel 實體類.前者實現(xiàn)了大部份的 TableModel 方法,讓用戶可以很有彈性地構(gòu)

造自己的表格模式;后者繼承前者類,是 java 默認的表格模式.這三者的關(guān)系如下所示:

TableModel---implements---AbstractTableModel-----extends---DefaultTableModel

AbstractTableModel:

java 提供的 AbstractTableModel 是一個抽象類,這個類幫我們實現(xiàn)大部份的 TableModel 方

法,除了 getRowCount(),getColumnCount(),getValueAt()這三個方法外.因此我們的主要任務(wù)就

是去實現(xiàn)這三個方法.利用這個抽象類就可以設(shè)計出不同格式的表格.我們來看看它所

提供的方法:

AbstractTableModel 方法:

void addTableModelListener(TableModelListener l):使表格具有處理 TableModelEvent 的能

力.當表格的 Table Model 有所變化時,會發(fā)出 TableModelEvent 事件信息.

int findColumn(String columnName):尋找在行名稱中是否含有 columnName 這個項目.若

有,則返回其所在行的位置;反之則返回-1 表示

void fireTableCellUpdated(int row, int column):通知所有的 Listener 在這個表格中的

(row,column)字段的內(nèi)容已經(jīng)改變了.

void fireTableChanged(TableModelEvent e):將所收的事件通知傳送給所有在這個 table

model 中注冊過的 TableModelListeners.

void fireTableDataChanged():通知所有的 listener 在這個表格中列的內(nèi)容已經(jīng)改變了.列的

數(shù)目可能已經(jīng)改變了,因此 JTable 可能需要重新顯示此表格的結(jié)構(gòu).

void fireTableRowsDeleted(int firstRow, int lastRow):通知所有的 listener 在這個表格中第

firstrow 行至 lastrow 列已經(jīng)被刪除了.

void fireTableRowsUpdated(int firstRow, int lastRow):通知所有的 listener 在這個表格中第

firstrow 行至 lastrow 列已經(jīng)被修改了.

void fireTableRowsInserted(int firstRow, int lastRow):通知所有的 listener 在這個表格中第

firstrow 行至 lastrow 列已經(jīng)被加入了

.

void fireTableStructureChanged():通知所有的listener在這個表格的結(jié)構(gòu)已經(jīng)改變了.行的數(shù)

目,名稱以及數(shù)據(jù)類型都可能已經(jīng)改變了

.

Class getColumnClass(int columnIndex):返回字段數(shù)據(jù)類型的類名稱.

String getColumnName(int column): 若 沒 有 設(shè) 置 列 標 題 則 返 回 默 認 值 , 依 次 為

A,B,C,...Z,AA,AB,..;若無此 column,則返回一個空的 String

.

Public EventListener[] getListeners(Class listenerType):返回所有在這個 table model 所建立的

listener 中符合 listenerType 的 listener,并以數(shù)組形式返回.

boolean isCellEditable(int rowIndex, int columnIndex):返回所有在這個 table model 所建立的

listener 中符合 listenerType 形式的 listener,并以數(shù)組形式返回.

voidremoveTableModelListener(TableModelListener l):從 TableModelListener 中移除一個

listener.

voidsetValueAt(Object aValue, int rowIndex, int columnIndex)

:設(shè)置某個 cell(rowIndex,columnIndex)的值.

若你仔細比較TableModel所定義的方法與上述AbstractTableModel所提供的方法,你可以發(fā)

現(xiàn),AbstractTableModel 抽象類并沒有實現(xiàn)

getRowCount(),getColumnCount(),getValueAt()這三個方法,這也就是為什么我們要去實現(xiàn)這

三個方法的原因.下面我們來看如何使用

AbstractTableModel 來實作出自己想要的表格模式.

范例:TableModel1.java

import javax.swing.table.AbstractTableModel;

import javax.swing.*;

import java.awt.*;

import java.awt.event.*;

public classTableModel1{

publicTableModel1() {

JFrame f = new JFrame();

MyTable mt=new MyTable();

JTable t=new JTable(mt);

t.setPreferredScrollableViewportSize(new Dimension(550, 30));

JScrollPane s = new JScrollPane(t);

f.getContentPane().add(s, BorderLayout.CENTER);

f.setTitle("JTable1");

f.pack();

f.setVisible(true);

f.addWindowListener(newWindowAdapter() {

public void windowClosing(WindowEvent e) {

System.exit(0);

}

});

}

public static void main(String args[]) {

newTableModel1();

}

}

class MyTable extendsAbstractTableModel{

Object[][] p = {

{"阿呆", new Integer(66),

new Integer(32), new Integer(98), new Boolean(false),new Boolean(false)},

{"阿瓜", new Integer(85),

new Integer(69), new Integer(154), new Boolean(true),new Boolean(false)},

};

String[] n = {"姓名",

"語文",

"數(shù)學",

"總分",

"及格",

"作弊"};

public int getColumnCount() {

return n.length;

}

public int getRowCount() {

return p.length;

}

public String getColumnName(int col) {

return n[col];

}

public Object getValueAt(int row, int col) {

return p[row][col];

}

public Class getColumnClass(int c) {

return getValueAt(0, c).getClass();

}

}

上例中表格內(nèi)的數(shù)據(jù)類型不論是 String,int 或是 Boolean 類型,都均以 string 的類型顯示.

例如在及格的字段中,原本的數(shù)據(jù)是以 Boolean

類型來表示,但顯示在 JTable 上時便轉(zhuǎn)換成字符串形式,若想要使表格能顯示出不同的數(shù)據(jù)類

型,我們要在 MyTable 中 Override 寫 getColumnCl

ass()方法,這個方法可以讓我們分辨出表格中每一行的數(shù)據(jù)類型,并將此類型作適當?shù)娘@示:

public Class getColumnClass(int c) {

return getValueAt(0, c).getClass();

}

這樣"作弊"會以 Check Box 顯示,數(shù)據(jù)類型一律靠右顯示,String 類型一律靠左顯示.

TableModel2.java

import javax.swing.table.AbstractTableModel;

import javax.swing.*;

import java.awt.*;

import java.awt.event.*;

public classTableModel2 implementsActionListener{

JTable t = null;

publicTableModel2() {

JFrame f = new JFrame("DataModel");

JButton b1 = new JButton("數(shù)學老師");

b1.addActionListener(this);

JButton b2 = new JButton("學生阿呆");

b2.addActionListener(this);

JPanel panel = new JPanel();

panel.add(b1);

panel.add(b2);

t=new JTable(new MyTable(1));

t.setPreferredScrollableViewportSize(new Dimension(550, 30));

JScrollPane s = new JScrollPane(t);

f.getContentPane().add(panel, BorderLayout.NORTH);

f.getContentPane().add(s, BorderLayout.CENTER);

f.pack();

f.setVisible(true);

f.addWindowListener(newWindowAdapter() {

public void windowClosing(WindowEvent e) {

System.exit(0);

}

});

}

public void actionPerformed(ActionEvent e)

{

if (e.getActionCommand().equals("學生阿呆"))

t.setModel(new MyTable(1));

if (e.getActionCommand().equals("數(shù)學老師"))

t.setModel(new MyTable(2));

t.revalidate();

}

public static void main(String args[]) {

newTableModel2();

}

}

class MyTable extendsAbstractTableModel{

Object[][] p1 = {

{"阿呆", "1234",new Integer(66),

new Integer(50), new Integer(116), new Boolean(false),new Boolean(false)}};

String[] n1 = {"姓名","學號","語文","數(shù)學","總分","及格","作弊"};

Object[][] p2 = {

{"阿呆", "1234",new Integer(50), new Boolean(false),new Boolean(false),"01234"},

{"阿瓜", "1235",new Integer(75), new Boolean(true),new Boolean(false),"05678"}};

String[] n2 = {"姓名","學號","數(shù)學","及格","作弊","電話"};

int model = 1;

public MyTable(int i){

model = i;

}

public int getColumnCount() {

if(model ==1)

return n1.length;

else

return n2.length;

}

public int getRowCount() {

if(model ==1)

return p1.length;

else

return p2.length;

}

public String getColumnName(int col) {

if(model ==1)

return n1[col];

else

return n2[col];

}

public Object getValueAt(int row, int col) {

if(model == 1)

return p1[row][col];

else

return p2[row][col];

}

public Class getColumnClass(int c) {

return getValueAt(0, c).getClass();

}

}

TableColumnModel:

TableColumnModel 本身是一個 Interface,里面定義了許多與表格的"列(行)"有關(guān)的方法,例

如增加列,刪除列,設(shè)置與取得"列"的相關(guān)信

息.通常我們不會直接實現(xiàn) TableColumnModel 界面,而是會利用 JTable 的 getColumnModel()

方法取得 TableColumnModel 對象,再利用此對象對

字段做設(shè)置.舉例來說,如果我們想設(shè)計的表格是包括有下拉式列表的 Combo Box,我們就能

利用 TableColumnModel 來達到這樣的效果.

我們先看看下面的例子:

import javax.swing.table.AbstractTableModel;

import javax.swing.*;

import java.awt.*;

import java.awt.event.*;

public class ColumnModelTest{

public ColumnModelTest() {

JFrame f = new JFrame();

/* 由 于 我 們 的 MyTable 類 繼 承 了 AbstractTableModel 并 且 實 作 了

getColmunCount(),getRowCount(),getValueAt()方法.因此我們可以通

*過 MyTable 來產(chǎn)生 TableModel 的實體.

*/

MyTable mt=new MyTable();

JTable t=new JTable(mt);//我們利用 MyTable 來建立 JTable.

JComboBox c = new JComboBox();//建立一個 JComboBox 的對象.

c.addItem("Taipei");//我們在新建立的 JComboBox 對象里新增三個項目.

c.addItem("ChiaYi");

c.addItem("HsinChu");

/*我們利用 JTable 所提供的 getTableColumnModel()方法取得 TableColumnModel 對象,

再由 TableColumnModel 類所提供的 getColumn()方

*法取得 TableColumn 對象,TableColumn 類可針對表格中的每一行做具體的設(shè)置,例如

設(shè)置字段的寬度,某行的標頭,設(shè)置輸入較復雜的

*數(shù)據(jù)類型等等.在這里,我們利用 TableColumn 類所提供的 setCellEditor()方法,將

JComboBox 作為第二行的默認編輯組件.

*/

t.getColumnModel().getColumn(1).setCellEditor(new DefaultCellEditor(c));

t.setPreferredScrollableViewportSize(new Dimension(550, 30));

JScrollPane s = new JScrollPane(t);

f.getContentPane().add(s, BorderLayout.CENTER);

f.setTitle("ColumnModelTest");

f.pack();

f.setVisible(true);

f.addWindowListener(newWindowAdapter() {

public void windowClosing(WindowEvent e) {

System.exit(0);

}

});

}

public static void main(String args[]) {

new ColumnModelTest();

}

}

class MyTable extendsAbstractTableModel{

Object[][] p = {

{"阿呆", "Taipei",new Integer(66),

new Integer(32), new Integer(98), new Boolean(false),new Boolean(false)},

{"阿瓜", "ChiaYi",new Integer(85),

new Integer(69), new Integer(154), new Boolean(true),new Boolean(false)},

};

String[] n = {"姓名",

"居住地",

"語文",

"數(shù)學",

"總分",

"及格",

"作弊"};

public int getColumnCount() {

return n.length;

}

public int getRowCount() {

return p.length;

}

public String getColumnName(int col) {

return n[col];

}

public Object getValueAt(int row, int col) {

return p[row][col];

}

public Class getColumnClass(int c) {

return getValueAt(0, c).getClass();

}

/*pu

如何用JAVA語句創(chuàng)建一個表

給你一個例子: import java.sql.*; import java.awt.*; public class Createexp { public static void main(String args[]){ String url = jdbc:odbc:wwms; ///wwms 是ODBC的數(shù)據(jù)源 Connection con = null; Statement sm = null;try{///加載JDBC-ODBC驅(qū)動程序 bridge Class.forName(sun.jdbc.odbc.JdbcOdbcDriver); //com.ms.jdbc.odbc.JdbcOdbcDriver /// 不對 com.ms 改為sun } catch(Exception e){ System.out.println(無法裝載JDBC-ODBC bridge 驅(qū)動程序);return;}/////與數(shù)據(jù)庫建立連接并顯示try{con = DriverManager.getConnection(url); sm = con.createStatement(); //創(chuàng)建對象 //執(zhí)行數(shù)據(jù)庫表的創(chuàng)建操作 sm.execute(create table tb(tepno int, tepname char(10) ));sm.close();

如何使用JAVA創(chuàng)建數(shù)據(jù)庫表。

JDBC連接數(shù)據(jù)庫

?創(chuàng)建一個以JDBC連接數(shù)據(jù)庫的程序,包含7個步驟:

1、加載JDBC驅(qū)動程序:

在連接數(shù)據(jù)庫之前,首先要加載想要連接的數(shù)據(jù)庫的驅(qū)動到JVM(Java虛擬機),

這通過java.lang.Class類的靜態(tài)方法forName(String className)實現(xiàn)。

例如:

try{

//加載MySql的驅(qū)動類

Class.forName("com.mysql.jdbc.Driver") ;

}catch(ClassNotFoundException e){

System.out.println("找不到驅(qū)動程序類 ,加載驅(qū)動失?。?);

e.printStackTrace() ;

}

成功加載后,會將Driver類的實例注冊到DriverManager類中。

2、提供JDBC連接的URL

?連接URL定義了連接數(shù)據(jù)庫時的協(xié)議、子協(xié)議、數(shù)據(jù)源標識。

?書寫形式:協(xié)議:子協(xié)議:數(shù)據(jù)源標識

協(xié)議:在JDBC中總是以jdbc開始

子協(xié)議:是橋連接的驅(qū)動程序或是數(shù)據(jù)庫管理系統(tǒng)名稱。

數(shù)據(jù)源標識:標記找到數(shù)據(jù)庫來源的地址與連接端口。

例如:(MySql的連接URL)

jdbc:mysql:

//localhost:3306/test?useUnicode=truecharacterEncoding=gbk ;

useUnicode=true:表示使用Unicode字符集。如果characterEncoding設(shè)置為

gb2312或GBK,本參數(shù)必須設(shè)置為true 。characterEncoding=gbk:字符編碼方式。

3、創(chuàng)建數(shù)據(jù)庫的連接

?要連接數(shù)據(jù)庫,需要向java.sql.DriverManager請求并獲得Connection對象,

該對象就代表一個數(shù)據(jù)庫的連接。

?使用DriverManager的getConnectin(String url , String username ,

String password )方法傳入指定的欲連接的數(shù)據(jù)庫的路徑、數(shù)據(jù)庫的用戶名和

密碼來獲得。

例如:

//連接MySql數(shù)據(jù)庫,用戶名和密碼都是root

String url = "jdbc:mysql://localhost:3306/test" ;

String username = "root" ;

String password = "root" ;

try{

Connection con =

DriverManager.getConnection(url , username , password ) ;

}catch(SQLException se){

System.out.println("數(shù)據(jù)庫連接失?。?);

se.printStackTrace() ;

}

4、創(chuàng)建一個Statement

?要執(zhí)行SQL語句,必須獲得java.sql.Statement實例,Statement實例分為以下3

種類型:

1、執(zhí)行靜態(tài)SQL語句。通常通過Statement實例實現(xiàn)。

2、執(zhí)行動態(tài)SQL語句。通常通過PreparedStatement實例實現(xiàn)。

3、執(zhí)行數(shù)據(jù)庫存儲過程。通常通過CallableStatement實例實現(xiàn)。

具體的實現(xiàn)方式:

Statement stmt = con.createStatement() ;

PreparedStatement pstmt = con.prepareStatement(sql) ;

CallableStatement cstmt =

con.prepareCall("{CALL demoSp(? , ?)}") ;

請問用java代碼如何創(chuàng)建數(shù)據(jù)表

class.forname("oracle.jdbc.driver.OracleDriver");//加載數(shù)據(jù)庫驅(qū)動

String url="jdbc:oracle:thin:@localhost:1521:db_name";

String sql="CREATE TABLE table(filed1 varchar2(2),filed2 varchar2(2))";

Connection conn=DriverManager.getConnection(url,"scott","tiger");//建立數(shù)據(jù)庫連接

if(!conn.isClose()){

Statement stmt = conn.createStatement();

stmt.executeUPDATE(sql); //建立一個表

}


當前標題:java代碼怎么創(chuàng)建表,java 創(chuàng)建數(shù)據(jù)庫,創(chuàng)建表
地址分享:http://weahome.cn/article/hdeoeo.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部