- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经使用 java swing 制作了一个库存系统。我的代码工作正常,直到我将这些代码行添加到我的“保存”按钮中:
这应该是:
从表中获取数据并将其保存到数据库
将这些数据插入我的表 IncomingTransactionITems
int rowCount=jTable3.getRowCount();
String[] ItemList=new String[6];
for(int rowctr=1;rowctr<rowCount;rowctr++){
ItemList[0]= String.valueOf(rowctr); // Incoming Transaction_Number
ItemList[1]= this.jTextField1.getText(); // Transaction ID
ItemList[2]=this.jTable3.getModel().getValueAt(rowctr, 0).toString(); // Item Number
ItemList[3]=this.jTable3.getModel().getValueAt(rowctr, 2).toString(); // Quantity
ItemList[4]=this.jTable3.getModel().getValueAt(rowctr, 3).toString(); // Unit Price
ItemList[5]=this.jTable3.getModel().getValueAt(rowctr, 4).toString(); // Total Price
// Save onto IncomingTransactionItems Table in Database
String sqlItems="INSERT INTO IncomingTransactionItems(Incoming_Transaction_Number, Transaction_ID,Item_Number, Quantity, Unit_Price,Total_Price)values('"
+ ItemList[0]+"','" // Incoming Transaction_Number
+ ItemList[1]+"','" // Transaction ID
+ ItemList[2]+"','" // Item Number
+ ItemList[3]+"','" // Quantity
+ ItemList[4]+"','" // Unit Price
+ ItemList[5]+"')"; // Total Price
try{
pst= conn.prepareStatement(sqlItems);
pst.execute();
this.UpdateJTable();
}
catch(SQLException | HeadlessException e){
Logger.getLogger(Encoding_Incoming_Batch.class.getName()).log(Level.SEVERE, null, e);
}
但是当我运行该程序时,它抛出异常:
Inventory_System.Encoding_Incoming_Batch cmdADDMouseReleased
SEVERE: null
java.sql.SQLException: General error
我认为我的数据库可能是只读的,所以我检查了系统的其他功能(即添加项目、日志、更新价格表等)仍然工作正常。
我检查了我的表的传入事务号主键,如果我可能保存重复值,但事实并非如此,因为程序获取表中的值数并将其加一以形成新记录。
错误点表明这一行有问题
pst= conn.prepareStatement(sqlItems);
我是错过了什么还是我做错了什么?
编辑
发布我的按钮的完整代码
if(cmdADD.isEnabled()){
//==================UPDATE ITEM COUNT and PRICE===================
int rowCountloop=jTable3.getRowCount();
float PreviousPrice;
float NewPrice;
for(int rowctr=1;rowctr<rowCountloop;rowctr++){
// get Item Count
int ItemQuantity=Integer.valueOf(this.jTable2.getModel().getValueAt(rowctr,1).toString());
int IncomingQuantity=Integer.valueOf(this.jTable3.getModel().getValueAt(rowctr, 2).toString());
// add incoming Items
int ItemTotal=ItemQuantity+IncomingQuantity;
PreviousPrice=(Float.valueOf(this.jTable2.getModel().getValueAt(rowctr,2).toString()));
NewPrice=(Float.valueOf(this.jTable3.getModel().getValueAt(rowctr, 3).toString()));
float newTotalPrice=((float) ((PreviousPrice*ItemQuantity)+(NewPrice*IncomingQuantity))/ItemTotal);
// convert values to 2 decimal
double PreviousPrice2 = Math.round(PreviousPrice*100.0)/100.0;
double NewPrice2 = Math.round(NewPrice*100.0)/100.0;
double newTotalPrice2 = Math.round(newTotalPrice*100.0)/100.0;
// Update Value of Quantity and Price
// String sqlUpdate= "Update allItems set Quantity='"+ItemTotal+"',Unit_Cost='"+NewPrice2+"',Total_Cost='"+newTotalPrice2+"' where Item_Number='"+this.jTable3.getModel().getValueAt(rowctr, 0).toString()+"'";
String sqlUpdate= "Update allItems set Quantity=?,Unit_Cost=?,Total_Cost=? where Item_Number='"+this.jTable3.getModel().getValueAt(rowctr, 0).toString()+"'";
try {
PreparedStatement pstUpdate= conn.prepareStatement(sqlUpdate);
pstUpdate.setInt(1, ItemTotal);
pstUpdate.setDouble(2, NewPrice2);
pstUpdate.setDouble(2, newTotalPrice2);
pstUpdate.executeUpdate();
} catch (SQLException ex) {
Logger.getLogger(Encoding_Inventory_Batch.class.getName()).log(Level.SEVERE, null, ex);
}
//==================SAVE Price Change to PriceList==========================================
String sqlPriceChange="insert into PriceList(PriceID,ItemNumber,NewPrice,PreviousPrice,DateAndTime)values(?,?,?,?,?)";
try (PreparedStatement pstPriceChange = conn.prepareStatement(sqlPriceChange)){
pstPriceChange.setString(1, "PL"+ (PriceIDtxt.getText())+"-"+rowctr);
pstPriceChange.setString(2,this.jTable3.getModel().getValueAt(rowctr, 0).toString());
pstPriceChange.setDouble(3,NewPrice2);
pstPriceChange.setDouble(4,PreviousPrice2);
pstPriceChange.setString(5, (dateFormatwithtime.format(date)));
pstPriceChange.executeUpdate();
}
catch(SQLException | HeadlessException e){
JOptionPane.showMessageDialog(null, e);
}
}// end of loop
//==========================================================================================
int RowCounter=jTable3.getRowCount();
if(RowCounter<=1){
JOptionPane.showMessageDialog(this,"Please Input Data on Incoming List","System Message", JOptionPane.ERROR_MESSAGE);
}else{
int reply = JOptionPane.showConfirmDialog(null, "Confirm and SAVE?", "System Message", JOptionPane.YES_NO_OPTION,JOptionPane.QUESTION_MESSAGE);
if (reply == JOptionPane.YES_OPTION) {
int answer = JOptionPane.showConfirmDialog(null, "Data Cannot be modified once it is SAVED, Continue?", "System Message", JOptionPane.YES_NO_OPTION,JOptionPane.WARNING_MESSAGE);
if (answer == JOptionPane.YES_OPTION) {
int rowCount=jTable3.getRowCount();
String[] ItemList=new String[6];
String sqlItems="INSERT INTO IncomingTransactionItems(Incoming_Transaction_Number, Transaction_ID,Item_Number, Quantity, Unit_Price,Total_Price)values(?,?,?,?,?,?)";
for(int rowctr=1;rowctr<rowCount;rowctr++){
ItemList[0]= String.valueOf(rowctr); // Incoming Transaction_Number
ItemList[1]= this.jTextField1.getText(); // Transaction ID
ItemList[2]=this.jTable3.getModel().getValueAt(rowctr, 0).toString(); // Item Number
ItemList[3]=this.jTable3.getModel().getValueAt(rowctr, 2).toString(); // Quantity
ItemList[4]=this.jTable3.getModel().getValueAt(rowctr, 3).toString(); // Unit Price
ItemList[5]=this.jTable3.getModel().getValueAt(rowctr, 4).toString(); // Total Price
// Save onto IncomingTransactionItems Table in Database
try (PreparedStatement pstInsert = conn.prepareStatement(sqlItems)){
// You could do this with a for-loop, I've done it long
// to demonstrate the use of PreparedStatement
pstInsert.setString(1, ItemList[0]);
pstInsert.setString(2, ItemList[1]);
pstInsert.setString(3, ItemList[2]);
pstInsert.setString(4, ItemList[3]);
pstInsert.setString(5, ItemList[4]);
pstInsert.setString(6, ItemList[5]);
pstInsert.executeUpdate();
}catch(SQLException | HeadlessException e){
Logger.getLogger(Encoding_Incoming_Batch.class.getName()).log(Level.SEVERE, null, e);
}
String sql="INSERT INTO Incoming_Transactions (Transaction_ID, Date_Delivered, Ref_No, PO_No,JO_No, Supplier_Code,Notes, Status, Time_Stamp )\n" +
"VALUES (?,?,?,?,?,?,?,?,?)";
try (PreparedStatement pstTransactions = conn.prepareStatement(sql)){
pstTransactions.setString(1, (this.TransactionNotxt.getText()));
pstTransactions.setString(2, this.DateDeliveredChooser.getDate().toString());
pstTransactions.setString(3,this.ReferenceTxt.getText());
pstTransactions.setString(4,this.POtxt.getText());
pstTransactions.setString(5, this.JOtxt.getText());
pstTransactions.setString(6, this.SupplierCodetxt.getText());
pstTransactions.setString(7, this.NoteTextArea.getText());
pstTransactions.setString(8, "Processed");
pstTransactions.setString(9, dateFormatwithtime.format(date));
pstTransactions.execute();
}
catch(SQLException | HeadlessException e){
Logger.getLogger(Encoding_Incoming_Batch.class.getName()).log(Level.SEVERE, null, e);
}
// update Table to show changes
this.UpdateJTable();
}
JOptionPane.showMessageDialog(null, "Transaction Saved");
this.cmdADD.setEnabled(false);
this.cmdDELETE.setEnabled(false);
CountDataPriceList(); // Increment Price List number
}
}
}
}
这是完整的错误
run:
Jul 16, 2015 1:19:31 PM Inventory_System.Encoding_Incoming_Batch cmdADDMouseReleased
SEVERE: null
java.sql.SQLException: General error
at sun.jdbc.odbc.JdbcOdbc.createSQLException(JdbcOdbc.java:6993)
at sun.jdbc.odbc.JdbcOdbc.standardError(JdbcOdbc.java:7121)
at sun.jdbc.odbc.JdbcOdbc.SQLExecute(JdbcOdbc.java:3156)
at sun.jdbc.odbc.JdbcOdbcPreparedStatement.execute(JdbcOdbcPreparedStatement.java:215)
at sun.jdbc.odbc.JdbcOdbcPreparedStatement.executeUpdate(JdbcOdbcPreparedStatement.java:137)
at Inventory_System.Encoding_Incoming_Batch.cmdADDMouseReleased(Encoding_Incoming_Batch.java:1240)
at Inventory_System.Encoding_Incoming_Batch.access$3600(Encoding_Incoming_Batch.java:44)
at Inventory_System.Encoding_Incoming_Batch$30.mouseReleased(Encoding_Incoming_Batch.java:915)
at java.awt.AWTEventMulticaster.mouseReleased(AWTEventMulticaster.java:290)
at java.awt.Component.processMouseEvent(Component.java:6516)
at javax.swing.JComponent.processMouseEvent(JComponent.java:3321)
at java.awt.Component.processEvent(Component.java:6281)
at java.awt.Container.processEvent(Container.java:2229)
at java.awt.Component.dispatchEventImpl(Component.java:4872)
at java.awt.Container.dispatchEventImpl(Container.java:2287)
at java.awt.Component.dispatchEvent(Component.java:4698)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4832)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4492)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4422)
at java.awt.Container.dispatchEventImpl(Container.java:2273)
at java.awt.Window.dispatchEventImpl(Window.java:2719)
at java.awt.Component.dispatchEvent(Component.java:4698)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:747)
at java.awt.EventQueue.access$300(EventQueue.java:103)
at java.awt.EventQueue$3.run(EventQueue.java:706)
at java.awt.EventQueue$3.run(EventQueue.java:704)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:87)
at java.awt.EventQueue$4.run(EventQueue.java:720)
at java.awt.EventQueue$4.run(EventQueue.java:718)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:717)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:242)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:161)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:150)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:146)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:138)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:91)
Jul 16, 2015 1:19:31 PM Inventory_System.Encoding_Incoming_Batch cmdADDMouseReleased
SEVERE: null
java.sql.SQLException: [Microsoft][ODBC Microsoft Access Driver] Data type mismatch in criteria expression.
at sun.jdbc.odbc.JdbcOdbc.createSQLException(JdbcOdbc.java:6964)
at sun.jdbc.odbc.JdbcOdbc.standardError(JdbcOdbc.java:7121)
at sun.jdbc.odbc.JdbcOdbc.SQLExecute(JdbcOdbc.java:3156)
at sun.jdbc.odbc.JdbcOdbcPreparedStatement.execute(JdbcOdbcPreparedStatement.java:215)
at Inventory_System.Encoding_Incoming_Batch.cmdADDMouseReleased(Encoding_Incoming_Batch.java:1278)
at Inventory_System.Encoding_Incoming_Batch.access$3600(Encoding_Incoming_Batch.java:44)
at Inventory_System.Encoding_Incoming_Batch$30.mouseReleased(Encoding_Incoming_Batch.java:915)
at java.awt.AWTEventMulticaster.mouseReleased(AWTEventMulticaster.java:290)
at java.awt.Component.processMouseEvent(Component.java:6516)
at javax.swing.JComponent.processMouseEvent(JComponent.java:3321)
at java.awt.Component.processEvent(Component.java:6281)
at java.awt.Container.processEvent(Container.java:2229)
at java.awt.Component.dispatchEventImpl(Component.java:4872)
at java.awt.Container.dispatchEventImpl(Container.java:2287)
at java.awt.Component.dispatchEvent(Component.java:4698)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4832)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4492)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4422)
at java.awt.Container.dispatchEventImpl(Container.java:2273)
at java.awt.Window.dispatchEventImpl(Window.java:2719)
at java.awt.Component.dispatchEvent(Component.java:4698)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:747)
at java.awt.EventQueue.access$300(EventQueue.java:103)
at java.awt.EventQueue$3.run(EventQueue.java:706)
at java.awt.EventQueue$3.run(EventQueue.java:704)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:87)
at java.awt.EventQueue$4.run(EventQueue.java:720)
at java.awt.EventQueue$4.run(EventQueue.java:718)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:717)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:242)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:161)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:150)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:146)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:138)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:91)
BUILD STOPPED (total time: 1 minute 45 seconds)
最佳答案
PreparedStatement
应该与实际值的位置标记 (?
) 一起使用,这有助于防止 SQL 注入(inject)攻击,但也可以让您少考虑传递不同类型值所需的编码(例如 int
、double
和 Date
)。
因此,您无需在 sqlItems
中指定实际值,而是提供带有占位符的抽象查询,例如...
String sqlItems="INSERT INTO IncomingTransactionItems(Incoming_Transaction_Number, Transaction_ID,Item_Number, Quantity, Unit_Price,Total_Price)values(?,?,?,?,?, ?)"
然后,您将每列的值“绑定(bind)”到语句...
pst.setString(1, ItemList[0]);
其中 1
表示第一个通配符,2
表示第二个通配符,依此类推(请记住,这不是 0
索引的,它是 1
索引,其中 1
是可能的最低值)。
所以,它可能看起来更像这样......
int rowCount=jTable3.getRowCount();
String[] ItemList=new String[6];
String sqlItems="INSERT INTO IncomingTransactionItems(Incoming_Transaction_Number, Transaction_ID,Item_Number, Quantity, Unit_Price,Total_Price)values(?,?,?,?,?, ?)"
for(int rowctr=1;rowctr<rowCount;rowctr++){
ItemList[0]= String.valueOf(rowctr); // Incoming Transaction_Number
ItemList[1]= this.jTextField1.getText(); // Transaction ID
ItemList[2]=this.jTable3.getModel().getValueAt(rowctr, 0).toString(); // Item Number
ItemList[3]=this.jTable3.getModel().getValueAt(rowctr, 2).toString(); // Quantity
ItemList[4]=this.jTable3.getModel().getValueAt(rowctr, 3).toString(); // Unit Price
ItemList[5]=this.jTable3.getModel().getValueAt(rowctr, 4).toString(); // Total Price
try (PreparedStatement pst = conn.prepareStatement(sqlItems)){
// You could do this with a for-loop, I've done it long
// to demonstrate the use of PreparedStatement
pst.setString(1, ItemList[0]);
pst.setString(2, ItemList[1]);
pst.setString(3, ItemList[2]);
pst.setString(4, ItemList[3]);
pst.setString(5, ItemList[4]);
pst.setString(6, ItemList[5]);
pst.executeUpdate();
}
catch(SQLException | HeadlessException e){
Logger.getLogger(Encoding_Incoming_Batch.class.getName()).log(Level.SEVERE, null, e);
}
}
this.UpdateJTable();
这也意味着您可以做一些更像......的事情
pst.setLong(1, rowctr);
pst.setString(2, (String)this.jTable3.getModel().getValueAt(rowctr, 0));
pst.setInt(3, (int)this.jTable3.getModel().getValueAt(rowctr, 1));
pst.setInt(4, (int)this.jTable3.getModel().getValueAt(rowctr, 2));
pst.setDouble(5, (double)this.jTable3.getModel().getValueAt(rowctr, 3));
pst.setDouble(6, (double)this.jTable3.getModel().getValueAt(rowctr, 4));
并使用所需的数据类型为列值添加种子(我猜测此处的实际类型)
您还应该调用 executeUpdate
而不是 execute
,它可以为您提供有关操作的更多信息(例如受影响的行数)
看看Using Prepared Statements了解更多详情
I checked the Incoming Transaction Number-Primary Key of My Table, If I Might be SAving a duplicate Value but It does not because the Program gets the Number of Values in the Table and Increments it by one for a new record.
明智的做法是使用自动增量键,并且如果可能的话,不要在插入语句中包含主键,这可以克服可能的线程竞争条件
基于 Java General Error On Insert...??? 的信息,您当前的连接中可能存在未提交的更改,这会导致后续更新失败
假设连接
设置为autoCommit
,您可以简单地使用 try-with-resources
block 自动关闭连接(和 PreparedStatement
)
try (Connection conn = ) {
String query = "...";
try (PreparedStatement stmt = conn.prepareStatement(query)) {
if (stmt.executeUpdate() == 0) {
System.err.println("Possible error with update, did not update any rows");
}
}
} catch (SQLException exp) {
exp.printStackTrace();
}
否则您应该手动提交
更新
try (Connection conn = ) {
String query = "...";
try (PreparedStatement stmt = conn.prepareStatement(query)) {
if (stmt.executeUpdate() == 0) {
System.err.println("Possible error with update, did not update any rows");
} else {
conn.commit();
}
}
} catch (SQLException exp) {
exp.printStackTrace();
}
关于java - 获取表数据并保存到数据库 - SQLEXception 一般错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31444452/
我正在编写一个具有以下签名的 Java 方法。 void Logger(Method method, Object[] args); 如果一个方法(例如 ABC() )调用此方法 Logger,它应该
我是 Java 新手。 我的问题是我的 Java 程序找不到我试图用作的图像文件一个 JButton。 (目前这段代码什么也没做,因为我只是得到了想要的外观第一的)。这是我的主课 代码: packag
好的,今天我在接受采访,我已经编写 Java 代码多年了。采访中说“Java 垃圾收集是一个棘手的问题,我有几个 friend 一直在努力弄清楚。你在这方面做得怎么样?”。她是想骗我吗?还是我的一生都
我的 friend 给了我一个谜语让我解开。它是这样的: There are 100 people. Each one of them, in his turn, does the following
如果我将使用 Java 5 代码的应用程序编译成字节码,生成的 .class 文件是否能够在 Java 1.4 下运行? 如果后者可以工作并且我正在尝试在我的 Java 1.4 应用程序中使用 Jav
有关于why Java doesn't support unsigned types的问题以及一些关于处理无符号类型的问题。我做了一些搜索,似乎 Scala 也不支持无符号数据类型。限制是Java和S
我只是想知道在一个 java 版本中生成的字节码是否可以在其他 java 版本上运行 最佳答案 通常,字节码无需修改即可在 较新 版本的 Java 上运行。它不会在旧版本上运行,除非您使用特殊参数 (
我有一个关于在命令提示符下执行 java 程序的基本问题。 在某些机器上我们需要指定 -cp 。 (类路径)同时执行java程序 (test为java文件名与.class文件存在于同一目录下) jav
我已经阅读 StackOverflow 有一段时间了,现在我才鼓起勇气提出问题。我今年 20 岁,目前在我的家乡(罗马尼亚克卢日-纳波卡)就读 IT 大学。足以介绍:D。 基本上,我有一家提供簿记应用
我有 public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
我已经在 Java 中实现了带有动态类型的简单解释语言。不幸的是我遇到了以下问题。测试时如下代码: def main() { def ks = Map[[1, 2]].keySet()
一直提示输入 1 到 10 的数字 - 结果应将 st、rd、th 和 nd 添加到数字中。编写一个程序,提示用户输入 1 到 10 之间的任意整数,然后以序数形式显示该整数并附加后缀。 public
我有这个 DownloadFile.java 并按预期下载该文件: import java.io.*; import java.net.URL; public class DownloadFile {
我想在 GUI 上添加延迟。我放置了 2 个 for 循环,然后重新绘制了一个标签,但这 2 个 for 循环一个接一个地执行,并且标签被重新绘制到最后一个。 我能做什么? for(int i=0;
我正在对对象 Student 的列表项进行一些测试,但是我更喜欢在 java 类对象中创建硬编码列表,然后从那里提取数据,而不是连接到数据库并在结果集中选择记录。然而,自从我这样做以来已经很长时间了,
我知道对象创建分为三个部分: 声明 实例化 初始化 classA{} classB extends classA{} classA obj = new classB(1,1); 实例化 它必须使用
我有兴趣使用 GPRS 构建车辆跟踪系统。但是,我有一些问题要问以前做过此操作的人: GPRS 是最好的技术吗?人们意识到任何问题吗? 我计划使用 Java/Java EE - 有更好的技术吗? 如果
我可以通过递归方法反转数组,例如:数组={1,2,3,4,5} 数组结果={5,4,3,2,1}但我的结果是相同的数组,我不知道为什么,请帮助我。 public class Recursion { p
有这样的标准方式吗? 包括 Java源代码-测试代码- Ant 或 Maven联合单元持续集成(可能是巡航控制)ClearCase 版本控制工具部署到应用服务器 最后我希望有一个自动构建和集成环境。
我什至不知道这是否可能,我非常怀疑它是否可能,但如果可以,您能告诉我怎么做吗?我只是想知道如何从打印机打印一些文本。 有什么想法吗? 最佳答案 这里有更简单的事情。 import javax.swin
我是一名优秀的程序员,十分优秀!