我想在PostgreSQL數據庫中插入一條記錄。它的大部分字段都是String,但也有java.sql.date和BIGINT。我怎樣才能做到這一點?我的代碼似乎不工作。在查詢錯誤中插入不同的數據類型到postgreSQL中
public Record(RecordFields data)
{
CreateNewRecord(data);
}
private void CreateNewRecord(RecordFields recordFields)
{
try
{
String addRecord = "INSERT INTO " + GlobalFields.TABLE + " VALUES (? , ? , ? , ? , ? , ? , ? , ? , ?);";
Connection conn = DataBase.Connect();
PreparedStatement query = conn.prepareStatement(addRecord);
query.setLong(1, recordFieldsID);
query.setString(2, recordFields.surname);
query.setString(3, recordFields.name);
query.setString(4, recordFields.sex);
DateTime date = recordFields.bornDate.toDateTime();
query.setTimestamp(5, new Timestamp(date.getMillis()));
query.setString(6, recordFields.adress);
query.setString(7, recordFields.contact);
query.setString(8, recordFields.insurance);
query.setString(9, recordFields.commentary);
query.executeUpdate(addRecord);
}
catch(SQLException e)
{
e.printStackTrace();
}
}
表生成:
public static void CreateTable()
{
try
{
Connection conn = DataBase.Connect();
try
{
Statement stat = conn.createStatement();
String createTable = "CREATE TABLE " + GlobalFields.TABLE
+ "(id BIGINT PRIMARY KEY,"
+ "surname TEXT,"
+ "name TEXT,"
+ "sex CHAR(1),"
+ "bornDate DATE,"
+ "adress TEXT,"
+ "contact TEXT,"
+ "insurance TEXT,"
+ "commentary TEXT);";
stat.executeUpdate(createTable);
}
finally
{
conn.close();
}
}
catch(SQLException e)
{
e.printStackTrace();
}
}
公共類RecordFields { 公共RecordFields(){ }
public long id;
public String surname;
public String name;
public String sex;
public MutableDateTime bornDate;
public String adress;
public String contact;
public String insurance;
public String commentary;
}
你會得到什麼錯誤? –
也許你可以描述它是如何工作的。什麼是輸出?是否拋出異常?什麼是細節? – btiernay
org.postgresql.util.PSQLException:無法使用在PreparedStatement上接受查詢字符串的查詢方法。 \t at org.postgresql.jdbc2.AbstractJdbc2Statement.executeUpdate(AbstractJdbc2Statement。java:294) \t at EngineClasses.Record.CreateNewRecord(Pacjent.java:62) \t at EngineClasses.Record。(Record.java:37) \t at mainPackage.Test.main(Test.java:38) –